当前位置: 首页 > article >正文

保姆级教程:手把手教你用第三种方法修复ClickHouse只读表(附详细命令)

ClickHouse表只读状态精准修复实战指南遇到ClickHouse表突然变成只读状态就像开车时突然发现方向盘锁死一样让人措手不及。这种状况通常发生在ZooKeeper压力过大或元数据丢失时但别担心本文将带你深入理解问题本质并掌握一种精准修复单表的高级技巧——通过删除本地数据文件、元数据及ZooKeeper中对应副本路径来重建表结构完全不影响其他正常表和数据。1. 问题诊断与前期准备在动手修复之前我们需要像医生问诊一样先确认病情。执行以下查询可以快速锁定问题表SELECT table, zookeeper_path, replica_path FROM system.replicas WHERE is_readonly 1这个查询会返回三个关键信息table处于只读状态的表名zookeeper_path表在ZooKeeper中的存储路径replica_path副本在ZooKeeper中的具体位置重要检查清单操作前必看确认ClickHouse服务账户对数据目录有读写权限备份重要表数据即使我们要修复的就是数据问题记录下原始表的CREATE TABLE语句可通过SHOW CREATE TABLE获取确保ZooKeeper集群状态健康避免在ZooKeeper不稳定时操作提示建议在操作前先执行SYSTEM SYNC REPLICA table_name尝试自动修复如果无效再继续后续步骤。2. 精准删除表残留数据传统方法要么需要重命名表影响应用要么需要重建整个节点影响其他表。而我们将采用外科手术式的精准删除# 删除本地数据文件替换为实际数据库名和表名 rm -rf /var/lib/clickhouse/data/database_name/table_name # 删除元数据文件 rm -rf /var/lib/clickhouse/metadata/database_name/table_name.sql路径确认技巧默认安装路径通常是/var/lib/clickhouse/使用ls -l /var/lib/clickhouse/data/可以查看所有数据库目录通过du -sh /var/lib/clickhouse/data/database_name/table_name可确认目录大小风险防控措施在执行rm命令前先用ls确认路径正确考虑先mv移动文件而非直接删除对生产环境建议先在测试环境演练3. ZooKeeper元数据清理实战ZooKeeper中残留的元数据是导致表只读的常见原因我们需要像清除电脑注册表一样清理这些僵尸条目。连接ZooKeeper并删除对应路径/usr/bin/zkCli.sh rmr /clickhouse/tables/shard_name/table_name/replicas/replica_name操作详解使用zkCli.sh连接ZooKeeper路径可能因安装方式不同而异执行ls /clickhouse/tables查看所有分片找到问题表对应的路径来自之前的查询结果使用rmr命令递归删除该路径注意ZooKeeper操作具有即时性删除后无法撤销请务必确认路径准确。常见问题处理如果遇到Authentication failed错误需要配置ZooKeeper权限使用stat命令可以查看节点状态信息操作完成后建议执行sync命令确保变更持久化4. 表重建与数据同步现在我们已经清除了所有病灶接下来就是让表重生的过程。首先重启ClickHouse服务非必须但推荐systemctl restart clickhouse-server然后使用原始CREATE TABLE语句重建表结构CREATE TABLE database_name.table_name ( -- 原始列定义 ) ENGINE ReplicatedReplacingMergeTree( /clickhouse/tables/{shard}/table_name, {replica} ) -- 其他原始参数关键点解析必须使用与原表完全相同的结构定义ENGINE参数中的路径需要与之前删除的ZooKeeper路径一致表创建后会自动从其他副本同步数据验证数据同步状态SELECT table, is_readonly, absolute_delay FROM system.replicas WHERE table table_name健康状态指标is_readonly应该变为0absolute_delay会显示同步延迟正常应逐渐减小至05. 高级技巧与深度优化对于大型集群或特殊场景我们还需要掌握一些进阶技巧。批量处理多个只读表#!/bin/bash # 自动处理所有只读表 clickhouse-client -q SELECT concat(rm -rf /var/lib/clickhouse/data/, database, /, table), concat(rm -rf /var/lib/clickhouse/metadata/, database, /, table, .sql), concat(echo \rmr , zookeeper_path, /replicas/, replica_name, \ | /usr/bin/zkCli.sh) FROM system.replicas WHERE is_readonly 1 fix_script.sh预防只读表再次出现ZooKeeper优化配置!-- 在zookeeper配置中添加 -- tcp_keep_alive_timeout60/tcp_keep_alive_timeout operation_timeout_ms10000/operation_timeout_ms session_timeout_ms30000/session_timeout_ms监控告警设置-- 创建监控系统使用的物化视图 CREATE MATERIALIZED VIEW system.replica_alerts ENGINE MergeTree() ORDER BY (event_time) AS SELECT now() AS event_time, table, readonly_alert AS alert_type FROM system.replicas WHERE is_readonly 1定期维护建议每月检查ZooKeeper磁盘空间使用情况设置合理的ZooKeeper日志滚动策略考虑使用SSD存储ZooKeeper数据目录6. 疑难问题排查指南即使按照上述步骤操作偶尔也会遇到特殊情况。以下是几个真实案例的解决方案案例一数据不同步-- 检查副本状态 SELECT * FROM system.replication_queue -- 手动触发同步 SYSTEM SYNC REPLICA table_name -- 如果仍然失败尝试重置副本 SYSTEM RESTART REPLICA table_name案例二ZooKeeper路径不一致# 查找表在所有节点上的路径 for node in node1 node2 node3; do ssh $node find /var/lib/clickhouse -name table_name done案例三权限问题修复# 修复ClickHouse数据目录权限 chown -R clickhouse:clickhouse /var/lib/clickhouse chmod -R 755 /var/lib/clickhouse最后分享一个实用技巧在操作前创建一个临时标记文件这样即使中断也能知道操作进行到哪一步touch /tmp/clickhouse_repair_started # 各步骤操作... rm /tmp/clickhouse_repair_started

