原文链接:【KWDB 创作者计划】使用Docker实现KWDB数据库的快速部署与配置-CSDN博客
作者:
KWDB是一款高性能、强一致的分布式数据库,具备高可用、易扩展、安全可靠等特性,适用于金融、物联网、实时大数据分析等多种场景。本文档旨在指导用户在Docker单机环境下快速搭建KWDB集群,体验其核心功能与部署流程。通过本指南,用户将掌握安全部署模式下的集群搭建、数据访问与同步测试等关键操作,为后续深入使用打下坚实基础。本实践面向技术爱好者和开发者,帮助其快速上手国产自研数据库的前沿代表——KWDB。
KWDB 是一款面向 AIoT 场景的分布式、多模融合数据库产品。 支持在同一个实例中建立时序库和关系库,并统一处理多种类型的数据,具备对海量时序数据的高效读写与分析能力。 产品具备高可用、安全稳定、易运维等特性,广泛应用于工业物联网、数字能源、车联网、智慧矿山等多个行业领域,为用户提供一站式数据存储、管理与分析的基础平台。
高性能处理能力:支持海量时序数据高速读写,提供插值查询、数学函数等丰富的时序特色功能,提升应用效率。
低运管成本:统一存储与管理多模数据,一套系统满足跨业务、跨部门数据融合需求,降低企业IT与运维投入。
低存储成本:支持 5-30 倍数据压缩比,结合数据生命周期管理策略,灵活控制数据保留时间,显著节省存储资源。
高安全性:提供数据库审计与加密机制,保障数据在复杂业务场景下的安全稳定运行。
易用性强:提供标准 SQL 接口、高速写入、极速查询、集群部署等能力,与第三方工具无缝集成,开发运维更便捷。
KWDB数据库的硬件规格要求
KWDB 支持在以下已安装 Docker的操作系统中进行容器部署
本次实践为个人测试环境,操作系统版本为Ubuntu 22.04.1。
使用容器镜像部署KaiwuDB的部署模式说明:
安装docker之前,我们先安装 HTTPS传输工具及必要组件。
apt install -y apt-transport-https ca-certificates curl gnupg lsb-release software-properties-common
添加阿里云 GPG 密钥
mkdir -p /etc/apt/keyrings curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker-archive-keyring.gpg
执行以下命令,开始配置阿里云 Docker 软件源。
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker-archive-keyring.gpg] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
使用apt-get update命令,更新软件源。
root@jeven01:~# apt update Hit:1 https://mirrors.aliyun.com/ubuntu jammy InRelease Hit:2 https://mirrors.aliyun.com/ubuntu jammy-security InRelease Hit:3 https://mirrors.aliyun.com/ubuntu jammy-updates InRelease Hit:4 https://mirrors.aliyun.com/ubuntu jammy-backports InRelease Hit:5 https://mirrors.aliyun.com/docker-ce/linux/ubuntu jammy InRelease Reading package lists... Done Building dependency tree... Done Reading state information... Done 194 packages can be upgraded. Run 'apt list --upgradable' to see them.
执行以下命令,安装Docker核心组件。
apt install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
执行以下命令,快速配置Docker镜像加速。可以自行添加多个Docker镜像加速源,确保后续可以成功拉取Docker镜像。
mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json > /dev/null <<EOF { "registry-mirrors": ["https://80c84f5330e14908928ca78944e61dc4.mirror.swr.myhuaweicloud.com"] } EOF
执行以下命令,配置Docker开机自启。
systemctl daemon-reload systemctl restart docker
检查Docker版本,可以看到当前安装的版本为28.1.1。
root@jeven01:~# docker -v Docker version 28.1.1, build 4eba377
检查Docker compose版本,当前安装版本为2.35.1。
root@jeven01:~# docker compose version Docker Compose version v2.35.1
执行以下命令,拉取KWDB容器镜像。本次实践所使用的KWDB镜像为kwdb/kwdb:2.2.0。
root@jeven01:/data/kwdb# docker pull kwdb/kwdb:2.2.0 2.2.0: Pulling from kwdb/kwdb Digest: sha256:9dda946922a69557e20be9f1d99c504c467fba6351bb8af0a34fe42711cde73f Status: Image is up to date for kwdb/kwdb:2.2.0 docker.io/kwdb/kwdb:2.2.0
在我们需要先提前创建好部署目录,这里直接创建/data/kwdb目录
mkdir -p /data/kwdb && cd /data/kwdb/
如需以安全模式部署KWDB集群,需使用命令创建CA证书、root用户客户端证书及节点服务器证书。若为跨节点部署,还需为每个节点生成并分发证书和密钥,并将root用户证书复制到需要访问集群的其他节点。
docker run --rm --privileged \ -v /data/kwdb/certs:/kaiwudb/certs \ -w /kaiwudb/bin \ kwdb/kwdb:2.2.0 \ bash -c './kwbase cert create-ca --certs-dir=/kaiwudb/certs --ca-key=/kaiwudb/certs/ca.key && \ ./kwbase cert create-client root --certs-dir=/kaiwudb/certs --ca-key=/kaiwudb/certs/ca.key && \ ./kwbase cert create-node 127.0.0.1 localhost 0.0.0.0 192.168.3.88 --certs-dir=/kaiwudb/certs --ca-key=/kaiwudb/certs/ca.key'
查看证书目录/data/kwdb/certs,可以看到已经生成相关证书文件,包括CA证书、root用户客户端证书及节点服务器证书等。
root@jeven01:/data/kwdb# ll certs/ total 32 drwxr-xr-x 2 root root 4096 May 3 13:35 ./ drwxr-xr-x 3 root root 4096 May 3 13:28 ../ -rw-r--r-- 1 root root 1123 May 3 13:35 ca.crt -rw------- 1 root root 1679 May 3 13:35 ca.key -rw-r--r-- 1 root root 1127 May 3 13:35 client.root.crt -rw------- 1 root root 1679 May 3 13:35 client.root.key -rw-r--r-- 1 root root 1192 May 3 13:35 node.crt -rw------- 1 root root 1679 May 3 13:35 node.key 1
我们以安全模式部署KWDB集群,创建KWDB数据库实例1,注意将本机的192.168.3.88替换为自己服务器的本地IP地址。
docker run -d --name kwdb1 --privileged \ --ulimit memlock=-1 --ulimit nofile=1048576 \ -p 26257:26257 -p 8080:8080 \ -v /data/kwdb/certs:/kaiwudb/certs \ -v /data/kwdb/kaiwudb1:/kaiwudb/deploy/kaiwudb-container \ --ipc shareable -w /kaiwudb/bin \ kwdb/kwdb:2.2.0 \ ./kwbase start --certs-dir=/kaiwudb/certs --listen-addr=0.0.0.0:26257 \ --advertise-addr=192.168.3.88:26257 --http-addr=0.0.0.0:8080 \ --store=/kaiwudb/deploy/kaiwudb-container --join 192.168.3.88:26257
主要参数解释:
我们以安全模式部署KWDB集群,创建KWDB数据库实例2,注意将本机的192.168.3.88替换为自己服务器的本地IP地址。
docker run -d --name kwdb2 --privileged \ --ulimit memlock=-1 --ulimit nofile=1048576 \ -p 26258:26257 -p 8081:8080 \ -v /data/kwdb/certs:/kaiwudb/certs \ -v /data/kwdb/kaiwudb2:/kaiwudb/deploy/kaiwudb-container \ --ipc shareable -w /kaiwudb/bin \ kwdb/kwdb:2.2.0 \ ./kwbase start --certs-dir=/kaiwudb/certs --listen-addr=0.0.0.0:26257 \ --advertise-addr=192.168.3.88:26258 --http-addr=0.0.0.0:8080 \ --store=/kaiwudb/deploy/kaiwudb-container --join 192.168.3.88:26257
我们以安全模式部署KWDB集群,创建KWDB数据库实例3,注意将本机的192.168.3.88替换为自己服务器的本地IP地址。
docker run -d --name kwdb3 --privileged \ --ulimit memlock=-1 --ulimit nofile=1048576 \ -p 26259:26257 -p 8082:8080 \ -v /data/kwdb/certs:/kaiwudb/certs \ -v /data/kwdb/kaiwudb3:/kaiwudb/deploy/kaiwudb-container \ --ipc shareable -w /kaiwudb/bin \ kwdb/kwdb:2.2.0 \ ./kwbase start --certs-dir=/kaiwudb/certs --listen-addr=0.0.0.0:26257 \ --advertise-addr=192.168.3.88:26259 --http-addr=0.0.0.0:8080 \ --store=/kaiwudb/deploy/kaiwudb-container --join 192.168.3.88:26257
检查各KWDB容器状态,确保容器正常运行。
root@jeven01:/data/kwdb# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 01f1dc5471bc kwdb/kwdb:2.2.0 "./kwbase start --ce…" 56 seconds ago Up 55 seconds 0.0.0.0:8082->8080/tcp, :::8082->8080/tcp, 0.0.0.0:26259->26257/tcp, :::26259->26257/tcp kwdb3 2581b7166274 kwdb/kwdb:2.2.0 "./kwbase start --ce…" About a minute ago Up About a minute 0.0.0.0:8081->8080/tcp, :::8081->8080/tcp, 0.0.0.0:26258->26257/tcp, :::26258->26257/tcp kwdb2 e9b13a92fd0b kwdb/kwdb:2.2.0 "./kwbase start --ce…" 2 minutes ago Up 2 minutes 0.0.0.0:8080->8080/tcp, :::8080->8080/tcp, 0.0.0.0:26257->26257/tcp, :::26257->26257/tcp kwdb1
执行以下命令,初始化KWDB集群。
docker exec kwdb1 ./kwbase init --certs-dir=/kaiwudb/certs --host=192.168.3.88:26257
使用 kwbase CLI 工具连接 KaiwuDB,如下所示:
docker exec -it kwdb1 ./kwbase sql --certs-dir=/kaiwudb/certs --host=192.168.3.88:26257
我们查询当前安装的KWDB数据库版本,可以看到当前安装的版本为2.2.0版本。
select version();
退出KWDB集群,执行以下命令,查询当前KWDB集群状态。
root@jeven01:/data/kwdb# docker exec -it kwdb1 ./kwbase node status --certs-dir=/kaiwudb/certs id | address | sql_address | build | started_at | updated_at | locality | start_mode | is_available | is_live -----+--------------------+--------------------+-------+----------------------------------+----------------------------------+--------------+------------+--------------+---------- 1 | 192.168.3.88:26257 | 192.168.3.88:26257 | 2.2.0 | 2025-05-03 13:50:13.477659+00:00 | 2025-05-03 13:59:49.518005+00:00 | region=NODE1 | start | true | true 2 | 192.168.3.88:26258 | 192.168.3.88:26258 | 2.2.0 | 2025-05-03 13:50:13.742053+00:00 | 2025-05-03 13:59:49.767398+00:00 | region=NODE2 | start | true | true 3 | 192.168.3.88:26259 | 192.168.3.88:26259 | 2.2.0 | 2025-05-03 13:50:14.102759+00:00 | 2025-05-03 13:59:50.12104+00:00 | region=NODE3 | start | true | true (3 rows)
我们再次进入KWDB集群内,执行以下命令:
docker exec -it kwdb1 ./kwbase sql --certs-dir=/kaiwudb/certs --host=192.168.3.88:26257
创建用户 jeven,设置密码为 jeven1234,并赋予管理员权限(角色为 admin)。
CREATE USER jeven WITH PASSWORD 'jeven1234'; grant admin TO jeven;
在KWDB实例1中,我们查询新建jeven用户。
root@192.168.3.88:26257/defaultdb> SHOW USERS; username | options | member_of -----------+------------+------------ admin | CREATEROLE | {} jeven | | {admin} root | CREATEROLE | {admin} (3 rows) Time: 10.348748ms
退出当前的 KWDB 数据库会话,连接到KWDB实例2中,可以看到用户jeven已经成功同步创建。
root@jeven01:/data/kwdb# docker exec -it kwdb2 ./kwbase sql --certs-dir=/kaiwudb/certs --host=192.168.3.88:26257 # # Welcome to the KWDB SQL shell. # All statements must be terminated by a semicolon. # To exit, type: \q. # # Server version: KaiwuDB 2.2.0 (x86_64-linux-gnu, built 2025/03/31 07:20:02, go1.16.15, gcc 11.4.0) (same version as client) # Cluster ID: f8c4840f-e0b9-44bc-a16e-fab1877b1daa # # Enter \? for a brief introduction. # root@192.168.3.88:26257/defaultdb> show users; username | options | member_of -----------+------------+------------ admin | CREATEROLE | {} jeven | | {admin} root | CREATEROLE | {admin} (3 rows) Time: 5.067895ms
退出当前的 KWDB数据库会话,连接到KWDB实例3中,可以看到用户jeven已经成功同步创建。
docker exec -it kwdb3 ./kwbase sql --certs-dir=/kaiwudb/certs --host=192.168.3.88:26257
show users;
本次基于Docker的KWDB安全部署实践顺利完成,成功搭建了多节点集群并完成了数据访问与同步测试,验证了KWDB强大的分布式能力与稳定性。整个部署过程逻辑清晰、操作高效,体现出KWDB良好的文档支持和易用性。通过直观的命令行工具和可视化监控界面,进一步展示了其在集群管理与运维方面的优势。作为一款优秀的国产自研数据库,KWDB在性能、功能与安全性方面表现突出,具备广阔的应用前景,值得深入研究与推广使用。