docker安装clickhouse(单机版)

docker安装clickhouse

1、docker安装clickhouse(单机版)

1.1、主机映射容器目录配置

容器数据相关的文件夹需要挂载到宿主机上, 分别有:clickhouse的配置文件、数据文件、日志文件。进而实现Clickhouse数据持久化, 方便数据备份、迁移、恢复。

宿主机对应文件夹:

bash 复制代码
#配置文件夹
mkdir -p /data/clickhouse/conf
#日志文件夹
mkdir -p /data/clickhouse/log
#数据文件夹
mkdir -p /data/clickhouse/data

为了拿配置文件,起个临时的容器

bash 复制代码
docker run --rm -d --name=temp-clickhouse-server clickhouse/clickhouse-server:22.12

复制配置文件到宿主机

bash 复制代码
docker cp temp-clickhouse-server:/etc/clickhouse-server/users.xml /data/clickhouse/conf/users.xml
docker cp temp-clickhouse-server:/etc/clickhouse-server/config.xml /data/clickhouse/conf/config.xml

删除临时容器

bash 复制代码
docker rm -f temp-clickhouse-server

1.2、添加用户

添加用户,编辑users.xml文件,在 标签下添加下面内容。
安装好后,用户名/密码:root/root就可以访问了

bash 复制代码
vi /data/clickhouse/conf/users.xml

<root>
    <password_sha256_hex>4813494d137e1631bba301d5acab6e7bb7aa74ce1185d456565ef51d737677b2</password_sha256_hex>
	<networks incl="networks" replace="replace">
		<ip>::/0</ip>
	</networks>
	<profile>default</profile>
	<quota>default</quota>
</root>

获得password_sha256_hex内容

bash 复制代码
echo -n "root" | sha256sum | tr -d '-'

1.3、修改config.xml,如果不改下面内容,副本集群不同步数据

还需要修改配置文件config.xml,加上后,后面搭建副本集群,才能同步数据。

bash 复制代码
vi /data/clickhouse/conf/config.xml
#放开注释
<interserver_http_port>9009</interserver_http_port>
#放开注释,修改为本机IP
#不能是127.0.0.1 ,localhost之类的,不然别的主机读不到这台机
<interserver_http_host>192.168.52.7</interserver_http_host>

1.4、启动容器和容器参数解释

bash 复制代码
sudo docker run -d --restart=always --name=ck01 \
		-p 9000:9000 -p 8123:8123 -p 9009:9009 \
		-e TZ=Asia/Shanghai \
		--volume=/data/clickhouse/conf/config.xml:/etc/clickhouse-server/config.xml \
		--volume=/data/clickhouse/conf/users.xml:/etc/clickhouse-server/users.xml \
		--volume=/data/clickhouse/log:/var/log/clickhouse-server \
		--volume=/data/clickhouse/data:/var/lib/clickhouse/ \
		clickhouse/clickhouse-server:22.12
dart 复制代码
参数解释:
-d:将容器设置为在后台运行。
--name=ck01:给容器指定一个名称,这里是 "ck01"。
-p 8123:8123:将主机的 8123 端口映射到容器的 8123 端口,用于通过 HTTP 访问 ClickHouse 的查询服务。
-p 9009:9009: 用来副本间传数据的地址端口,端口默认配好了是9009。
-p 9000:9000: 本地协议端口,即clickhouse的tcp协议端口。用于通过TCP/IP协议与ClickHouse数据库进行交互。
-e TZ=Asia/Shanghai:设置容器的时区为亚洲/上海,以适应上海时区的时间。
--volume 容器和本机文件映射。
clickhouse/clickhouse-server:22.12:基于 ClickHouse 22.12 版本的 Docker 镜像,用于启动 ClickHouse 服务。

创建数据库命令

bash 复制代码
CREATE DATABASE IF NOT EXISTS example_db;

2、命令行对clickhouse增删改查

bash 复制代码
#进入容器
docker exec -it ck01 bash
#进入命令行交互(默认无密码访问)
clickhouse-client
#指定用户名密码访问
clickhouse-client -u root --password root

#创建数据库
CREATE DATABASE IF NOT EXISTS example_db;
#查看数据库
show databases;
#进入指定数据库
use defalut;
#查询库里面的所有表
show tables;
#查看表的创建语句
show CREATE  table t_order_rep;
相关推荐
心有—林夕9 分钟前
两个事务间的传播机制
java·事务
疯狂成瘾者13 分钟前
什么是多 Agent,多Agent是如何协作的?
java
he___H20 分钟前
Spring中的设计模式
java·spring·设计模式
liuyao_xianhui26 分钟前
优选算法_最小基因变化_bfs_C++
java·开发语言·数据结构·c++·算法·哈希算法·宽度优先
做一个AK梦28 分钟前
计算机系统概论知识点(软件设计师)
java·开发语言
東雪木1 小时前
Java学习——一访问修饰符(public/protected/default/private)的权限控制本质
java·开发语言·学习·java面试
两点王爷1 小时前
docker 创建和使用存储卷相关内容
java·docker·容器
boonya1 小时前
Embedding模型与向量维度动态切换完整方案
java·数据库·embedding·动态切换大模型
宁波阿成1 小时前
族谱管理系统架构分析与亮点总结
java·系统架构·vue·ruoyi-vue·族谱
姬成韶1 小时前
BUUCTF--[RoarCTF 2019]Easy Java
java·网络安全