Docker快速部署clickhouse
Clickhouse特点
- 完备的DBMS:不仅是个数据库,也是个数据库系统
- 列存储和数据压缩:典型的olap数据库特性
- 向量化并行:利用CPU的SIMD(Single INstruction MUltiple Data),单条指令操作多条数据
- 多线程并行:向量化并行利用硬件采取数据并行(缺陷:不适应较多分支的判断),多线程级并行提高并发
- 关系模型:有数据库、表、视图和函数。更好清晰的描述实体间的关系
- SQL:极高的群众基础
- 多样化表引擎:合并树、内存、文件、接口等20多种表引擎
- 多主架构:天然避免单点故障,服务端对客户端都是“孪生兄弟”
- 分布式:分区、分片
Docker快速部署
-
创建目录
cd /var/data/test_clickhouse-server mkdir {conf,database,log}
-
拷贝默认配置文件
# 因我们无默认配置文件,那么就先运行一个临时容器,然后再将容器内的临时文件拷贝出来,如果你本身就有配置文件可以省略直接上传到conf目录下即可 docker run --rm --name tmp --ulimit nofile=262144:262144 yandex/clickhouse-server docker cp tmp:/etc/clickhouse-server/users.xml /var/data/clickhouse/conf/users.xml docker cp tmp:/etc/clickhouse-server/config.xml /var/data/clickhouse/conf/config.xml
-
生成密码
# 这一步如果你不需要密码就跳过,需要操作一下 # 我们生成一个double_shal 加密密码,密码是 123 echo "123"; echo -n "123" | sha1sum | tr -d '-' | xxd -r -p | sha1sum | tr -d '-' ## 明文 123 ## 密文 23ae809ddacaf96af0fd78ed04b6a265e05aa257
-
修改
users.xml
配置同理,不需要配置密码的就省略这一步吧。
看图
-
运行容器
docker run -itd --name test_clickhouse-server --ulimit nofile=262144:262144 -p 28123:8123 -p 29000:9000 -p 29009:9009 -v /var/data/test_clickhouse/database:/var/lib/clickhouse:rw -v /var/data/test_clickhouse/conf/config.xml:/etc/clickhouse-server/config.xml -v /var/data/test_clickhouse/conf/users.xml:/etc/clickhouse-server/users.xml -v /var/data/test_clickhouse/log:/var/log/clickhouse-server:rw yandex/clickhouse-server:19.17.5.18
- 测试
# 进入容器
docker exec -it test_clickhouse-server bash
# 连接clickhouse
clickhouse-client --password "123"
# 查看库
show databases;
## 或者在其他其他上通过http接口测试是否能连通
echo 'show databases' | curl 'http://127.0.0.1:28123/?user=default&password=123' -d @-
## 如果本地可以通,其他主机连不通的话则看一下防火墙是否打开端口了,没有的开放一下
firewall-cmd --zone=public --add-port=28123/tcp --permanent
firewall-cmd --zone=public --add-port=29000/tcp --permanent
firewall-cmd --zone=public --add-port=29009/tcp --permanent
注意:ClickHouse默认的用户是default,密码则是你设置的密码