相关文章:

保姆级教程:手把手教你用第三种方法修复ClickHouse只读表(附详细命令)

ClickHouse表只读状态精准修复实战指南 遇到ClickHouse表突然变成只读状态,就像开车时突然发现方向盘锁死一样让人措手不及。这种状况通常发生在ZooKeeper压力过大或元数据丢失时,但别担心,本文将带你深入理解问题本质,并掌握一种…...

ESP32 RMT驱动WS2812灯条:从官方例程到彩虹跑马灯,一份避坑指南

ESP32 RMT驱动WS2812灯条:从基础到高级特效的实战指南 当你在深夜的工作室里,看着一排WS2812灯条随着代码的节奏流淌出绚丽的色彩,那种将数字信号转化为视觉艺术的成就感,正是嵌入式开发的魅力所在。ESP32的RMT外设与WS2812的结合…...

xrdp技术深度解析:开源RDP服务器的架构设计与企业级应用

xrdp技术深度解析:开源RDP服务器的架构设计与企业级应用 【免费下载链接】xrdp xrdp: an open source RDP server 项目地址: https://gitcode.com/gh_mirrors/xrd/xrdp xrdp作为一个开源的远程桌面协议(RDP)服务器实现,为L…...

别再只会apt update了!深度解析Ubuntu/Debian的sources.list与‘package has no installation candidate’的底层逻辑

从源码到候选包:APT系统深度诊断指南 当你在Ubuntu上执行apt install时,背后发生了什么?为什么有些包会神秘地"没有安装候选"?这次我们不再停留在"换源-update三板斧",而是深入APT系统内部&#x…...

避开PyTorch新手坑:正确搭建LeNet/AlexNet模型的结构与参数设置详解

PyTorch经典CNN实现避坑指南:从LeNet到AlexNet的维度计算与参数设计 当你在PyTorch中第一次尝试实现经典的卷积神经网络时,是否曾被各种参数设置搞得晕头转向?卷积核大小、步长、填充这些看似简单的数字背后,隐藏着怎样的数学逻辑…...

告别手动改图!用FME+Python搞定GIS数据五大拓扑错误(附完整模板)

从数据质检到智能修复:FME与Python联袂解决GIS拓扑难题 当一份布满尖锐角、自相交和缝隙的GIS数据摆在面前时,许多工程师的第一反应可能是头皮发麻。传统手动修复不仅耗时费力,还容易引入新的错误。本文将揭示如何通过FME Workbench与Python脚…...

VoiceFixer终极指南:一键修复受损录音的AI音频救星

VoiceFixer终极指南:一键修复受损录音的AI音频救星 【免费下载链接】voicefixer General Speech Restoration 项目地址: https://gitcode.com/gh_mirrors/vo/voicefixer 你是否曾为老旧录音中的噪音和失真而烦恼?VoiceFixer是一款开源的AI音频修复…...

