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

从零到生产:在CentOS 8 Stream上部署ClickHouse集群的完整指南(含单机版前置步骤与性能调优建议)

从零到生产在CentOS 8 Stream上部署ClickHouse集群的完整指南ClickHouse作为一款开源的列式数据库管理系统凭借其卓越的查询性能和高吞吐量已成为大数据分析领域的明星产品。本文将带您从单机部署开始逐步构建一个面向生产环境的ClickHouse集群涵盖系统调优、配置优化以及集群扩展的全流程。1. 环境准备与基础配置在开始安装之前我们需要确保CentOS 8 Stream系统已做好充分准备。生产环境下的ClickHouse对系统资源有着较高要求特别是文件描述符和用户进程数。首先检查当前系统限制ulimit -a对于生产环境建议调整以下参数# 编辑limits.conf文件 sudo vi /etc/security/limits.conf # 添加以下内容 * soft nofile 1048576 * hard nofile 1048576 * soft nproc 131072 * hard nproc 131072关键系统优化项关闭透明大页(THP)echo never /sys/kernel/mm/transparent_hugepage/enabled调整swappinesssysctl vm.swappiness1禁用NUMA平衡sysctl kernel.numa_balancing0提示这些优化参数建议添加到/etc/sysctl.conf中实现永久生效2. ClickHouse单机版安装与配置2.1 官方仓库安装推荐使用官方仓库安装最新稳定版sudo yum install -y yum-utils sudo rpm --import https://repo.clickhouse.com/CLICKHOUSE-KEY.GZ sudo yum-config-manager --add-repo https://repo.clickhouse.com/rpm/stable/x86_64 sudo yum install -y clickhouse-server clickhouse-client2.2 关键配置文件调整生产环境需要特别关注以下几个配置文件config.xml核心参数max_memory_usage68719476736/max_memory_usage max_concurrent_queries100/max_concurrent_queries background_pool_size16/background_pool_sizeusers.xml内存限制示例max_memory_usage_for_user8589934592/max_memory_usage_for_user max_memory_usage_for_all_queries103079215104/max_memory_usage_for_all_queries2.3 数据目录规划生产环境建议将数据目录与系统盘分离sudo mkdir -p /data/clickhouse/{data,metadata,logs} sudo chown -R clickhouse:clickhouse /data/clickhouse修改config.xml中的对应路径path/data/clickhouse/data//path tmp_path/data/clickhouse/tmp//tmp_path user_files_path/data/clickhouse/user_files//user_files_path3. 生产环境性能调优3.1 内核参数优化创建/etc/sysctl.d/clickhouse.conf文件vm.swappiness 1 net.ipv4.tcp_syncookies 1 net.ipv4.tcp_max_syn_backlog 1024 net.core.somaxconn 4096 vm.overcommit_memory 23.2 ClickHouse服务配置关键性能参数参数推荐值说明max_threads物理核心数查询执行最大线程数max_memory_usage系统内存的80%单查询最大内存使用background_pool_size16-32后台操作线程数max_concurrent_queries100-200最大并发查询数3.3 存储引擎选择策略根据数据特点选择合适的表引擎MergeTree系列时序数据、日志分析ReplacingMergeTree需要去重的场景CollapsingMergeTree需要行级更新的场景Distributed集群环境必备4. 集群部署与扩展4.1 ZooKeeper/Keeper配置ClickHouse集群需要协调服务推荐使用ClickHouse Keeperzookeeper node index1 hostnode1/host port9181/port /node node index2 hostnode2/host port9181/port /node node index3 hostnode3/host port9181/port /node /zookeeper4.2 分片与副本配置在config.xml中定义集群拓扑remote_servers cluster_3shards_1replicas shard replica hostnode1/host port9000/port /replica /shard shard replica hostnode2/host port9000/port /replica /shard shard replica hostnode3/host port9000/port /replica /shard /cluster_3shards_1replicas /remote_servers4.3 分布式表创建在集群环境中需要创建Distributed表CREATE TABLE distributed_table ON CLUSTER cluster_3shards_1replicas AS local_table ENGINE Distributed(cluster_3shards_1replicas, default, local_table, rand())5. 监控与维护5.1 系统监控指标关键监控项包括查询延迟(P99/P95)内存使用率磁盘I/O吞吐量ZooKeeper延迟5.2 Prometheus集成配置/etc/clickhouse-server/config.d/prometheus.xmlyandex prometheus endpoint/metrics/endpoint port9363/port metricstrue/metrics eventstrue/events asynchronous_metricstrue/asynchronous_metrics /prometheus /yandex5.3 日常维护命令常用维护操作# 查看集群状态 SELECT * FROM system.clusters # 检查副本延迟 SELECT database, table, absolute_delay FROM system.replicas # 强制合并分区 OPTIMIZE TABLE table_name FINAL在实际生产部署中我们发现合理配置内存参数和并发控制是保证集群稳定性的关键。对于写入密集型场景建议适当增加background_pool_size并监控后台合并操作的状态。

