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;
相关推荐
薯条不要番茄酱7 分钟前
【SpringBoot】从零开始全面解析SpringMVC (三)
java·spring boot·后端
IDRSolutions_CN34 分钟前
PDF 合并测试:性能与内容完整性
java·经验分享·pdf·软件工程·团队开发
TDengine (老段)35 分钟前
TDengine 在新能源领域的价值
java·大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
helloworld工程师36 分钟前
Java实现PDF加水印功能:技术解析与实践指南
java·开发语言·pdf
编程乐学(Arfan开发工程师)1 小时前
10、底层注解-@Conditional条件装配
java·spring boot·后端·架构
爬菜1 小时前
包装类(1)
java
带刺的坐椅1 小时前
高德地图 MCP,可用 Java SolonMCP 接入(支持 java8, java11, java17, java21)
java·ai·solon·高德地图·lbs·mcp
AA-代码批发V哥1 小时前
Java-List集合类全面解析
java·开发语言·list
cainiao0806051 小时前
Java大数据机器学习模型在金融衍生品风险建模中的创新实践
java·金融
举一个梨子zz2 小时前
Java—— IO流 第一期
java·开发语言