【KWDB创作者计划】_KaiwuDB 2.1.0 单节点裸机部署
大家好,这里是 DBA学习之路,专注于提升数据库运维效率。
@TOC
前言
今天无意间在墨天轮看到一个征文活动 征文大赛 |「码」上数据库—— KWDB 2025 创作者计划启动,想着参与一下支持开源,顺便了解一下新的开源时序数据库 KWDB。
写了一篇时序数据库 KWDB 的简单安装和使用,分享给大家一起看看~
KWDB 介绍
KWDB(KaiwuDB)是一款开源的时序数据库,是浪潮集团控股的数据库企业,以多模数据库为核心,主要面向工业物联网、数字能源、交通车联网、智慧城市、数字政务等多种场景。
早在 2023.01.10 KWDB 1.0 就已经正式发布,经过一年多的孵化,目前最新版已经来到 2.1.0,可以说已经是一款比较成熟的数据库了。

KWDB 为不同角色开发者提供以下支持(包括但不限于):
- 为开发者提供通用连接接口,具备高速写入、极速查询、SQL 支持、随需压缩、数据生命周期管理、集群部署等特性,与第三方工具无缝集成,降低开发及学习难度,提升开发使用效率。
- 为运维管理人员提供快速安装部署、升级、迁移、监控等能力,降低数据库运维管理成本。
KWDB 官方资源参考:
- KWDB 开源地址:https://gitee.com/kwdb/kwdb
- 部署操作文档:https://www.kaiwudb.com/kaiwudb_docs/#/oss_v2.1.0/quickstart/overview.html
- KWDB 最新发行版 2.1.0 下载地址:https://gitee.com/kwdb/kwdb/releases/tag/V2.1.0
KWDB 支持用户根据需求选择二进制安装包、容器和源码安装与试用 KWDB 数据库:
- 二进制安装包:支持单机和集群以及安全和非安全部署模式。
- 源码安装:源码编译目前支持单节点非安全模式部署。
- 容器镜像:KWDB 暂未提供可供下载的容器镜像,如需以容器方式部署 KWDB,需要联系 KWDB 技术支持人员。
可以看到二进制安装包的方式支持的架构比较多,所以本文选择用二进制安装的方式进行部署。
安装准备
本文介绍如何使用 KWDB 二进制安装包在单个节点上安装部署 KWDB。
环境信息
这里本着国产数据库用国产系统,所以选择麒麟 V10 系统进行测试:
| 主机名 | 版本 | CPU | 内存 | 硬盘 |
|---|---|---|---|---|
| kwdb | 银河麒麟V10 | x86 | 8G | 100G |
配置要求
参考官方手册给出的部署 KWDB 所需的硬件规格:
| 项目 | 要求 |
|---|---|
| CPU 和内存 | 单节点配置建议不低于 4 核 8G。对于数据量大、复杂的工作负载、高并发和高性能场景,建议配置更高的 CPU 和内存资源以确保系统的高效运行。 |
| 磁盘 | 1、推荐使用 SSD 或者 NVMe 设备,尽量避免使用 NFS、CIFS、CEPH 等共享存储。 2、磁盘必须能够实现 500 IOPS 和 30 MB/s 处理效率。 |
| 文件系统 | 建议使用 ext4 文件系统。 |
实际部署时,用户可以根据实际的业务规模和性能要求规划硬件资源。
操作系统
KWDB 官方已经认证的服务器操作系统:
| 操作系统 | 版本 | 架构 |
|---|---|---|
| Anolis | 8.6 | ARM_64 |
| Anolis | 8.6 | x86_64 |
| KylinOS | V10 SP3 2403 V10 SP3 2303 |
ARM_64 |
| KylinOS | V10 SP3 2403 V10 SP3 2303 |
x86_64 |
| Ubuntu | V20.04 | ARM_64 |
| Ubuntu | V20.04 | x86_64 |
| Ubuntu | V22.04 | ARM_64 |
| Ubuntu | V22.04 | x86_64 |
| Ubuntu | V24.04 | ARM_64 |
| Ubuntu | V24.04 | x86_64 |
| UOS | 1060e | x86_64 |
| UOS | 1060e | ARM_64 |
软件依赖
KWDB 在安装时会对依赖进行检查,如果缺少依赖会退出安装并提示依赖缺失。不同操作系统及安装包的依赖略有不同,需要根据实际安装包类型及操作系统,在部署前安装好相应的依赖。
下表列出需要在目标机器安装的依赖:
| 依赖 | 版本 | 说明 |
|---|---|---|
| OpenSSL | v1.1.1+ | N/A |
| Protobuf | v3.5.0+ | N/A |
| GEOS | v3.3.8+ | 可选依赖 |
| xz-libs | v5.2.0+ | N/A |
| squashfs-tools | any | N/A |
| libgcc | v7.3.0+ | N/A |
| mount | any | N/A |
| squashfuse | any | 可选依赖 |
配置本地软件源:
1 | ## 挂载本地镜像源 |
手动安装依赖:
1 | yum install -y protobuf |
检查操作系统是否已安装对应依赖:
1 | [root@kwdb soft]# rpm -q openssl protobuf geos xz-libs squashfs-tools libgcc util-linux |
确保所有的依赖都已成功安装。
端口要求
在安装部署前,确保目标机器的以下端口没有被占用且没有被防火墙拦截。在安装部署时,用户可以修改 deploy.cfg 文件中的端口配置参数。
下表列出 KWDB 服务需要映射的端口:
| 端口号 | 说明 |
|---|---|
| 8080 | 数据库 Web 服务端口 |
| 26257 | 数据库服务端口、节点监听端口和对外连接端口 |
建议关闭防火墙:
1 | [root@kwdb ~]# systemctl stop firewalld.service |
安装包下载
在 gitee 上下载对应的二进制安装包:

