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;
相关推荐
曹牧2 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法3 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7253 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎3 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄3 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
金刚猿3 小时前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
忆~遂愿3 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds3 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹3 小时前
【Java基础】多态 | 打卡day2
java·开发语言
Re.不晚4 小时前
JAVA进阶之路——无奖问答挑战2
java·开发语言