前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CentOS7下搭建ClickHouse集群

CentOS7下搭建ClickHouse集群

作者头像
yuanfan2012
发布2021-02-25 10:16:30
1.2K0
发布2021-02-25 10:16:30
举报
文章被收录于专栏:WalkingCloud

一、ClickHouse简单介绍

什么是ClickHouse?ClickHouse是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS)。

具体概念可以参考官方文档中的介绍:https://clickhouse.tech/docs/zh/

二、ClickHouse特点以及业务价值

(图片可放大查看)

(图片可放大查看)

(图片可放大查看)

三、CentOS7下搭建ClickHouse集群

1、基础环境介绍

三台CentOS7.9服务器(均可以访问互联网)

node1 192.168.31.121

node2 192.168.31.122

node3 192.168.31.123

(图片可放大查看)

2、利用脚本搭建zookeeper+clickhouse集群

具体操作步骤

代码语言:javascript
复制
cd /opt
rz上传clickhouse.zip
unzip clickhouse.zip
#所在节点执行对应的安装脚本
#例如node1执行sh jdk_zookeeper_clickhouse_node1.sh 
sh jdk_zookeeper_clickhouse_node1.sh 

(图片可放大查看)

jdk_zookeeper_clickhouse_node1.sh脚本内容如下

以node1为例

代码语言:javascript
复制
[root@node1 opt]# cat jdk_zookeeper_clickhouse_node1.sh 
#!/bin/bash
#wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
#sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo
#wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
#yum clean all
#yum makecache
echo "-----------基础环境配置----------------"
setenforce 0
sed -i 's/^SELINUX=.*$/SELINUX=disabled/' /etc/selinux/config
systemctl disable firewalld
systemctl stop firewalld

cat >> /etc/security/limits.conf << EOF
* soft nofile 65536 
* hard nofile 65536 
* soft nproc 131072 
* hard nproc 131072
EOF

cat >> /etc/security/limits.d/90-nproc.conf << EOF
* soft nofile 65536
* hard nofile 65536
* soft nproc 131072
* hard nproc 131072
EOF

cat >> /etc/hosts << EOF
192.168.31.121 node1
192.168.31.122 node2
192.168.31.123 node3
EOF

cat > /etc/yum.repos.d/clickhouse.repo << EOF
[repo.yandex.ru_clickhouse_rpm_stable_x86_64]
name=clickhouse stable
baseurl=https://mirrors.tuna.tsinghua.edu.cn/clickhouse/rpm/stable/x86_64
enabled=1
EOF

echo "-----------安装JDK----------------"
cd /opt
sleep 5
rpm -ivh jdk-8u251-linux-x64.rpm
echo "export JAVA_HOME=/usr/java/jdk1.8.0_251-amd64" >> /etc/profile
echo "export PATH=\$PATH:\$JAVA_HOME/bin" >> /etc/profile
echo "export CLASSPATH=.:\$JAVA_HOME/jre/lib:\$JAVA_HOME/lib:\$JAVA_HOME/lib/tools.jar" >> /etc/profile

echo "-----------安装zookeeper----------------"
cd /opt
tar -zxf apache-zookeeper-3.6.2-bin.tar.gz
mv apache-zookeeper-3.6.2-bin zookeeper
cd zookeeper
mkdir data
cd conf
cp zoo_sample.cfg zoo.cfg

sed -i "s#dataDir=/tmp/zookeeper#dataDir=/opt/zookeeper/data#g" zoo.cfg
echo "server.1=node1:2888:3888" >> zoo.cfg
echo "server.2=node2:2888:3888" >> zoo.cfg
echo "server.3=node3:2888:3888" >> zoo.cfg

echo 1 > /opt/zookeeper/data/myid
#echo 2 > /opt/zookeeper/data/myid
#echo 3 > /opt/zookeeper/data/myid

echo "export PATH=\$PATH:/opt/zookeeper/bin" >> /etc/profile
. /etc/profile

echo "-----------安装clickhouse---------------"
sed -i "s/gpgcheck=1/gpgcheck=0/g" /etc/yum.conf 
yum install clickhouse-server clickhouse-client -y
\cp -rf /opt/config_node1.xml /etc/clickhouse-server/config.xml
#\cp -rf /opt/config_node2.xml /etc/clickhouse-server/config.xml
#\cp -rf /opt/config_node3.xml /etc/clickhouse-server/config.xml
\cp -rf /opt/users.xml /etc/clickhouse-server/

mkdir -p /opt/clickhouse
chown -R clickhouse:clickhouse /opt/clickhouse


echo "-----------启动zookeeper---------------"
zkServer.sh start
sleep 2
zkServer.sh status

echo "-----------启动clickhouse---------------"
systemctl enable clickhouse-server 
systemctl start clickhouse-server 
systemctl status clickhouse-server 

sleep 2
echo "-----------clickhouse-client连接---------------"
clickhouse-client --user=ck --password=clickhouse2021 -m --host=node1 --port=9000
#clickhouse-client --user=ck --password=clickhouse2021 -m --host=node2 --port=9000
#clickhouse-client --user=ck --password=clickhouse2021 -m --host=node3 --port=9000

(图片可放大查看)

其中 config.xml中如下地方均做了修改 如下图所示

-- 1)、路径均修改为/opt/clickhouse目录

(图片可放大查看)

(图片可放大查看)

(图片可放大查看)

-- 2)、集群<remote_server>配置,<zookeeper>配置,以及 <macros>配置修改

(图片可放大查看)

(图片可放大查看)

其中<macros>配置不同节点配置不同,注意区分

当然我这里是三分片一副本的配置,可以根据自身实际环境进行修改

-- 3)、监听地址修改为0.0.0.0

<listen_host>0.0.0.0</listen_host>

(图片可放大查看)

-- 4)、users.xml中添加ck用户及密码等配置

(图片可放大查看)

3、集群状态验证

在node1上

代码语言:javascript
复制
zkServer.sh status
systemctl status clickhouse-server
clickhouse-client --user=ck --password=clickhouse2021 -m --host=node1 --port=9000
:)select * from system.clusters;

(图片可放大查看)

(图片可放大查看)

可以看到 cluster_clickhouse名称的集群信息说明集群搭建成功

clickhouse集群的简单搭建就介绍到这里

公众号后台回复clickhouse获取clickhouse.zip文件(安装脚本+相关依赖文件)及《ClickHouse知识讲解PPT.pptx》

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-02-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 WalkingCloud 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、ClickHouse简单介绍
  • 二、ClickHouse特点以及业务价值
  • 三、CentOS7下搭建ClickHouse集群
    • 1、基础环境介绍
      • 2、利用脚本搭建zookeeper+clickhouse集群
        • 3、集群状态验证
        相关产品与服务
        数据库智能管家 DBbrain
        数据库智能管家(TencentDB for DBbrain,DBbrain)是腾讯云推出的一款为用户提供数据库性能、安全、管理等功能的数据库自治云服务。DBbrain 利用机器学习、大数据手段、专家经验引擎快速复制资深数据库管理员的成熟经验,将大量传统人工的数据库运维工作智能化,服务于云上和云下企业,有效保障数据库服务的安全、稳定及高效运行。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档