将安装包复制到待安装 KWDB 的目标机器上,然后解压缩安装包:
1 | [root@kwdb soft]# ll |
解压后生成的目录包含以下文件:
1 | [root@kwdb kwdb_install]# tree -N |
至此,环境准备完成,接下来可以开始部署 KWDB。
部署 KWDB
部署 KWDB 时,系统将对配置文件、运行环境、硬件配置和软件依赖进行检查。
- 如果相应硬件未能满足要求,系统将继续安装,并提示硬件规格不满足要求。
- 如果软件依赖未能满足要求,系统将中止安装,并提供相应的提示信息。
在部署过程中,系统会自动生成相关日志。如果部署时出现错误,用户可以通过查看终端输出或 KWDB 安装目录中 log 目录里的日志文件,获取详细的错误信息。
部署完成后,系统会将 KWDB 封装成系统服务(名称为 kaiwudb),并生成以下文件:
kaiwudb.service:配置 KWDB 的 CPU 资源占用率。kaiwudb_env:配置 KWDB 启动参数。
安装用户为 root 用户或者拥有 sudo 权限的普通用户。
登录待部署节点,编辑安装包目录下的 deploy.cfg 配置文件,设置安全模式、管理用户、服务端口等信息:
1 | ## 默认情况下,deploy.cfg 配置文件中包含集群配置参数,需要删除或注释 [cluster] 集群配置项。 |
参数说明:
global:全局配置secure_mode:是否开启安全模式,支持以下两种取值:insecure:使用非安全模式。tls:(默认选项)开启 TLS 安全模式。开启安全模式后,KaiwuDB 生成 TLS 证书,作为客户端或应用程序连接数据库的凭证,生成的客户端相关证书存放在/etc/kaiwudb/certs目录。
management_user:KaiwuDB 的管理用户,默认为 kaiwudb。安装部署后,KaiwuDB 创建相应的管理用户以及和管理用户同名的用户组。rest_port:KaiwuDB Web 服务端口,默认为8080。kaiwudb_port:KaiwuDB 服务端口,默认为26257。data_root:数据目录,默认为/var/lib/kaiwudb。cpu: 可选参数,用于指定 KaiwuDB 服务占用当前节点服务器 CPU 资源的比例,默认无限制。取值范围为 [0,1],最大精度为小数点后两位。
local:本地节点配置node_addr:本地节点对外提供服务的 IP 地址,监听地址为 0.0.0.0,端口为 KaiwuDB 服务端口。
为 deploy.sh 脚本添加运行权限:
1 | [root@kwdb kwdb_install]# chmod +x deploy.sh |
安装过程中需要输入 kaiwudb 用户密码,复杂度参考操作系统,不符合复杂度会报错退出安装。如果没有密码复杂性要求,不想设置密码太复杂的话,可以取消密码复杂度:
1 | [root@kwdb kwdb_install]# sed -i 's/^password\+[[:space:]]\+requisite[[:space:]]\+pam_pwquality.so/#&/g' /etc/pam.d/system-auth |
执行单机部署安装命令:
1 | [root@kwdb kwdb_install]# ./deploy.sh install --single |
执行成功后,控制台输出以下信息:
1 | [INSTALL COMPLETED]:KaiwuDB has been installed successfully! To start KaiwuDB, please execute the command 'systemctl daemon-reload'. |
根据系统提示重新加载 systemd 守护进程的配置文件:
1 | [root@kwdb kwdb_install]# systemctl daemon-reload |
启动 KWDB 节点:
1 | [root@kwdb kwdb_install]# ./deploy.sh start |
执行成功后,控制台输出以上信息。
查看 KWDB 节点状态:
1 | [root@kwdb kwdb_install]# ./deploy.sh status |
配置 KWDB 开机自启动:
1 | [root@kwdb kwdb_install]# systemctl enable kaiwudb |
配置 KWDB 开机自启动后,如果系统重启,则自动启动 KWDB。
简单实用
连接数据库
1 | [kaiwudb@kwdb ~]$ kwbase sql --insecure --host=192.168.6.79 |
创建数据库
1 | -- 创建一个名称为 tsdb 的时序库,数据保存周期为 90 天 |
创建用户
1 | -- 创建一个名称为 testu 的用户,授予其 tsdb 数据库的所有权限 |
创建时序表
在 tsdb 数据库中创建名为 readings 的时序表,存储温度和湿度数据,并使用传感器 ID 和位置作为标签:
1 | root@192.168.6.79:26257/defaultdb> use tsdb; |
向 readings 时序表中写入数据:
1 | root@192.168.6.79:26257/tsdb> INSERT INTO tsdb.readings |
查询 readings 时序表中的数据:
1 | root@192.168.6.79:26257/tsdb> SELECT * FROM readings; |
查看已创建的表结构:
1 | root@192.168.6.79:26257/tsdb> SHOW CREATE TABLE readings; |
到这, KaiwuDB 的单机安装就完成了。