前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >clickhouse断电导致的启动失败

clickhouse断电导致的启动失败

作者头像
编码如写诗
发布2024-08-30 11:29:07
990
发布2024-08-30 11:29:07
举报
文章被收录于专栏:编码如写诗

使用docker-compose部署的clickhouse

错误日志:

将错误日志复制到当前目录下

代码语言:javascript
复制
docker cp clickhouse:/var/log/clickhouse-server/clickhouse-server.err.log ./

查看其中的错误信息

总结一下报错关键字:

  • Detaching broken part
  • DB::Exception: Suspiciously many (15) broken parts to remove

原因

  • 异常断电后,文件系统可能会出现问题,尤其是一些在不断进行读写合并的文件。由于clickhouse是开源列式存储数据库,服务器断电后,写入数据导致元数据与数据不一致。clickhouse在重启服务的时候会重新加载MergeTree表引擎数据,数据可能存在损坏情况。
  • clickhouse配置参数当中包含一个参数max_suspicious_broken_parts(默认路径 /etc/clickhouse-server/config.xml),默认值是10,可选范围是任意正整数。如果单个分区的损坏部分数量超过max_suspicious_broken_parts配置的值,则拒绝自动修复或者拒绝删除损坏部分的数据,并且在服务启动时直接报错退出。
  • 目前需要尽量避免该错误以免服务启动失败,推荐把该参数配置为1000或者更大的值。

解决:

修改配置文件方式:

新建max_suspicious_broken_parts.xml文件写入如下内容。clickhouse的配置文件推荐放置在/etc/clickhouse-server/config.d/文件夹下生效。

代码语言:javascript
复制
<?xml version="1.0"?>
<yandex>
    <merge_tree>
        <max_suspicious_broken_parts>9999</max_suspicious_broken_parts>
    </merge_tree>
</yandex>

docker-compose新增如下映射

代码语言:javascript
复制
- /home/app/proxy-statistics/ch/config/max_suspicious_broken_parts.xml:/etc/clickhouse-server/config.d/max_suspicious_broken_parts.xml
代码语言:javascript
复制
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编码如写诗 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 使用docker-compose部署的clickhouse
  • 错误日志:
  • 原因
  • 解决:
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档