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;
相关推荐
DeeplyMind44 分钟前
第12章 Docker存储机制(重要)
运维·docker·容器
欧恩意1 小时前
【Tools】Java反汇编工具推荐
java·汇编
寻星探路1 小时前
【JVM 终极通关指南】万字长文从底层到实战全维度深度拆解 Java 虚拟机
java·开发语言·jvm·人工智能·python·算法·ai
lbb 小魔仙1 小时前
【Java】Java 实战项目:手把手教你写一个电商订单系统
android·java·python
星河耀银海1 小时前
Java安全开发实战:从代码防护到架构安全
java·安全·架构
青云交1 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市水资源管理与节水策略制定中的应用
java·java 大数据·java 大数据可视化·城市水资源管理·spark 数据清洗·echarts 热力图·管网漏损控制
紫陌涵光2 小时前
112. 路径总和
java·前端·算法
workflower2 小时前
多变量时间序列预测
java·hadoop·nosql·需求分析·big data·结对编程
xuhe23 小时前
Claude Code配合Astro + GitHub Pages:为 sharelatex-ce 打造现代化的开源项目宣传页
linux·git·docker·github·浏览器·overleaf
Volunteer Technology3 小时前
DynamicTP动态线程池(四)
java·spring boot·后端·spring