Skills 天翼云 DMS 数据管理服务 (客户端)
提供 DMS 客户端数据管理能力,包括实例管理、SQL查询、工单创建、团队管理、用户管理。用于用户请求数据库实例添加、数据查询、提交工单、团队配置等操作时调用。
git clone https://github.com/openclaw/skills
skills/18108851659-yzh/test000-my-skill/Skill.md天翼云 DMS 数据管理服务 (客户端)
本 Skill 提供 DMS(数据管理服务)客户端的自动化操作能力,支持通过 API 调用或 CLI 工具实现实例管理、数据查询、工单创建、团队配置等功能。
功能概述
本 Skill 支持以下 4 个核心功能场景:
- 自动实例管理 - 数据库实例的添加、删除、修改
- 数据查询 - SQL 执行和数据探索分析
- 自然语言提工单 - 工单创建和查询
- 自动团队配置管理 - 团队创建、用户邀请、实例分配
⚠️ 避坑指南(必读)
1. 实例登录方式
实例登录支持两种方式:
方式一:使用 dbAccountId 登录(推荐)
通过
account-list 命令获取数据库账号 ID,然后使用账号 ID 登录,无需密码。
步骤:
# 1. 查询实例账户列表 java -jar dms-cli.jar instance account-list --id <实例ID> --origin <origin值> # 2. 使用 dbAccountId 登录 java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account-id <账号ID> \ --origin <origin值>
方式二:使用账密登录
使用数据库账号和密码登录,需要用户手动提供真实密码,不支持任何默认密码。
命令:
java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account <数据库账号> \ --password <数据库密码> \ --origin <origin值>
⚠️ 注意:
- 参数名是
,不是--password--db-password - 密码会被自动 AES 加密传输
- 禁止提供默认密码或自动尝试密码
2. origin 参数必须显式指定
错误写法(可能失败):
java -jar dms-cli.jar instance login --id 10413 --db-account root --password "密码" # origin 使用默认值 5,但实例实际可能是 2
正确写法:
# 先查询实例详情确认 origin 值 java -jar dms-cli.jar instance detail --id 10413 # 查看返回数据中的 "origin" 字段 # 登录时显式指定正确的 origin java -jar dms-cli.jar instance login --id 10413 --db-account root --password "密码" --origin 2
⚠️ origin 取值:
| origin值 | 来源 | 常见场景 |
|---|---|---|
| 1 | RDS云数据库 | 天翼云RDS |
| 2 | 公网/直连 | 客户端添加的公网实例 |
| 3 | DMS代理 | Agent模式 |
| 4 | AOne环境 | AOne开发环境 |
| 5 | 内网 | 内网数据库(默认) |
3. 弱管控实例也需要 Token
⚠️ 重要:即使 controlType=0(弱管控),执行 SQL 仍需要先登录获取 Token!
错误做法:
# 直接执行 SQL,不登录 java -jar dms-cli.jar sql execute --instance-id 10413 --sql "SHOW DATABASES" # 会报错:"查询弱管控实例Token不能为空"
正确流程:
# 1. 先登录获取 Token java -jar dms-cli.jar instance login --id 10413 --db-account root --password "密码" --origin 2 # 返回: {"code":200,"data":"26d4540fe7e01ff1",...} -- Token 在 data 字段 # 2. 使用 Token 执行 SQL java -jar dms-cli.jar sql execute \ --instance-id 10413 \ --sql "SHOW DATABASES" \ --instance-token "26d4540fe7e01ff1" \ --origin 2
4. database list API 可能返回空
问题:
database list 命令返回空数组,但实例确实有数据库。
原因: 该 API 对某些实例可能不返回数据。
解决方案: 使用 SQL 直接查询
# 先登录获取 Token java -jar dms-cli.jar instance login --id 10413 --db-account root --password "密码" --origin 2 # 用 SQL 查询数据库列表 java -jar dms-cli.jar sql execute \ --instance-id 10413 \ --sql "SHOW DATABASES" \ --instance-token "Token值" \ --origin 2
5. account-list 可能返回空
问题:
account-list 命令返回空数组,但实例详情显示有 dbAccount: "root"。
解决方案: 直接使用实例详情中的
dbAccount 值登录
# 查询实例详情 java -jar dms-cli.jar instance detail --id 10413 # 找到 "dbAccount": "root" # 直接使用该账号登录 java -jar dms-cli.jar instance login --id 10413 --db-account root --password "密码" --origin 2
6. ⚠️⚠️⚠️ PostgreSQL 数据库切换的正确方法(极重要)
问题: 使用
--database 或 --db-id 参数执行 SQL 时,数据可能写入错误的数据库!
根因分析(已验证):
- WebSocket 连接建立时会绑定到登录时的数据库
和--database
参数不会切换数据库连接,只是设置消息体参数--db-id- PostgreSQL 不支持跨数据库操作,必须在连接时就指定正确的数据库
⚠️ 验证结果:
# 测试:创建表并插入数据,检查 db_name 列 CREATE TABLE tpcds_verify (id INT, db_name TEXT DEFAULT current_database()) INSERT INTO tpcds_verify (id) VALUES (1) SELECT * FROM tpcds_verify # 结果:db_name = "autotest_db_3952484"(错误的数据库!) # 即使指定了 --database tpcds 和 --db-id 17575
✅ 正确做法:登录时必须使用 --db-name 参数指定目标数据库!
# ❌ 错误做法:登录时不指定数据库,后续无法切换 java -jar dms-cli.jar instance login \ --id 10292 \ --db-account-id 4587 \ --origin 2 # 登录后连接到默认数据库,无法切换! # ❌ 错误做法:使用 --database 参数尝试切换数据库 java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "CREATE TABLE test (id INT)" \ --database tpcds \ --instance-token "xxx" \ --origin 2 # 表仍然创建在默认数据库中! # ✅ 正确做法:登录时使用 --db-name 参数指定目标数据库(PG需要此参数) java -jar dms-cli.jar instance login \ --id 10292 \ --db-account-id 4587 \ --origin 2 \ --db-name tpcds # 现在连接已经绑定到 tpcs 数据库 # 验证当前数据库 java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT current_database()" \ --instance-token "xxx" \ --origin 2 # 应该返回 "tpcds"
完整安全流程(PostgreSQL 专用):
# 步骤1:查询目标数据库的 dbId(可选,用于某些需要 dbId 的操作) java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT datname, oid FROM pg_database WHERE datistemplate = false" \ --instance-token "xxx" \ --origin 2 # 步骤2:登出当前连接(如果有) java -jar dms-cli.jar instance logout --token "旧Token" # 步骤3:重新登录并指定目标数据库 java -jar dms-cli.jar instance login \ --id 10292 \ --db-account-id 4587 \ --origin 2 \ --db-name tpcds # 返回新的 Token # 步骤4:验证当前数据库 java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT current_database()" \ --instance-token "新Token" \ --origin 2 # 确认返回 "tpcds" # 步骤5:执行 SQL(现在可以安全地操作 tpcs 数据库) java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "CREATE TABLE test (id INT PRIMARY KEY)" \ --instance-token "新Token" \ --origin 2 \ --db-type 2 # 步骤6:验证表是否在正确的数据库中 java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT tablename FROM pg_tables WHERE schemaname = 'public'" \ --instance-token "新Token" \ --origin 2
⚠️ 不同数据库类型的处理方式:
| 数据库类型 | dbType | 切换数据库方式 | 关键参数 |
|---|---|---|---|
| MySQL | 1 | 参数有效 | 登录后可用 |
| PostgreSQL | 2 | 必须登录时指定 | 在登录时 |
| SQL Server | 6 | 参数有效 | 登录后可用 |
| MongoDB/DDS | 9 | 参数有效 | 连接字符串指定 |
⚠️ PostgreSQL 特殊说明:
参数只在--db-name
命令中有效instance login- 登录后无法通过任何参数切换数据库
- 每次需要操作不同数据库时,必须先登出再重新登录
和--db-id
参数用于 schema 级别操作,不切换数据库--schema-id
枚举参数说明
一、实例来源 (origin)
| 值 | 枚举名 | 中文说明 | 英文说明 |
|---|---|---|---|
| 1 | RDS | 云数据库/天翼云数据库 | Cloud Database |
| 2 | PUBLIC | 公网/直连数据库 | Public Network/Direct Connection Database |
| 3 | AGENT | DMS代理数据库 | DMS Proxy Database |
| 4 | AONE | AOne环境数据库 | AOne Environment Database |
| 5 | INTRANET | 内网数据库 | Intranet Database |
二、数据库类型 (dbType)
| 值 | 枚举名 | 中文说明 |
|---|---|---|
| 1 | MYSQL | MySQL |
| 2 | PGSQL | PostgreSQL |
| 3 | ADB | TeleDB For AnalyticDB |
| 4 | GPSQL | Greenplum |
| 5 | TELEDBX | TeleDB for Xscale |
| 6 | SQLSERVER | SQL Server |
| 7 | DRDS | DRDS |
| 8 | MONGO | MongoDB |
| 9 | DDS | DDS |
| 10 | HIVE | Hive |
| 11 | ORACLE | Oracle |
| 12 | DAMENG | 达梦 |
| 13 | CLICKHOUSE | ClickHouse |
| 14 | TIDB | TiDB |
三、实例环境 (envType / defaultEnvType)
| 值 | 枚举名 | 中文说明 | 英文说明 |
|---|---|---|---|
| 1 | DEV | 开发 | develop |
| 2 | BETA | 测试 | beta |
| 3 | PRE | 预发 | pre-product |
| 4 | PRO | 生产 | product |
四、实例状态 (state)
| 值 | 枚举名 | 中文说明 | 英文说明 |
|---|---|---|---|
| 1 | DEFAULT | 正常 | Normal |
| 2 | ERROR | 异常 | Exception |
| 3 | DISABLE | 禁用 | Disabled |
五、读写类型 (rw / isRw)
| 值 | 枚举名 | 中文说明 |
|---|---|---|
| 0 | READONLY | 只读 |
| 1 | RW | 读写 |
六、实例模式 (mode / instanceMode)
| 值 | 枚举名 | 中文说明 | 英文说明 |
|---|---|---|---|
| 1 | WEB | Web模式 | Web Mode |
| 2 | CLIENT | Client模式 | Client Mode |
七、管控类型 (controlType)
| 值 | 枚举名 | 中文说明 |
|---|---|---|
| 0 | WEAK_CONTROL_TYPE | 弱管控模式 |
| 1 | STRONG_CONTROL_TYPE | 强管控模式 |
⚠️ 说明:
- 弱管控模式:无需数据库账号密码即可登录,但执行 SQL 仍需要 Token
- 强管控模式:需要数据库账号密码授权后才能执行 SQL
八、工单类型 (type)
| 值 | 中文说明 |
|---|---|
| export | 数据导出工单 |
| import | 数据导入工单 |
| sql | SQL变更工单 |
| query | SQL查询工单 |
| sqlreview | SQL评审工单 |
九、工单状态 (status)
| 值 | 中文说明 |
|---|---|
| 0 | 待提交 |
| 1 | 审批中 |
| 2 | 审批通过 |
| 3 | 审批拒绝 |
| 4 | 执行中 |
| 5 | 执行成功 |
| 6 | 执行失败 |
| 7 | 已撤回 |
| 8 | 已关闭 |
十、团队成员角色 (role)
| 值 | 枚举名 | 中文说明 |
|---|---|---|
| 1 | ADMIN | 管理员 |
| 2 | MEMBER | 普通成员 |
| 5 | READONLY | 只读 |
十一、实例登录状态 (loginStatus)
| 值 | 中文说明 |
|---|---|
| 0 | 未登录 |
| 1 | 已登录 |
构建与运行
前提条件
- Java 11 或更高版本
- Maven 3.6+
构建项目
cd dms-data-management-java mvn clean package
运行 CLI
java -jar target/dms-cli-1.0.0.jar <command>
一、实例管理命令
创建实例
java -jar dms-cli.jar instance create \ --alias "测试数据库" \ --host 127.0.0.1 \ --port 3306 \ --user root \ --password "your_password" \ --type mysql
修改实例
# 基本修改 java -jar dms-cli.jar instance modify --id 123 --alias "新名称" java -jar dms-cli.jar instance modify --id 123 --host 192.168.1.1 --port 3307 # 将实例添加到团队(重要:需要先通过 instance detail 获取 origin 值) java -jar dms-cli.jar instance modify --id <实例ID> --team-id <团队ID> --origin <origin值> # origin值说明: # 1 = RDS (云数据库) # 2 = PUBLIC (公网/直连) # 3 = AGENT (DMS代理) # 4 = AONE (AOne环境) # 5 = INTRANET (内网)
删除实例
java -jar dms-cli.jar instance delete --id 123
查看实例详情
java -jar dms-cli.jar instance detail --id 123 # 返回示例: # {"code":200,"data":{..., "id":"10413", "origin":2, "controlType":0, "dbAccount":"root", ...}}
查看实例列表
java -jar dms-cli.jar instance list --page 1 --page-size 10
测试连接
java -jar dms-cli.jar instance test \ --host 127.0.0.1 \ --port 3306 \ --user root \ --password "password" \ --type mysql # type可选值:mysql(1), pgsql(2), sqlserver(6), mongo(8), doris(3), etc.
登录/登出实例 ⚠️
实例登录支持两种方式:
方式一:使用 dbAccountId 登录(推荐)
# 查询账户列表 java -jar dms-cli.jar instance account-list --id <实例ID> --origin <origin值> # 使用 dbAccountId 登录(无需密码) java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account-id <账号ID> \ --origin <origin值>
方式二:使用账密登录
# ⚠️ 必须指定正确的 origin 值(从实例详情获取) # ⚠️ 密码需要用户手动提供,不支持默认密码 java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account <数据库账号> \ --password <数据库密码> \ --origin <origin值>
登出
java -jar dms-cli.jar instance logout --token "instance_token"
添加实例到团队
java -jar dms-cli.jar instance add-to-team --id 123 --team-id 456
二、用户管理命令
用户列表
java -jar dms-cli.jar user list --page 1 --page-size 10
用户详情
java -jar dms-cli.jar user detail --id 123
添加用户
java -jar dms-cli.jar user add --email "user@example.com" --captcha "123456"
删除用户
java -jar dms-cli.jar user delete --id 123 java -jar dms-cli.jar user delete --id 123 --tenant-id 456
修改用户
java -jar dms-cli.jar user modify --id 123 --comment "用户备注"
三、团队管理命令
创建团队
java -jar dms-cli.jar team create --name "数据分析团队" --desc "团队描述" --manager-ids "42"
按名称查找团队
java -jar dms-cli.jar team find --name "数据分析团队" # 返回: {"id":"123","teamName":"数据分析团队","memberCount":1,...} # Agent可以通过此命令获取团队ID
添加团队成员
# role取值说明: # 1 = 管理员 (ADMIN) # 2 = 普通成员 (MEMBER) # 5 = 只读 (READONLY) java -jar dms-cli.jar team add-member --team-id 123 --user-id "405" --role 2
修改团队
java -jar dms-cli.jar team modify --id 123 --name "新团队名"
删除团队
java -jar dms-cli.jar team delete --id 123
团队详情
java -jar dms-cli.jar team detail --id 123
团队列表
java -jar dms-cli.jar team list --page 1 --page-size 10
我的团队
java -jar dms-cli.jar team my
四、工单管理命令
创建工单
# 导出工单 (type=export) java -jar dms-cli.jar workorder create \ --type export \ --instance-id 123 \ --database "db_name" \ --table "table_name" # 导入工单 (type=import) java -jar dms-cli.jar workorder create \ --type import \ --instance-id 123 \ --database "db_name" # SQL变更工单 (type=sql) java -jar dms-cli.jar workorder create \ --type sql \ --instance-id 123 \ --sql "UPDATE table SET column='value' WHERE id=1"
工单详情
java -jar dms-cli.jar workorder detail --id 123
工单列表
# 支持 status 参数过滤 # status取值: # 0=待提交, 1=审批中, 2=审批通过, 3=审批拒绝 # 4=执行中, 5=执行成功, 6=执行失败, 7=已撤回, 8=已关闭 java -jar dms-cli.jar workorder list --page 1 --page-size 10 java -jar dms-cli.jar workorder list --status 1
撤回工单
java -jar dms-cli.jar workorder withdraw --id 123
重试工单
java -jar dms-cli.jar workorder retry --id 123
五、数据库查询命令 ⚠️
查看数据库列表
# ⚠️ 注意:可能返回空数组,建议使用 SQL 查询 java -jar dms-cli.jar database list --instance-id 123 # 分页查询 java -jar dms-cli.jar database page-list --instance-id 123 --page 1 --page-size 20
执行 SQL ⚠️ 完整流程
⚠️ 重要:执行 SQL 前必须先登录获取 Token!
流程步骤
-
查询实例详情,获取关键信息
java -jar dms-cli.jar instance detail --id <实例ID> # 记录 origin, dbAccount, controlType -
登录实例获取 Token
方式一:使用 dbAccountId 登录(推荐)
# 查询账户列表获取 dbAccountId java -jar dms-cli.jar instance account-list --id <实例ID> --origin <origin值> # 使用 dbAccountId 登录 java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account-id <账号ID> \ --origin <origin值>方式二:使用账密登录
# ⚠️ 参数是 --password,不是 --db-password # ⚠️ 必须指定正确的 --origin 值 # ⚠️ 密码需要用户手动提供 java -jar dms-cli.jar instance login \ --id <实例ID> \ --db-account <数据库账号> \ --password <数据库密码> \ --origin <origin值> -
⚠️ 验证当前数据库(关键步骤!)
# MySQL/PostgreSQL 验证当前数据库 java -jar dms-cli.jar sql execute \ --instance-id <实例ID> \ --sql "SELECT current_database()" \ --instance-token <Token> \ --origin <origin值> # 确认返回的数据库名称是否为目标数据库! # 如果不匹配,需要使用 --db-id 参数或重新登录 -
执行 SQL
# 基本执行 java -jar dms-cli.jar sql execute \ --instance-id <实例ID> \ --sql "SELECT * FROM table_name" \ --instance-token <登录获取的Token> \ --origin <origin值> # PostgreSQL 必须使用 db-id 参数 java -jar dms-cli.jar sql execute \ --instance-id <实例ID> \ --sql "CREATE TABLE test (id INT)" \ --database <数据库名> \ --db-id <数据库ID> \ --schema-id <SchemaID> \ --db-type 2 \ --instance-token <Token> \ --origin <origin值> -
⚠️ 执行后验证数据是否写入正确的数据库
java -jar dms-cli.jar sql execute \ --instance-id <实例ID> \ --sql "SELECT current_database(), table_name FROM information_schema.tables WHERE table_schema = 'public'" \ --database <数据库名> \ --instance-token <Token> \ --origin <origin值>
SQL 执行示例
# 1. 登录获取 Token java -jar dms-cli.jar instance login \ --id 10413 \ --db-account root \ --password "DIEVU-k7eNxR" \ --origin 2 # 返回: {"code":200,"data":"26d4540fe7e01ff1",...} # 2. ⚠️ 验证当前数据库 java -jar dms-cli.jar sql execute \ --instance-id 10413 \ --sql "SELECT database()" \ --instance-token "26d4540fe7e01ff1" \ --origin 2 # 确认返回的数据库名称是否正确! # 3. 使用 Token 查询数据库列表 java -jar dms-cli.jar sql execute \ --instance-id 10413 \ --sql "SHOW DATABASES" \ --instance-token "26d4540fe7e01ff1" \ --origin 2 # 4. 在指定数据库执行 SQL(先验证数据库) java -jar dms-cli.jar sql execute \ --instance-id 10413 \ --sql "SHOW TABLES" \ --database "dms_console" \ --instance-token "26d4540fe7e01ff1" \ --origin 2 # 5. PostgreSQL 示例(必须使用 db-id 和 schema-id) # 先查询数据库 ID java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT datname, oid FROM pg_database WHERE datistemplate = false" \ --instance-token "xxx" \ --origin 2 # 使用 db-id 执行 SQL java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "CREATE TABLE test (id INT PRIMARY KEY)" \ --database tpcds \ --db-id 17575 \ --schema-id 4239 \ --db-type 2 \ --instance-token "xxx" \ --origin 2 # 验证表是否创建在正确的数据库 java -jar dms-cli.jar sql execute \ --instance-id 10292 \ --sql "SELECT current_database(), tablename FROM pg_tables WHERE schemaname = 'public'" \ --database tpcds \ --db-id 17575 \ --instance-token "xxx" \ --origin 2
配置文件说明
配置文件
config.json 需要包含以下内容:
{ "base_url": "https://localhost:8091", "ws_url": "wss://localhost:8091/cloud/ws/sqlConsole/query", "tokens": ["token1", "token2"], "headers": { "Accept": "application/json, text/plain, */*", "Accept-Language": "zh-CN", "Content-Type": "application/json", "From-Client": "true", "User-Agent": "Mozilla/5.0..." }, "cookies": { "Authorization-jwt": "your_jwt_token", "XSRF-TOKEN": "your_xsrf_token", "Authorization-jwt-local": "your_local_token" }, "xsrf_token": "your_xsrf_token", "verify": false }
API 接口说明
一、实例管理
| 功能 | 方法 | 接口 | 说明 |
|---|---|---|---|
| 创建实例 | POST | | 创建新的数据库实例 |
| 修改实例 | POST | | 修改实例信息,支持添加实例到团队 |
| 删除实例 | POST | | 删除指定实例 |
| 实例详情 | POST | | 获取实例详细信息 |
| 实例列表 | POST | | 分页查询实例列表 |
| 测试连接 | POST | | 测试实例连接是否正常 |
| 登录实例 | POST | | 登录到指定实例 |
| 登出实例 | POST | | 登出实例 |
| 添加实例到团队 | POST | | 通过修改接口的 参数添加 |
二、用户与团队管理
| 功能 | 方法 | 接口 | 说明 |
|---|---|---|---|
| 用户登录 | POST | | DMS 用户登录 |
| 用户登出 | POST | | DMS 用户登出 |
| 添加用户 | POST | | 添加用户到组织 |
| 删除用户 | POST | | 从组织删除用户 |
| 用户列表 | POST | | 分页查询用户列表 |
| 用户详情 | POST | | 获取用户详细信息 |
| 修改用户 | POST | | 修改用户信息 |
| 创建团队 | POST | | 创建新的团队 |
| 添加团队成员 | POST | | 将用户添加到团队 |
| 修改团队 | POST | | 修改团队信息 |
| 删除团队 | POST | | 删除指定团队 |
| 团队详情 | POST | | 获取团队详细信息 |
| 团队列表 | POST | | 分页查询团队列表 |
| 按名称查找团队 | - | 命令 | 遍历列表查找指定名称的团队 |
三、工单管理
| 功能 | 方法 | 接口 | 说明 |
|---|---|---|---|
| 创建工单 | POST | | 创建新的工单 |
| 工单详情 | POST | | 获取工单详情 |
| 工单列表 | POST | | 分页查询工单列表 |
| 撤回工单 | POST | | 撤回指定工单 |
| 重试工单 | POST | | 重试失败的工单 |
常见场景流程
场景一:创建团队并添加成员和实例
当用户要求创建团队、邀请用户加入、将实例添加到团队时,使用以下流程:
步骤1:创建团队
java -jar dms-cli.jar team create --name "团队名称" --desc "描述" --manager-ids "42" # 返回 {"code":200,"data":"SUCCESS"}
步骤2:查找新团队ID(因为创建返回无ID)
java -jar dms-cli.jar team find --name "团队名称" # 返回团队详情,包含 id
步骤3:添加成员
# role: 1=管理员, 2=普通成员, 5=只读 java -jar dms-cli.jar team add-member --team-id <团队ID> --user-id <用户ID> --role 2
步骤4:查找实例ID和origin(从instance detail获取)
java -jar dms-cli.jar instance detail --id <实例ID> # 从返回数据中找到 id, origin 字段
步骤5:将实例添加到团队
java -jar dms-cli.jar instance modify --id <实例ID> --team-id <团队ID> --origin <origin值>
场景二:SQL查询执行
⚠️ 请参考上方"数据库查询命令"部分的完整流程
重要说明
- 认证要求: 所有 API 调用需要有效的 JWT Token,通过配置文件中的
传递cookies - 密码安全: 敏感密码需要使用 AES 加密后传输,加密密钥为
DMS-FRONT@2023#* - 权限控制: 部分操作需要特定权限(如实例创建、删除需要对应功能权限)
- WebSocket 连接: SQL 执行使用 WebSocket 协议,需要保持连接直到查询完成
- 实例管控模式: 实例分为强管控和弱管控两种模式
- 弱管控 (controlType=0): 登录时无需密码,但执行 SQL 仍需要 Token
- 强管控 (controlType=1): 需要数据库账号密码授权后才能执行 SQL
- ⚠️ Token 有效期: Token 有有效期限制,过期需要重新登录
- ⚠️ origin 参数: 登录和 SQL 执行都必须指定正确的 origin 值,默认值可能不正确