更换 Kingbase V9 License 踩坑记

更换 Kingbase V9 License 踩坑记

本地测试环境使用KDTS迁移数据时候遇到连接用户过多错误,原因是初始化Kingbase实例时候指定的开发版license限制最大连接数10

我用官网的更换 license 文件 - License管理 | KingbaseES方法更换失败:

bash 复制代码
[kingbase@localhost V9]$ ./Server/bin/sys_ctl -D data reload_license -L ./license_4_V009R001C-pro_180days.dat
pgsql 复制代码
SELECT GET_LICENSE_VALIDDAYS();
-- | get_license_validdays |
-- | 364                   |

仍然是原来的 开发版365天 授权。

所以在此记录更换license步骤。

第一步:定位当前的 License 文件并确定操作

  1. 登录数据库,执行以下 SQL 查询数据目录的绝对路径:
pgsql 复制代码
SHOW data_directory;

假设返回结果为:/opt/Kingbase/ES/V9/data

  1. 在该目录的父级查找 license.dat 文件:
bash 复制代码
find /opt/Kingbase/ES/V9/ -name "license.dat"

输出了三个license.dat文件,已知安装时候使用的授权是开发版365天。经过 ls -la,确认了这三个文件:

文件路径 内容 描述 是否更换
/opt/Kingbase/ES/V9/KESRealPro/V009R001C010/Server/bin/license.dat 企业版,90天试用授权 ksql、sys_dump等客户端工具启动时校验自身合法性 猜测KDTS使用ksql/sys_dump/sys_restore等命令时候可能会校验该授权文件。
/opt/Kingbase/ES/V9/KESRealPro/V009R001C010/license.dat 开发版,365天试用授权 数据库实例实际使用的授权 予以替换
/opt/Kingbase/ES/V9/license.dat -> /opt/Kingbase/ES/V9/KESRealPro/V009R001C010/license.dat 软链接 初始化数据库实例时候指定的授权文件,在实例化数据库时被迁移到了KESRealPro/V009R001C010/license.dat 予以替换

因此只需要替换/opt/Kingbase/ES/V9/KESRealPro/V009R001C010/license.dat即可。

第二步:替换真正的授权文件

  1. 准备授权文件

新的授权文件上传到了/opt/Kingbase/ES/V9/license_4_V009R001C-pro_180days.dat。先以root用户修改新授权文件权限:

bash 复制代码
sudo -i 
# [sudo] kingbase 的密码:
cd /opt/Kingbase/ES/V9/
chown kingbase:kingbase license_4_V009R001C-pro_180days.dat
chmod 77 license_4_V009R001C-pro_180days.dat
  1. 备份并替换授权文件

切换到kingbase用户,备份并替换授权文件:

bash 复制代码
su kingbase
# 确认当前目录
cd /opt/Kingbase/ES/V9/
mv ./KESRealPro/V009R001C010/license.dat ./KESRealPro/V009R001C010/license.dat.260617.bak
ls -la ./KESRealPro/V009R001C010/ | grep license
# -rw-rw-r--  1 kingbase kingbase 5036  6月 17 09:58 license.dat
# -rw-rw-r--  1 kingbase kingbase 4998  6月 16 15:02 license.dat.260617.bak

第三步:重载license

  1. 重载license再次失败

按照官方文档,sys_ctl ... reload_license ...

bash 复制代码
cd /opt/Kingbase/ES/V9/Server/bin
./sys_ctl -D /opt/Kingbase/ES/V9/data reload -L /opt/Kingbase/ES/V9/KESRealPro/V009R001C010
/license.dat
# Checking license file...
# Check successfully. license file will expire in 2026-12-14.
# Reload successfully.

在数据库查询中验证:

pgsql 复制代码
SELECT GET_LICENSE_VALIDDAYS();
-- | get_license_validdays |
-- | 364                   |

仍然是原来的 开发版365天 授权。

  1. 重启数据库实例
bash 复制代码
./sys_ctl restart -D /opt/Kingbase/ES/V9/data
# 等待服务器进程关闭 .... 完成
# 服务器进程已经关闭
# 等待服务器进程启动 ....2026-06-17 10:24:48.035 CST [46474] LOG:  请尽快配置有效的归档命令做WAL日志文件的归档
# ...
#  完成
# 服务器进程已经启动

在数据库查询中验证授权:

pgsql 复制代码
SELECT GET_LICENSE_VALIDDAYS();
-- | get_license_validdays |
-- | 180                   |

至此,已经把旧的 license开发版 365天 替换为专业版 180天

相关推荐
Chengbei113 小时前
AISec真正拟人化全自动渗透工具!支持浏览器交互全自动化挖掘,SQL注入、XSS、越权等。
sql·安全·web安全·网络安全·自动化·系统安全·xss
审判长烧鸡4 小时前
数据库字段命名规范速查表
数据库·sql
吴声子夜歌21 小时前
SQL经典实例——元数据查询
数据库·sql
吴声子夜歌1 天前
SQL经典实例——处理字符串
数据库·sql
罗政1 天前
AI工作流实现Excel自动化+SQL,零 VBA ,零公式,电商订单分析案例 | DTBot
sql·自动化·excel
吴声子夜歌1 天前
SQL经典实例——处理数字
java·数据库·sql
NineData1 天前
日常巡检 Oracle 时,ChatDBA 怎么把会话、SQL 和等待事件一起看
数据库·sql·oracle·ninedata·故障排查·chatdba·实例巡检
吴声子夜歌2 天前
SQL经典实例——使用多张表
数据库·sql
摇滚侠2 天前
MyBatis 入门到项目实战 特殊 SQL 的执行 34-37
java·sql·mybatis