相关文章:

从零到生产:在CentOS 8 Stream上部署ClickHouse集群的完整指南(含单机版前置步骤与性能调优建议)

从零到生产:在CentOS 8 Stream上部署ClickHouse集群的完整指南 ClickHouse作为一款开源的列式数据库管理系统,凭借其卓越的查询性能和高吞吐量,已成为大数据分析领域的明星产品。本文将带您从单机部署开始,逐步构建一个面向生产环…...

Bilibili评论爬虫:零基础获取B站完整评论数据的终极指南

Bilibili评论爬虫:零基础获取B站完整评论数据的终极指南 【免费下载链接】BilibiliCommentScraper B站视频评论爬虫 Bilibili完整爬取评论数据,包括一级评论、二级评论、昵称、用户ID、发布时间、点赞数 项目地址: https://gitcode.com/gh_mirrors/bi/…...

LSLib终极指南:轻松制作《神界原罪》与《博德之门3》游戏MOD的完整教程

LSLib终极指南:轻松制作《神界原罪》与《博德之门3》游戏MOD的完整教程 【免费下载链接】lslib Tools for manipulating Divinity Original Sin and Baldurs Gate 3 files 项目地址: https://gitcode.com/gh_mirrors/ls/lslib 想要为《神界原罪》系列或《博德…...

RimWorld Mod开发进阶:用状态机重构你的集群AI,告别行为树死板流程

RimWorld Mod开发进阶:用状态机重构集群AI的实战指南 在RimWorld的Mod开发中,AI行为设计一直是开发者面临的核心挑战之一。原生行为树系统虽然易于上手,但当我们需要实现复杂的多阶段动态事件时,其线性执行的局限性就会暴露无遗。…...

LeRobot机器人AI控制框架终极指南:5分钟快速上手实战教程

LeRobot机器人AI控制框架终极指南:5分钟快速上手实战教程 【免费下载链接】lerobot 🤗 LeRobot: Making AI for Robotics more accessible with end-to-end learning 项目地址: https://gitcode.com/GitHub_Trending/le/lerobot LeRobot是Hugging…...

在Jetson NX上搞定RealSense D435i:Ubuntu 18.04 + ROS Melodic 保姆级避坑实录

Jetson NX实战:RealSense D435i在Ubuntu 18.04与ROS Melodic环境下的深度集成指南 当机器人开发者尝试在边缘计算设备上部署深度视觉系统时,NVIDIA Jetson NX与Intel RealSense D435i的组合堪称黄金搭档。这套方案不仅具备强大的计算能力,还能…...

斯坦福大学教授李飞飞团队:2026年人工智能发展报告总结!

本文约5000字,建议阅读5分钟关于斯坦福大学教授李飞飞联合创始的HAI团队发布的2026年人工智能发展报告《2026人工智能指数报告》的最新总结。1. 研究与开发:产业界垄断加剧,美国吸引AI人才的速度10年来最低先看一个今年很扎眼的变化。2025年&…...

【实战】Windows平台LVGL模拟器快速上手:从CodeBlocks配置到首个GUI组件创建

