KingbaseV8R6配置SSL

一、准备工作

a.获取镜像并加载
官方下载地址
kingbase_v8r6.tar

bash 复制代码
docker load -i kingbase_v8r6.tar

b.创建数据目录

bash 复制代码
# 创建数据持久化目录和 SSL 证书目录
mkdir -p /opt/docker/kingbaseV8R6_ssl/data /opt/docker/kingbaseV8R6_ssl/ssl
chmod -R 777 /opt/docker/kingbaseV8R6_ssl

二、生成SSL证书

使用 OpenSSL 生成自签名证书(在宿主机执行):

a.进入ssl目录

bash 复制代码
cd /opt/docker/kingbaseV8R6_ssl/ssl/

b.生成服务端证书

bash 复制代码
# 1. 生成 CA 根证书和私钥
openssl genrsa -out root.key 2048
openssl req -new -x509 -days 3650 -key root.key -out root.crt \
  -subj "/C=CN/ST=Beijing/L=Beijing/O=Kingbase/CN=CA"

# 2. 生成服务器私钥和证书请求(CSR)
openssl genrsa -out server.key 2048
openssl req -new -key server.key -out server.csr \
  -subj "/C=CN/ST=Beijing/L=Beijing/O=Kingbase/CN=localhost"
# 如果 openssl req报错:Can't open /usr/local/openssl/openssl.cnf for reading, No such file or directory
# 是因为找不到openssl.cnf配置文件,可以使用find命令查找:
# find / -name "openssl.cnf" 2>/dev/null
# 例如找到的路径为 /etc/pki/tls/openssl.cnf ,则添加 -config 指定配置文件
# openssl req -new -key server.key -out server.csr -config /etc/pki/tls/openssl.cnf \
#   -subj "/C=CN/ST=Beijing/L=Beijing/O=Kingbase/CN=localhost"

# 3. 使用 CA 签署服务器证书
openssl x509 -req -days 3650 -in server.csr \
  -CA root.crt -CAkey root.key -set_serial 01 -out server.crt

# 4. 设置私钥权限(数据库要求严格权限)
chmod 600 server.key
chmod 600 root.key

# 5. 验证证书
openssl verify -CAfile root.crt server.crt

c.生成客户端证书

bash 复制代码
# 生成客户端私钥
openssl genrsa -out client.key 2048

# 生成客户端证书请求(CSR)
openssl req -new -key client.key -out client.csr \
  -subj "/C=CN/ST=Beijing/L=Beijing/O=Kingbase/CN=system"  # CN 使用数据库用户名

# 使用 CA 签署客户端证书
openssl x509 -req -days 3650 -in client.csr \
  -CA root.crt -CAkey root.key -set_serial 02 -out client.crt

# 设置权限
chmod 600 client.key

d.转换客户端私钥格式
JDBC 驱动不支持 PEM 格式的 RSA 私钥,需要转换为 PKCS#8 格式。

bash 复制代码
openssl pkcs8 -topk8 -inform PEM -outform DER -in client.key -out client.pk8 -nocrypt

三、运行容器

a.运行(数据库密码根据实际情况修改)

bash 复制代码
docker run -d \
  --name kingbase_ssl \
  --privileged=true \
  --restart=always \
  -p 44321:54321 \
  -v /opt/docker/kingbaseV8R6_ssl/data:/home/kingbase/userdata \
  -v /opt/docker/kingbaseV8R6_ssl/ssl:/home/kingbase/ssl \
  -e DB_USER=system \
  -e DB_PASSWORD={{自定义密码}} \
  -e DB_MODE=oracle \
  -e NEED_START=yes \
  kingbase_v008r006c008b0020_single_x86:v1 \
  /usr/sbin/init

b.查看日志

bash 复制代码
docker logs -f kingbase_ssl

c.客户端连接测试

连接信息如下:

hostname: localhost

port: 44321

username1: system

password1: {{自定义密码}}

四、配置SSL

a.进入容器

bash 复制代码
docker exec -it kingbase_ssl bash

b.将证书复制到数据目录

bash 复制代码
cp /home/kingbase/ssl/server.crt /home/kingbase/userdata/data
cp /home/kingbase/ssl/server.key /home/kingbase/userdata/data
cp /home/kingbase/ssl/root.crt /home/kingbase/userdata/data
cp /home/kingbase/ssl/client.crt /home/kingbase/userdata/data
cp /home/kingbase/ssl/client.key /home/kingbase/userdata/data

c.修改 kingbase.conf 配置文件

bash 复制代码
vi /home/kingbase/userdata/data/kingbase.conf

# 修改或添加如下内容:
ssl = on                                    # 开启 SSL
ssl_cert_file = 'server.crt'                # 服务器证书
ssl_key_file = 'server.key'                 # 服务器私钥
ssl_ca_file = 'root.crt'                    # CA 根证书(用于客户端认证)

d.修改 sys_hba.conf 配置文件

bash 复制代码
vi /home/kingbase/userdata/data/sys_hba.conf

# 修改或添加如下内容:
hostssl    all    all    0.0.0.0/0    md5        clientcert=verify-ca

只保留 local 和 hostssl ,注释host,则只允许SSL连接

五、重启数据库

bash 复制代码
# 退出容器
exit

# 重启
docker restart kingbase_ssl

六、验证SSL连接

a.ksql验证

需要用到证书文件:client.crt、client.key、root.crt

bash 复制代码
# 执行如下命令并输入密码后登录成功
ksql "host=localhost port=54321 user=system dbname=test sslmode=verify-ca sslcert=client.crt sslkey=client.key sslrootcert=root.crt"
# 执行如下SQL语句
SELECT ssl, version, cipher FROM sys_stat_ssl WHERE pid = pg_backend_pid();
# 出现如下内容,则是SSL连接
 ssl | version |         cipher         
-----+---------+------------------------
 t   | TLSv1.3 | TLS_AES_256_GCM_SHA384

b.dbeaver验证

需要用到证书文件:client.crt、client.pk8 、root.crt

设置如下四个驱动属性:


相关推荐
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据4 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡4 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
程序员mine4 天前
HTTPS-TLS加密与证书完全指南(中)
网络协议·https·ssl
曹牧4 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon4 天前
SQL学习指南——视图
数据库·sql