如何为你的项目选择最佳开源中文字体:WenQuanYi Micro Hei技术深度解析

如何为你的项目选择最佳开源中文字体:WenQuanYi Micro Hei技术深度解析 【免费下载链接】fonts-wqy-microhei Debian package for WenQuanYi Micro Hei (mirror of https://anonscm.debian.org/git/pkg-fonts/fonts-wqy-microhei.git) 项目地址: https://gitcode.…...

闽老师-天道 vs 人道

天道 vs 人道:一张图看透《道德经》与人生觉醒的底层逻辑 🔑 关键区分: 天道:宇宙运行的真实法则(如四季更替、供需平衡)人道:人类社会的运作系统人性:人本能的趋利避害文化属性&…...

华为eNSP模拟器上ACL配置的5个实战避坑点(附Serial线特殊场景)

华为eNSP模拟器ACL配置实战:5个关键陷阱与解决方案 当你在深夜的实验室里盯着屏幕上闪烁的命令行,反复检查那条看似完美的ACL规则却依然无法阻挡测试流量时,是否怀疑过是模拟器在"欺骗"你?作为华为网络技术学习者的标配…...

Python老师福音:用xlwings+requests自动抓取iCode学生刷题数据,解放双手

Python教学自动化:用xlwingsrequests打造智能刷题监控系统 每周五下午三点,李老师都会准时打开电脑,开始他耗时两小时的"数据搬运"工作——手动登录三十多名学生的编程训练平台账号,逐个记录他们在四个训练场的刷题进度…...

FPGA实战:手把手教你用DDS生成1MHz正弦波(附完整代码)

FPGA实战:从零构建1MHz正弦波发生器的工程指南 在数字信号处理领域,直接数字频率合成(DDS)技术因其高精度、快速切换和灵活配置的特性,已成为现代电子系统中的核心技术之一。本文将带领FPGA初学者和需要快速实现DDS功能…...

从零手搓一个DES-CBC加密库:用C语言一步步还原经典算法(附完整源码)

从零手搓一个DES-CBC加密库:用C语言一步步还原经典算法(附完整源码) 在嵌入式系统和教学场景中,理解加密算法的底层实现往往比单纯调用现成库更有价值。本文将带你从零开始实现DES-CBC加密算法,不仅剖析每个核心组件的…...

ENVI 5.3在Win10/Win11安装踩坑实录:MSVC_2010报错、license消失、远程桌面打不开,一次搞定

ENVI 5.3在Win10/Win11安装全攻略:从报错排查到系统级优化 第一次在Windows 10或11上安装ENVI 5.3的经历,对很多遥感领域的从业者来说简直是一场噩梦。我清楚地记得那个深夜,实验室只剩下我一个人对着屏幕上反复出现的MSVC_2010安装失败提示束…...

egergergeeert镜像价值:FLUX.1-dev路线+定制LoRA=小算力下的高表现平衡点

egergergeeert 文生图使用手册 1. 平台介绍 egergergeeert 是一套面向图像创作场景的文生图镜像,支持通过输入提示词直接生成图片,适合用于插画草图、角色图、视觉概念图和宣传图生成。 本镜像当前采用的模型组合为: 基础模型:…...

Koikatu HF Patch终极指南:如何快速优化你的Koikatsu游戏体验

Koikatu HF Patch终极指南:如何快速优化你的Koikatsu游戏体验 【免费下载链接】KK-HF_Patch Automatically translate, uncensor and update Koikatu! and Koikatsu Party! 项目地址: https://gitcode.com/gh_mirrors/kk/KK-HF_Patch Koikatu HF Patch是一款…...

7个秘诀快速掌握RPFM:全面战争模组编辑器的终极指南

7个秘诀快速掌握RPFM:全面战争模组编辑器的终极指南 【免费下载链接】rpfm Rusted PackFile Manager (RPFM) is a... reimplementation in Rust and Qt5 of PackFile Manager (PFM), one of the best modding tools for Total War Games. 项目地址: https://gitco…...

IDM试用重置终极指南:免费无限续期30天的完整解决方案

IDM试用重置终极指南:免费无限续期30天的完整解决方案 【免费下载链接】idm-trial-reset Use IDM forever without cracking 项目地址: https://gitcode.com/gh_mirrors/id/idm-trial-reset 还在为Internet Download Manager(IDM)试用…...

终极指南:3种方法激活Beyond Compare 5专业版

终极指南:3种方法激活Beyond Compare 5专业版 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen Beyond Compare密钥生成器是一个基于Python开发的专业工具,专门用于生成Bey…...

微信小程序体验版请求数据失败的3个常见原因及解决方法(附详细排查步骤)

微信小程序体验版请求数据失败的深度排查指南 当你在微信开发者工具中测试一切正常,但发布体验版后却遭遇数据请求失败时,这种落差感会让任何开发者感到沮丧。本文将带你系统梳理微信小程序体验版数据请求失败的三大核心症结,并提供一套完整…...

【泛微E9开发】ESB中心:从零到一的异构系统集成实战

1. ESB中心入门:为什么需要异构系统集成? 第一次接触泛微E9的ESB中心时,我和大多数开发者一样充满疑惑:为什么OA系统需要集成其他业务系统?简单来说,企业日常运营中会产生大量数据流转需求。比如销售人员在…...

Android Studio中文界面终极指南:3分钟快速实现完整汉化

Android Studio中文界面终极指南:3分钟快速实现完整汉化 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 你是否曾经在…...

网络小白也能懂:用H3C S5500-SI的LLDP功能,5分钟搞定交换机邻居发现与链路监控

网络拓扑可视化实战:H3C S5500-SI交换机LLDP功能深度解析 走进机房,面对错综复杂的网线和成排的交换机设备,你是否经常困惑某根网线究竟连接到哪里?传统的手工记录方式不仅效率低下,还容易出错。这就是LLDP&#xff08…...

镜像供应链攻击频发,你还在跳过签名验证?27个必须执行的Docker签名验证步骤,现在不看明天被黑

第一章:镜像供应链攻击的现状与签名验证的生死线 近年来,容器镜像供应链攻击呈爆发式增长。攻击者不再直接入侵运行时环境,而是将恶意代码注入构建阶段——篡改基础镜像、劫持CI/CD流水线、伪造Docker Hub账号上传带后门的镜像。2023年CNCF报…...

别再搞混了!博图SCL实现‘先进先出’的两种写法与核心区别

博图SCL中两种"先进先出"实现逻辑的深度解析与工业场景适配 在工业自动化编程中,"先进先出"(FIFO)是最基础却最容易引发混淆的概念之一。许多工程师第一次接触SCL语言实现队列时,往往会惊讶地发现&#xff1a…...

别再死记硬背了!用Python+NumPy手把手教你搞定任意倾斜椭圆的参数拟合

用PythonNumPy实战任意倾斜椭圆的参数拟合 在计算机视觉和工业检测领域,椭圆拟合是一项基础但关键的技术。想象一下这样的场景:生产线上的摄像头捕捉到的圆形零件由于拍摄角度变成了椭圆形,天文望远镜拍摄的星体轨道呈现倾斜椭圆形态&#xf…...

如何用 JavaScript 实现单选式盒子颜色切换(点击高亮,其余复原)

本文详解如何使用原生 JavaScript 实现“单选高亮”效果:点击任一 .box 元素时,仅该元素变为指定颜色,其余同组元素自动恢复默认背景色。 本文详解如何使用原生 javascript 实现“单选高亮”效果:点击任一 .box 元素时&#…...

神通数据库Oscar.conf安全加固指南:从审计日志到访问控制的实战配置

神通数据库Oscar.conf安全加固实战:从审计日志到访问控制的深度配置 在企业级数据库运维中,安全配置从来不是简单的参数开关切换。当面对神通数据库的Oscar.conf配置文件时,我们需要理解每个安全参数背后的攻防逻辑,以及如何通过组…...

别再只记概念了!通过调试DES-CBC的C代码,彻底搞懂分组密码的‘链’是怎么连起来的

调试DES-CBC:用代码可视化理解分组密码的链式奥秘 当你在教科书上读到"分组密码"和"链式加密"这些术语时,是否感觉它们就像数学公式一样抽象难懂?作为开发者,我们更习惯通过代码和调试器来理解事物。本文将带…...

别再只扫端口了!用Nmap+Responder组合拳,教你挖掘Windows靶机隐藏的认证漏洞

从Web漏洞到域控:Nmap与Responder的深度协同攻击实战 当大多数渗透测试者还在机械地扫描端口时,真正的红队专家已经开始思考如何将看似孤立的漏洞串联成完整的攻击链。本文将揭示一个经典但常被忽视的攻击路径:如何通过Web应用的LFI漏洞触发W…...