1. Windows平台LVGL模拟器入门指南 第一次接触LVGL的朋友可能会被嵌入式开发吓到,但其实在Windows上就能轻松体验。我刚开始学LVGL时也以为必须买开发板,后来发现用CodeBlocks配合官方模拟器,完全可以在PC上跑起来。这种方式特别适合想快速验…...

不止于安装:将PVE里的Win10打造成你的主力远程开发/测试环境(含性能调优与安全加固)

不止于安装:将PVE里的Win10打造成你的主力远程开发/测试环境(含性能调优与安全加固) 在虚拟化技术日益成熟的今天,Proxmox VE(PVE)作为开源的虚拟化平台,已经成为许多开发者和IT专业人士的首选。…...

Mos终极指南:让Mac鼠标滚动如丝般顺滑的完美解决方案

Mos终极指南:让Mac鼠标滚动如丝般顺滑的完美解决方案 【免费下载链接】Mos 一个用于在 macOS 上平滑你的鼠标滚动效果或单独设置滚动方向的小工具, 让你的滚轮爽如触控板 | A lightweight tool used to smooth scrolling and set scroll direction independently fo…...

ORB-SLAM2跑KITTI数据集,除了看轨迹还能做什么?聊聊视觉里程计的实际评估与调参

ORB-SLAM2在KITTI数据集上的深度实践:从轨迹评估到参数调优 当你第一次看到ORB-SLAM2在KITTI数据集上成功运行并输出轨迹时,那种成就感确实令人振奋。但作为一名真正希望掌握视觉SLAM技术的开发者或研究者,这仅仅是探索旅程的起点。本文将带…...

终极指南:如何让Mac鼠标滚轮像触控板一样丝滑滚动

终极指南:如何让Mac鼠标滚轮像触控板一样丝滑滚动 【免费下载链接】Mos 一个用于在 macOS 上平滑你的鼠标滚动效果或单独设置滚动方向的小工具, 让你的滚轮爽如触控板 | A lightweight tool used to smooth scrolling and set scroll direction independently for y…...

Treble Check:安卓设备兼容性检测的强力工具

Treble Check:安卓设备兼容性检测的强力工具 【免费下载链接】treble Treble Compatibility Checking App 项目地址: https://gitcode.com/gh_mirrors/tr/treble Treble Check是一款专业的Android应用程序,专门用于检测设备对Project Treble架构、…...

别再只调PID了!从一场起重机大赛看机器人设计的系统思维:结构、电源与控制的平衡艺术

从起重机大赛看机器人设计的系统思维:结构、电源与控制的平衡艺术 在机器人设计领域,我们常常陷入对单一技术点的过度关注——比如如何优化PID参数、选择哪种传感器、使用什么控制算法。然而,真正决定一个机器人系统成败的,往往是…...

萤石2026新品发布会:AI驱动创新,以安全科技共创美好生活

萤石举办2026品牌新品发布会,展现AI创新成果4月21日,全球领先的安全智能生活品牌萤石在杭州正式举办2026品牌新品发布会。这场以“驭智向前”(Ahead with Intelligence)为主题的盛会,全景式展现了AI驱动下的创新成果&a…...

心理韧性+同伴支持

...

别再死记硬背波形图了!用LTspice仿真带你搞懂LLC谐振变换器的三种工作模式

用LTspice仿真破解LLC谐振变换器的三种工作模式 电源设计领域里,LLC谐振变换器因其高效率、低EMI特性成为业界宠儿,但它的三种工作模式却让不少工程师头疼。传统教材里密密麻麻的公式推导和静态波形图,总让人有种"看懂了却不会用"的…...

告别卡顿!在IMX6ULL上用LVGL 9.0+FFmpeg+OpenCV打造丝滑的本地监控GUI(附源码思路)

告别卡顿!在IMX6ULL上用LVGL 9.0FFmpegOpenCV打造丝滑的本地监控GUI 在嵌入式开发中,流畅的图形界面往往被视为奢侈的需求——尤其是当硬件平台采用像IMX6ULL这样的中低端处理器时。但现实情况是,越来越多的智能设备需要同时处理视频流和复杂…...

ZYNQ实战:手把手教你用LWIP实现UDP文件传输到DDR(附完整代码)

