KingbaseES Docker速查表

在 KingbaseES(人大金仓)的 Docker 容器内,管理和操作数据库主要通过 ksql 命令行客户端和 sys_ctl 控制工具来完成。

下面是核心操作的快速参考:

操作 命令 说明
进入容器 docker exec -it <容器名或ID> /bin/bash 进入容器内部。
连接数据库 ksql -U <用户名> -d <数据库名> -p 54321 -U指定用户,-d指定数据库。默认用户是system,默认数据库是test
免密连接 ksql 仅输入命令,然后按提示输入密码即可。
执行SQL文件 \i /path/to/your/file.sql ksql交互界面中,执行指定路径的SQL文件。
查看数据库状态 sys_ctl -D /home/kingbase/userdata/data/ status 检查Kingbase数据库进程是否正常运行。
重新加载配置 sys_ctl reload -D /home/kingbase/userdata/data/ 修改kingbase.conf等配置文件后,使其生效。
退出ksql \q 退出ksql命令行界面,返回容器的shell。

📌 核心命令详解

1. 进入容器

首先,你需要进入Kingbase容器的bash环境,才能执行后续的所有命令。

复制代码
# 请将 <容器名或ID> 替换为你实际的容器名(如 kingbase)或容器ID(如 bb0a406b3e7a)
docker exec -it <容器名或ID> /bin/bash

# 成功进入后,命令行提示符通常会变成类似 [root@xxx /]# 的形式
2. 连接数据库:ksql

ksql 是KingbaseES自带的命令行客户端,功能类似PostgreSQL的psql。进入容器后,使用ksql命令连接数据库。

指定参数连接(推荐)

此方式最为明确。连接成功后,提示符会变为 <数据库名>=#

复制代码
# 语法:ksql -U 用户名 -d 数据库名 -p 端口号
ksql -U system -d test -p 54321

免密快速连接

如果你的环境已经配置好(通常是默认的system用户),直接输入ksql命令并回车,它会自动尝试以当前Linux用户(通常是kingbase)免密登录test数据库。

复制代码
ksql
3. 执行SQL文件:\i

当你需要执行一个已写好的.sql脚本文件时,可以先连接数据库,再使用\i命令。

复制代码
-- 1. 先连接到目标数据库
ksql -U system -d test -p 54321

-- 2. 在ksql提示符下,执行脚本文件
\i /home/kingbase/userdata/defence_cloud-kb.sql
4. 查看和管理数据库

在容器内,你可以使用sys_ctl工具来管理数据库进程。

查看数据库状态

复制代码
# 切换到 kingbase 用户(如果需要),然后执行状态查看命令
su - kingbase
sys_ctl -D /home/kingbase/userdata/data/ status

输出示例:

复制代码
sys_ctl: server is running (PID: 76)

这表示数据库正在运行。

重新加载配置

当修改了数据库的配置文件(如 kingbase.conf)后,需要让配置生效,但又不想重启整个服务,可以使用reload命令。

复制代码
# 执行重新加载命令
/home/kingbase/install/kingbase/bin/sys_ctl reload -D /home/kingbase/userdata/data/

💡 常见问题与路径速查

  • 数据库默认目录 : /home/kingbase/userdata/data/
  • 默认账户/密码 : system / 123456 (或 12345678ab
  • ksql连接不上 : 确认容器已用-p 54321:54321映射端口,并且数据库服务已启动
  • 提示权限不足 : 如果遇到权限错误,可以尝试切换到kingbase用户再执行命令:su - kingbase
相关推荐
阳光满路1 小时前
三步搞定:Linux 安装配置 Telnet 服务
linux·运维·centos
Sunny_20228371 小时前
有些CAD图形能显示却打印不出来
运维·pccad插件、cad·pccad个人免费版·免费cad插件
原来是猿2 小时前
Docker 【 技术架构(2)】
docker·架构
梦想的颜色2 小时前
MySQL 数据存储结构与查询执行生命周期深度解析
运维·数据结构·数据库·mysql·线程·优化
RisunJan2 小时前
Linux命令-objdump(显示二进制文件信息)
linux·运维
小肥君2 小时前
docker镜像配置
运维·docker·容器
左心房的默白,,,3 小时前
33:HSMS over TCP/IP 通信原理与配置
运维·自动化