ZYNQ LWIP UDP文件传输实战:从协议栈配置到DDR存储的完整实现 在嵌入式系统开发中,网络通信功能已成为现代SoC设计的标配能力。Xilinx ZYNQ系列凭借其ARM处理器与可编程逻辑的完美结合,为开发者提供了灵活高效的网络通信解决方案。本文将深入…...

React新手必踩的坑:为什么你的对象(Object)在JSX里渲染不出来?

React对象渲染避坑指南:从原理到实战的深度解析 刚接触React的开发者们,你们是否曾在深夜调试时突然遭遇那个令人困惑的报错——"Objects are not valid as a React child"?这就像一堵无形的墙,挡住了你前进的道路。别担…...

用逻辑分析仪抓波形,手把手教你调试AT24C08的I2C读写时序(附代码避坑点)

用逻辑分析仪精准调试AT24C08的I2C通信:从波形捕获到代码优化的完整指南 当你在深夜调试一块无法正常读写的AT24C08 EEPROM芯片时,是否曾盯着示波器上那些跳动的波形感到无从下手?I2C通信作为嵌入式开发中最常见的协议之一,其看似…...

STM32 HAL库串口接收不定长数据实战:用定时器7实现MODBUS从机帧超时判断

STM32 HAL库串口接收不定长数据的工程实践:基于定时器的MODBUS帧超时检测方案 在嵌入式通信协议开发中,可靠接收不定长数据帧是个经典难题。当我们需要实现MODBUS RTU从机时,如何准确判断一帧数据的结束位置尤为关键。虽然HAL库提供了UART_ID…...

基于springboot网上电子书店商城好书推荐管理系统 论坛

目录同行可拿货,招校园代理 ,本人源头供货商功能模块分析推荐与论坛功能技术实现要点项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 功能模块分析 用户管理模块 用户注册与登录&…...

基于springboot的高校教材订阅选购管理系统

目录同行可拿货,招校园代理 ,本人源头供货商高校教材订阅选购管理系统的功能分析用户管理模块教材管理模块订阅与选购模块订单与支付模块统计与报表模块系统管理模块技术实现要点扩展功能(可选)项目技术支持源码获取详细视频演示 :文章底部获…...

基于springboot的银行储蓄存业务系统

目录同行可拿货,招校园代理 ,本人源头供货商核心功能模块业务处理功能辅助功能模块技术实现要点项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 核心功能模块 账户管理 支持个人/企业…...

基于springboot的在线教育课程购买作业平台

目录同行可拿货,招校园代理 ,本人源头供货商核心功能模块交易与学习功能作业评估系统技术实现要点扩展功能方向项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 核心功能模块 用户管理模…...

基于springboot的在线导游预约系统

目录同行可拿货,招校园代理 ,本人源头供货商核心功能模块预约与交易功能后台管理功能扩展功能设计项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 核心功能模块 用户管理模块 注册与登…...

QMK Toolbox:解锁机械键盘自定义潜能的终极工具

QMK Toolbox:解锁机械键盘自定义潜能的终极工具 【免费下载链接】qmk_toolbox A Toolbox companion for QMK Firmware 项目地址: https://gitcode.com/gh_mirrors/qm/qmk_toolbox 想让你心爱的机械键盘拥有超乎想象的功能吗?厌倦了千篇一律的按键…...

Mac鼠标滚轮终极救星:3分钟告别卡顿,体验丝滑滚动

Mac鼠标滚轮终极救星:3分钟告别卡顿,体验丝滑滚动 【免费下载链接】Mos 一个用于在 macOS 上平滑你的鼠标滚动效果或单独设置滚动方向的小工具, 让你的滚轮爽如触控板 | A lightweight tool used to smooth scrolling and set scroll direction independ…...

SpringBoot项目里,用dynamic-datasource搞定多库读写分离和事务,保姆级避坑指南

SpringBoot多数据源实战:dynamic-datasource深度整合与避坑手册 当你的应用流量开始突破单库性能瓶颈,或是业务需要接入多个异构数据库时,如何优雅管理数据源连接就成了必须面对的工程难题。最近在重构公司订单系统时,我亲历了从…...