Skip to content
OpenClaw 不踩坑恶意 Skills ,企业需 Skills Registry:Nacos 3.2 发布Know more

Console API

控制台API

Nacos 提供了若干开放的控制台API,当您有自定义开发Nacos对应的控制台UI需求时,您可以通过这些API,获取Nacos Server节点中的数据,从而实现自定义的Nacos控制台UI界面。

同时配合关闭Nacos 默认控制台UI来使用自定义UI,相关详情请参考控制台手册-关闭默认控制台

0. 控制台API 相关说明

0.1. 统一路径格式

Nacos的控制台 API,使用统一的Path格式进行的规范。格式为[/$nacos.console.contextPath]/v3/console/[module]/[subPath]..., 其中

  • $nacos.console.contextPath:控制台的根路径,默认为“,可以通过nacos.console.contextPath配置项进行修改。
  • module:控制台的模块名称,例如servercsnscore等。
  • subPath:控制台的子路径,例如statenamespaceconfig等, 可能有多层子路径。

下列列出的控制台API,采用默认$nacos.console.contextPath的情况进行展示,若已修改部署环境中的$nacos.console.contextPath 配置项,请自行修改调用API时的请求URL。

同时下列列出的控制台API样例中,均采用默认Nacos Console的端口进行展示,若已修改部署环境中的$nacos.console.port 配置项,请自行修改调用API时的请求URL。

0.2. 鉴权认证

Nacos 3.X 的控制台 API默认启用鉴权认证,除少量被标记为公开接口的API外,请在调用API时,携带正确的身份信息,否则请求将会被拦截。

若想要关闭鉴权,请设置nacos.core.auth.console.enabled=false,然后重启Nacos 控制台。

0.3. Swagger 类型文档

Nacos 3.X 的控制台 API 也提供了Swagger风格的文档,您可以通过访问Nacos Swagger控制台 API查看。

1. Nacos 基础控制台API

基础控制台API提供了Nacos 集群的基础信息,例如集群信息、命名空间信息等。

1.1. 获取集群状态信息

接口描述

通过该接口,可以获取到Nacos 集群的基础状态和开关信息,例如:版本号,运行模式,鉴权是否开启等;该接口不会返回Nacos 集群的节点信息。

请求方式

GET

鉴权状态

公开接口,无需身份信息。

请求URL

/v3/console/server/state

请求参数

返回数据

参数名参数类型描述
versionstringNacos集群的版本号,例如3.0.0
startup_modestringNacos集群的模式,例如standalonecluster
server_portintegerNacos集群的主端口,例如8848
function_modestringNacos集群的功能模式,例如confignamingall, 若为null时,相当于all
datasource_platformstringNacos集群的数据源类型,例如mysqlderby等,若为“时,说明使用默认数据源类型
console_ui_enabledbooleanNacos控制台UI是否启用
auth_enabledbooleanNacos是否启用鉴权
auth_admin_requestbooleanNacos是否需要初始化admin用户nacos
auth_system_typestringNacos鉴权的插件类型,例如nacos等,若为“时,说明使用默认鉴权系统类型
login_page_enabledbooleanNacos控制台是否启用登录页
plugin_datasource_log_enabledbooleanNacos是否启用打印数据源访问Debug日志
config_retention_daysintegerNacos集群的配置历史数据保留天数,单位为天
isManageCapacitybooleanNacos是否启用配置容量限制检查,默认为true,开启时仅会统计当前配置的使用量,在超过限额时不会拒绝请求。
isCapacityLimitCheckbooleanNacos是否启用配置容量限制检查,默认为false,开启后当配置容量超出限额时,会拒绝配置的变更请求。
defaultMaxSizeintegerNacos集群的配置文件大小限制,单位为Byte,默认为102400,即100KB。
defaultGroupQuotaintegerNacos集群的单个分组(GroupName)下的配置文件数量限额,默认为200
defaultClusterQuotaintegerNacos集群的整个集群配置文件数量限额,默认为100000
isHealthCheckbooleanNacos是否启用naming模块健康检查,默认为true,开启后当注册到nacos上的服务实例出现异常时,Nacos会主动剔除该服务端节点。
maxContentinteger已废弃,请使用defaultMaxSize
defaultMaxAggrSizeinteger未实际使用,已废弃
defaultMaxAggrCountinteger未实际使用,已废弃

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/server/state'
  • 返回示例
{
"defaultMaxSize": "102400",
"auth_system_type": "nacos",
"auth_enabled": "false",
"defaultMaxAggrSize": "1024",
"maxHealthCheckFailCount": "12",
"maxContent": "10485760",
"console_ui_enabled": "true",
"defaultMaxAggrCount": "10000",
"auth_admin_request": "false",
"defaultGroupQuota": "200",
"config_retention_days": "30",
"startup_mode": "standalone",
"isHealthCheck": "true",
"version": "3.0.0-SNAPSHOT",
"function_mode": null,
"isManageCapacity": "true",
"isCapacityLimitCheck": "false",
"datasource_platform": "",
"notifyConnectTimeout": "100",
"server_port": "8848",
"notifySocketTimeout": "200",
"defaultClusterQuota": "100000",
"login_page_enabled": "false",
"plugin_datasource_log_enabled": "false"
}

1.2. 获取控制台公告信息

接口描述

通过该接口,可以获取到Nacos 控制台希望在浏览器中显示的公告信息。Nacos默认控制台UI会在未开启鉴权时调用此接口,返回集群未开启鉴权的提示。

请求方式

GET

鉴权状态

公开接口,无需身份信息。

请求URL

/v3/console/server/announcement

请求参数

参数名类型必填参数描述
languagestring访问的语言i18n值,默认为zh-CN,目前仅支持zh-CNen-US

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring控制台公告内容

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/server/announcement?language=zh-CN'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "当前集群没有开启鉴权,请参考<a href=\"https://nacos.io/zh-cn/docs/v2/guide/user/auth.html\">文档</a>开启鉴权~"
}

1.3. 获取控制台引导内容

接口描述

通过该接口,可以获取Nacos控制台的引导信息。Nacos默认控制台UI会在关闭Nacos控制台UI时调用,以获取引导信息,相关详情请参考控制台手册-关闭默认控制台

请求方式

GET

鉴权状态

公开接口,无需身份信息。

请求URL

/v3/console/server/guide

请求参数

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring控制台引导内容

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/server/guide'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "当前节点已关闭Nacos开源控制台使用,请修改application.properties中的nacos.console.ui.enabled参数为true打开开源控制台使用,详情查看<a href=\"https://nacos.io/zh-cn/docs/v2/guide/admin/console-guide.html\">文档</a>中关于<code>关闭默认控制台部分</code>。"
}

1.4. 获取Nacos控制台的存活状态

接口描述

通过该接口,可以获取Nacos控制台的存活状态,Nacos控制台是否可正常接受和响应请求。

请求方式

GET

鉴权状态

公开接口,无需身份信息。

请求URL

/v3/console/health/liveness

请求参数

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring固定为ok

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/health/liveness'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

1.5. 获取Nacos控制台的可读状态

接口描述

通过该接口,可以获取Nacos控制台的是否处于可读取状态,即Nacos控制台是否可以读取到数据。

请求方式

GET

鉴权状态

公开接口,无需身份信息。

请求URL

/v3/console/health/readiness

请求参数

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring若为可读状态时,固定为ok,否则为不可读的模块即对应原因信息

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/health/readiness'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

1.6. 获取Nacos节点运行信息

接口描述

通过该接口,可以获取Nacos节点运行信息,包括节点ip,节点运行状态,节点元数据等。

请求方式

GET

鉴权状态

需要Nacos 管理员用户权限。

请求URL

/v3/console/core/cluster/nodes

请求参数

无。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/core/cluster/nodes'
  • 返回示例
{
"code": 0,
"message": "success",
"data": [
{
"ip": "127.0.0.1",
"port": 8848,
"state": "UP",
"extendInfo": {
"lastRefreshTime": 1733221062619,
"raftMetaData": {
"metaDataMap": {
"naming_instance_metadata": {
"leader": "127.0.0.1:7848",
"raftGroupMember": [
"127.0.0.1:7848"
],
"term": 1
},
"naming_persistent_service": {
"leader": "127.0.0.1:7848",
"raftGroupMember": [
"127.0.0.1:7848"
],
"term": 1
},
"naming_persistent_service_v2": {
"leader": "127.0.0.1:7848",
"raftGroupMember": [
"127.0.0.1:7848"
],
"term": 1
},
"naming_service_metadata": {
"leader": "127.0.0.1:7848",
"raftGroupMember": [
"127.0.0.1:7848"
],
"term": 1
}
}
},
"raftPort": "7848",
"readyToUpgrade": true,
"supportGrayModel": true,
"version": "3.0.0-SNAPSHOT"
},
"address": "127.0.0.1:8848",
"failAccessCnt": 0,
"abilities": {
"remoteAbility": {
"supportRemoteConnection": true,
"grpcReportEnabled": true
},
"configAbility": {
"supportRemoteMetrics": false
},
"namingAbility": {
"supportJraft": true
}
},
"grpcReportEnabled": true
}
]
}

1.7. 获取Nacos命名空间列表

接口描述

通过该接口,可以获取当前Nacos集群的命名空间列表。

请求方式

GET

鉴权状态

任意有效鉴权身份信息。

由于命名空间是Nacos的基础隔离概念,因此大多数数据查询的接口都需要选择某个命名空间才能进行查询。因此,获取命名空间列表的能力应该是任意有效身份信息用户均可访问。

请求URL

/v3/console/core/namespace/list

请求参数

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
namespacestring命名空间id
namespaceShowNamestring命名空间名称
namespaceDescstring命名空间描述
configCountinteger命名空间下的配置个数
quotainteger命名空间的配置个数配额,需开启配置配额功能才会实际生效,默认不开启,仅做预留字段。
typeinteger命名空间的类型,预留字段,目前为0时为默认命名空间、2时为自定义创建的命名空间。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/core/namespace/list'
  • 返回示例
{
"code": 0,
"message": "success",
"data": [
{
"namespace": "public",
"namespaceShowName": "public",
"namespaceDesc": "Default Namespace",
"quota": 200,
"configCount": 0,
"type": 0
}
]
}

1.8. 获取命名空间详情

接口描述

通过该接口,可以获取指定命名空间的详情。

请求方式

GET

鉴权状态

需要Nacos 管理员用户权限。

请求URL

/v3/console/core/namespace

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间id。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
namespacestring命名空间id
namespaceShowNamestring命名空间名称
namespaceDescstring命名空间描述
configCountinteger命名空间下的配置个数
quotainteger命名空间的配置个数配额,需开启配置配额功能才会实际生效,默认不开启,仅做预留字段。
typeinteger命名空间的类型,预留字段,目前为0时为默认命名空间、2时为自定义创建的命名空间。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/core/namespace?namespaceId=public'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"namespace": "public",
"namespaceShowName": "public",
"namespaceDesc": "Default Namespace",
"quota": 200,
"configCount": 0,
"type": 0
}
}

1.9. 创建新命名空间

接口描述

通过该接口,可以创建新的命名空间。

请求方式

POST

鉴权状态

需要Nacos 管理员用户权限。

请求URL

/v3/console/core/namespace

请求参数

参数名类型必填参数描述
customNamespaceIdstring命名空间id,未填入时将会使用UUID生成ID。
namespaceNamestring命名空间名称。
namespaceDescstring命名空间描述。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean创建命名空间是否成功。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/core/namespace' -d 'namespaceName=test&namespaceDesc=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

1.10. 更新命名空间

接口描述

通过该接口,可以更新命名空间的信息,无法更新命名空间ID,仅能更新命名空间的名称和描述。

请求方式

PUT

鉴权状态

需要Nacos 管理员用户权限。

请求URL

/v3/console/core/namespace

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间ID
namespaceNamestring命名空间名称。
namespaceDescstring命名空间描述。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean更新命名空间是否成功。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/core/namespace' -d 'namespaceId=test&namespaceName=test&namespaceDesc=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

1.11. 删除命名空间

接口描述

通过该接口,可以删除命名空间。默认命名空间public无法被删除。

请求方式

DELETE

鉴权状态

需要Nacos 管理员用户权限。

请求URL

/v3/console/core/namespace

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间ID。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean删除命名空间是否成功。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/core/namespace?namespaceId=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

1.12. 检查命名空间是否存在

接口描述

通过该接口,可以检查命名空间ID是否存在。默认控制台ID将在创建命名空间前调用,确认自定义的命名空间ID是否已经存在,以防冲突。

请求方式

GET

鉴权状态

任意有效鉴权身份信息。

请求URL

/v3/console/core/namespace/exist

请求参数

参数名类型必填参数描述
customNamespaceIdstring命名空间ID,传入空字符串时认为是需要自动生成的UUID。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean命名空间是否存在,存在是为true,否则为false

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/core/namespace/exist?customNamespaceId=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": false
}

1.13. 获取插件详情

接口描述

通过该接口,可以按类型和名称获取指定插件的详情信息。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/plugin

请求参数

参数名类型必填参数描述
pluginTypestring插件类型,如 auth(鉴权)、control(控制)、datasource(数据源)等。
pluginNamestring插件名称,如 nacos-default-auth-plugin

返回数据

参数名参数类型描述
data.pluginIdstring插件唯一标识。
data.pluginTypestring插件类型。
data.pluginNamestring插件名称。
data.enabledboolean当前是否已启用。
data.criticalboolean是否为关键插件(关键插件不可被禁用)。
data.configurableboolean是否支持控制台动态配置。
data.configobject插件当前配置项。
data.configDefinitionsarray插件配置项定义列表,用于渲染配置表单。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/plugin?pluginType=auth&pluginName=nacos-default-auth-plugin'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"name": "nacos-default-auth-plugin",
"type": "auth",
"enabled": true,
"config": {}
}
}

1.14. 查询插件在集群节点上的可用性

接口描述

通过该接口,可以获取指定插件在各集群节点上的可用情况。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/plugin/availability

请求参数

参数名类型必填参数描述
pluginTypestring插件类型,如 authcontroldatasource 等。
pluginNamestring插件名称。

返回数据

返回 data 为 Map<节点地址, 是否可用>,键为 Nacos 节点地址(如 127.0.0.1:8848),值为该节点上该插件是否可用。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/plugin/availability?pluginType=auth&pluginName=nacos-default-auth-plugin'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"127.0.0.1:8848": true
}
}

1.15. 更新插件配置

接口描述

通过该接口,可以更新插件的配置。需要提供插件类型、名称及配置内容。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/plugin/config

请求参数

参数名类型必填参数描述
pluginTypestring插件类型。
pluginNamestring插件名称。
configstring插件配置内容,JSON 对象,具体字段由插件定义。

返回数据

参数名参数类型描述
datastring操作结果描述信息。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/plugin/config' \
-d 'pluginType=auth' \
-d 'pluginName=nacos-default-auth-plugin' \
-d 'config={}'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "Plugin configuration updated successfully"
}

1.16. 获取插件列表

接口描述

通过该接口,可以获取插件列表,可按插件类型筛选。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/plugin/list

请求参数

参数名类型必填参数描述
pluginTypestring插件类型;不传则返回所有类型的插件列表。

返回数据

返回 data 为插件信息数组,每项包含插件名称、类型、是否启用等。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/plugin/list?pluginType=auth'
  • 返回示例
{
"code": 0,
"message": "success",
"data": [
{
"name": "nacos-default-auth-plugin",
"type": "auth",
"enabled": true
}
]
}

1.17. 启用或禁用插件

接口描述

通过该接口,可以更新插件的启用状态(启用或禁用)。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/plugin/status

请求参数

参数名类型必填参数描述
pluginTypestring插件类型。
pluginNamestring插件名称。
enabledboolean是否启用,true 启用、false 禁用。
localOnlyboolean是否仅更新本地节点插件状态。

返回数据

参数名参数类型描述
datastring操作结果描述信息。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/plugin/status' \
-d 'pluginType=auth' \
-d 'pluginName=nacos-default-auth-plugin' \
-d 'enabled=True'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "Plugin status updated successfully"
}

2. 配置管理

2.1. 获取配置详情

接口描述

通过该接口,可以获取指定配置的详情。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config

请求参数

参数名类型必填参数描述
dataIdstring配置ID。
groupNamestring配置分组。
namespaceIdstring命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
idstring配置在存储系统中的ID,一般为Long类型的字符串。
dataIdstring配置ID。
groupNamestring配置分组。
namespaceIdstring命名空间ID。
contentstring配置内容。
descstring配置描述。
md5string配置内容的MD5值。
configTagsstring配置的标签。
encryptedDataKeystring加密配置内容的密钥,使用配置加密插件时存在。
appNamestring配置所属的应用名称。
typestring配置类型。
createTimeinteger配置创建时间。
modifyTimeinteger配置修改时间。
createUserstring配置创建人。
createIpstring配置创建IP。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/cs/config?dataId=test&groupName=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"appName": "",
"configTags": null,
"content": "test",
"createIp": "127.0.0.1",
"createTime": 1741681316620,
"createUser": "nacos",
"dataId": "test",
"desc": null,
"encryptedDataKey": "",
"groupName": "test",
"id": "873472517803610112",
"md5": "098f6bcd4621d373cade4e832627b4f6",
"modifyTime": 1741681316620,
"namespaceId": "public",
"type": "text"
}
}

2.2. 发布配置

接口描述

通过该接口,可以创建新的配置或更新已有配置。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config

请求参数

参数名类型必填参数描述
dataIdstring配置ID。
groupNamestring配置分组。
namespaceIdstring命名空间ID,默认值为public
contentstring配置内容。
descstring配置描述。
typestring配置类型,默认值为text
configTagsstring配置标签,多个标签之间用英文逗号分隔。
appNamestring配置所属应用名称,主要用于标记配置所使用的应用。
  • 当配置已存在(dataId,groupName相同)时,再次调用此接口将会对此配置进行更新
  • 同时更新配置时,若请求Header中存在betaIps,则会将配置标记为BETA配置,在终止BETA或完全发布配置之前,控制台UI需要进行特殊处理。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean创建配置是否成功。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/cs/config' -d 'dataId=test&groupName=test&namespaceId=public&content=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

2.3. 删除配置

接口描述

通过该接口,可以删除指定配置。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config

请求参数

参数名类型必填参数描述
dataIdstring配置ID。
groupNamestring配置分组。
namespaceIdstring命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean删除配置是否成功。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/cs/config?dataId=test&groupName=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

2.4. 批量删除配置

接口描述

通过该接口,可以批量删除指定配置。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config/batchDelete

请求参数

参数名类型必填参数描述
idsstring配置的存储ID列表,并非dataId列表,多个ID之间用英文逗号分隔。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
databoolean删除配置是否成功。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/cs/config/batchDelete?ids=838025461287096320,838025489170829312'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

2.5. 查询配置列表

接口描述

通过该接口,可以查询指定命名空间下的配置列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/list

请求参数

参数名类型必填参数描述
pageNointeger当前页码,起始值为1。
pageSizeinteger每页显示的配置数量。
dataIdstring配置ID,当searchblur时,可使用*进行模糊搜索,例如test*,当值为“或缺失时,查询全部符合groupName条件的配置。
groupNamestring配置分组,当searchblur时,可使用*进行模糊搜索,例如test*,当值为“或缺失时,查询全部符合dataId条件的配置。
searchstringblur or accurate
namespaceIdstring命名空间ID,默认值为public
appNamestring配置所属应用名称,默认为空,传入时过滤归属于此应用的配置,值为空时查询所有应用的配置。
configTagsstring配置标签,多个标签之间用英文逗号分隔,默认为空,传入时过滤拥有此tag的配置,值为空时查询所有tag的配置。
typestring配置的类型,默认值为空,传入时过滤此类型的配置,值为空时查询所有类型的配置。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合规则的配置总数。
pagesAvailableinteger可用页码总数。
pageNumberinteger当前页码。
pageItemsList符合规则的配置列表。
pageItems[i].idstring配置在存储系统中的ID,一般为Long类型的字符串。
pageItems[i].dataIdstring配置ID。
pageItems[i].groupNamestring配置分组。
pageItems[i].namespaceIdstring命名空间ID。
pageItems[i].md5string配置内容的MD5值。
pageItems[i].appNamestring配置所属的应用名称。
pageItems[i].typestring配置类型。
pageItems[i].createTimeinteger配置创建时间。
pageItems[i].modifyTimeinteger配置修改时间。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/cs/config/list?dataId=&groupName=&appName=&configTags=&pageNo=1&pageSize=10&namespaceId=&type=&search=blur'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"pageItems": [
{
"appName": "",
"createTime": 0,
"dataId": "aaa",
"groupName": "DEFAULT_GROUP",
"id": "873471898128748544",
"md5": null,
"modifyTime": 0,
"namespaceId": "public",
"type": "text"
},
{
"appName": "",
"createTime": 0,
"dataId": "bbb",
"groupName": "DEFAULT_GROUP",
"id": "873473460813172736",
"md5": null,
"modifyTime": 0,
"namespaceId": "public",
"type": "text"
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 2
}
}

2.6. 通过配置内容查询配置

接口描述

通过该接口,可以通过配置内容查询对应配置的列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/searchDetail

请求参数

参数名类型必填参数描述
pageNointeger当前页码,起始值为1。
pageSizeinteger每页显示的配置数量。
searchstringblur or accurate
namespaceIdstring命名空间ID,默认值为public
dataIdstring配置ID,当searchblur时,可使用*进行模糊搜索,例如test*,当值为“或缺失时,查询全部符合groupName条件的配置。
groupNamestring配置分组,当searchblur时,可使用*进行模糊搜索,例如test*,当值为“或缺失时,查询全部符合dataId条件的配置。
appNamestring配置所属应用名称,默认为空,传入时过滤归属于此应用的配置,值为空时查询所有应用的配置。
configTagsstring配置标签,多个标签之间用英文逗号分隔,默认为空,传入时过滤拥有此tag的配置,值为空时查询所有tag的配置。
typestring配置的类型,默认值为空,传入时过滤此类型的配置,值为空时查询所有类型的配置。
configDetailstring配置内容检索条件,用于按配置内容过滤,支持模糊匹配(如 *11*)。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合规则的配置总数。
pagesAvailableinteger可用页码总数。
pageNumberinteger当前页码。
pageItemsList符合规则的配置列表。
pageItems[i].idstring配置在存储系统中的ID,一般为Long类型的字符串。
pageItems[i].dataIdstring配置ID。
pageItems[i].groupNamestring配置分组。
pageItems[i].namespaceIdstring命名空间ID。
pageItems[i].md5string配置内容的MD5值。
pageItems[i].appNamestring配置所属的应用名称。
pageItems[i].typestring配置类型。
pageItems[i].createTimeinteger配置创建时间。
pageItems[i].modifyTimeinteger配置修改时间。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/cs/config/searchDetail?dataId=&groupName=&appName=&configTags=&pageNo=1&pageSize=10&namespaceId=&type=&search=blur&configDetail=*11*'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"pageItems": [
{
"appName": "",
"createTime": 0,
"dataId": "111",
"groupName": "DEFAULT_GROUP",
"id": "873475812546842624",
"md5": null,
"modifyTime": 0,
"namespaceId": "public",
"type": "text"
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 1
}
}

2.7. 查询配置的监听者列表

接口描述

通过该接口,可以查询指定配置的监听者列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/listener

请求参数

参数名类型必填参数描述
dataIdstring配置ID。
groupNamestring配置分组。
namespaceIdstring命名空间ID,默认值为public
aggregationboolean是否聚合查询。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
queryTypestring订阅者查询类型,该接口为config
listenersStatusmap<string, string>订阅者列表,key为订阅者IP,value为订阅者订阅当前配置的MD5值。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/cs/config/listener?dataId=test&groupName=test'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"listenersStatus": {
"127.0.0.1": "32cacc65accfdab47954de3fc781e938"
},
"queryType": "config"
}
}

2.8. 查询某个订阅者IP订阅了哪些配置

接口描述

通过该接口,可以查询某个订阅者IP订阅了哪些配置。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/listener/ip

请求参数

参数名类型必填参数描述
ipstring订阅者IP。
allboolean是否查询全部订阅数据。
namespaceIdstring命名空间ID,默认值为public
aggregationboolean是否聚合查询。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
queryTypestring订阅者查询类型,该接口为ip
listenersStatusmap<string, string>订阅者列表,key为订阅的配置信息,格式为dataId+groupName+namespaceId,value为订阅者订阅当前配置的MD5值。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/cs/config/listener/ip?ip=127.0.0.1'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"listenersStatus": {
"qtc-user.yaml+DEFAULT_GROUP+public": "32cacc65accfdab47954de3fc781e938"
},
"queryType": "ip"
}
}

2.9. 导出配置

接口描述

通过该接口,可以将所选或所查询的配置,导出的配置为zip文件,进行备份或导入到其他Nacos集群。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/export2

请求参数

参数名类型必填参数描述
dataIdstring需要导出的配置ID的pattern,例如test*
groupNamestring需要导出的配置分组的pattern,例如test*
idsstring需要导出的配置的存储ID,多个ID用英文逗号分隔。
namespaceIdstring命名空间ID,默认值为public
appNamestring需要导出的配置所属的应用名称。

使用时建议分开使用 idsdataId + groupName 的组合,只选择一种方式,另一类传入空字符串,否则可能导致导出文件为空内容。

返回数据

导出成功是为byte数组的file attachment模式,导出失败时返回体遵循Nacos open API 统一返回体格式

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/cs/config/export2?dataId=&groupId=&ids=" --output ~/test.zip
  • 返回示例
Terminal window
unzip ~/test.zip
> Archive: /path/to/test.zip
> inflating: DEFAULT_GROUP/111
> inflating: DEFAULT_GROUP/qtc-user.yaml
> inflating: .metadata.yml

2.10. 导入配置

接口描述

通过该接口,可以将从Nacos导出的zip文件导入到Nacos的指定命名空间中

请求方式

POST

请求体类型:multipart/form-data

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config/import

请求参数

参数名类型必填参数描述
fileMultipartFile导入的zip文件。
namespaceIdstring导入的配置所属的命名空间ID,默认值为public
policystring导入策略,当导入的配置dataIdgroupName相同,存在冲突时,所进行的导入策略。可选值有ABORT(终止导入),SKIP(跳过冲突配置),OVERWRITE(覆盖冲突配置)。默认值为ABORT
src_userstring导入操作来源用户标识。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
succCountinteger导入成功的配置数量。
skipCountinteger导入跳过的配置数量。

示例

  • 请求示例
Terminal window
curl -vX POST "http://127.0.0.1:8080/v3/console/cs/config/import" -F "file=@/path/to/test.zip" -F "namespaceId=test"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"succCount": 2,
"skipCount": 0
}
}

2.11. 克隆配置

接口描述

通过该接口,可以将所选或所查询的配置克隆到其他命名空间。

请求方式

POST

请求体类型:application/json,为配置列表数组。

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config/clone

请求参数

参数名类型必填参数描述
srcUserstring克隆操作来源用户标识。
targetNamespaceIdstring目标命名空间ID。
policystring克隆策略,当导入的配置dataIdgroupName相同,存在冲突时,所进行的克隆策略。可选值有ABORT(终止克隆),SKIP(跳过冲突配置),OVERWRITE(覆盖冲突配置)。默认值为ABORT

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
succCountinteger成功克隆的配置数量。
skipCountinteger克隆跳过的配置数量。

示例

  • 请求示例
Terminal window
curl -H "Content-Type: application/json" -X POST "http://127.0.0.1:8080/v3/console/cs/config/clone?targetNamespaceId=public&policy=ABORT" -d "[{\"cfgId\":838029534438625280,\"dataId\":\"111\",\"group\":\"DEFAULT_GROUP\"},{\"cfgId\":838033747294031872,\"dataId\":\"qtc-user.yaml\",\"group\":\"DEFAULT_GROUP\"}]"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"succCount": 2,
"skipCount": 0
}
}

2.12. 停止配置BETA发布

接口描述

通过该接口,可以将配置从BETA发布状态停止,即回滚配置的Beta发布状态。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/cs/config/beta

请求参数

参数名类型必填参数描述
dataIdstring配置的dataId
groupNamestring配置的groupName
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述

示例

  • 请求示例
Terminal window
curl -X DELETE "http://127.0.0.1:8080/v3/console/cs/config/beta?dataId=test&groupName=DEFAULT_GROUP"
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

2.13. 查询配置Beta发布状态

接口描述

通过该接口,可以查询配置的BETA发布状态。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/config/beta

请求参数

参数名类型必填参数描述
dataIdstring配置的dataId
groupNamestring配置的groupName
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
idstringbeta配置的存储ID。
dataIdstring配置的dataId。
groupNamestring配置的groupName。
namespaceIdstring配置所属的命名空间。
descstring配置描述。
md5string配置内容的MD5值。
configTagsstring配置的标签。
encryptedDataKeystring加密配置内容的密钥,使用配置加密插件时存在。
appNamestring配置所属的应用名称。
typestring配置类型。
createTimeinteger配置创建时间。
modifyTimeinteger配置修改时间。
createUserstring配置创建人。
createIpstring配置创建IP。
grayNamestring灰度发布规则名称, 固定为beta
grayRulestring灰度发布规则,格式为JSON,其中的expr为beta的ip列表。

示例

  • 请求示例
Terminal window
curl "http://127.0.0.1:8080/v3/console/cs/config/beta?dataId=111&groupName=DEFAULT_GROUP"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"appName": "",
"configTags": null,
"content": "bbb11xxccc",
"createIp": null,
"createTime": 0,
"createUser": "nacos",
"dataId": "111",
"desc": null,
"encryptedDataKey": null,
"grayName": "beta",
"grayRule": "{\"type\":\"beta\",\"version\":\"1.0.0\",\"expr\":\"1.1.1.1\",\"priority\":2147483647}",
"groupName": "DEFAULT_GROUP",
"id": "873481464488923136",
"md5": "2f080e5e21ba12bb8ca6894ac0fc5862",
"modifyTime": 1741683449619,
"namespaceId": "public",
"type": null
}
}

2.14. 查询配置发布历史

接口描述

通过该接口,可以查询配置的发布历史。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/history/list

请求参数

参数名类型必填参数描述
pageNointeger当前页码,起始为1
pageSizeinteger每页显示的记录数。
dataIdstring配置的dataId
groupNamestring配置的groupName
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger历史记录的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList历史记录列表。
pageItems[i].idstring历史记录的ID。
pageItems[i].dataIdstring配置的dataId。
pageItems[i].groupNamestring配置的groupName。
pageItems[i].namespaceIdstring配置所属的命名空间。
pageItems[i].appNamestring配置所属的appName。
pageItems[i].opTypestring操作类型,I为插入、U为更新、D为删除。
pageItems[i].publishTypestring发布类型,formal为普通发布,gray为beta发布。
pageItems[i].srcIpstring发布的来源IP。
pageItems[i].srcUserstring发布的用户,仅在开启鉴权并登录用户后才发布配置才存在。
pageItems[i].createTimeinteger配置创建时间。
pageItems[i].modifyTimeinteger配置修改时间。

示例

  • 请求示例
Terminal window
curl "http://127.0.0.1:8080/v3/console/cs/history/list?pageNo=1&pageSize=10&dataId=111&groupName=DEFAULT_GROUP"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"pageItems": [
{
"appName": "",
"createTime": 1272988800000,
"dataId": "111",
"groupName": "DEFAULT_GROUP",
"id": "18",
"md5": null,
"modifyTime": 1741683760489,
"namespaceId": "public",
"opType": "D ",
"publishType": "gray",
"srcIp": "127.0.0.1",
"srcUser": "nacos",
"type": null
},
{
"appName": "",
"createTime": 1272988800000,
"dataId": "111",
"groupName": "DEFAULT_GROUP",
"id": "17",
"md5": null,
"modifyTime": 1741683449619,
"namespaceId": "public",
"opType": "I ",
"publishType": "gray",
"srcIp": "0:0:0:0:0:0:0:1",
"srcUser": "nacos",
"type": null
},
{
"appName": "",
"createTime": 1272988800000,
"dataId": "111",
"groupName": "DEFAULT_GROUP",
"id": "7",
"md5": null,
"modifyTime": 1741682102157,
"namespaceId": "public",
"opType": "I ",
"publishType": "formal",
"srcIp": "0:0:0:0:0:0:0:1",
"srcUser": "nacos",
"type": null
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 3
}
}

2.15. 查询配置的某次历史变更记录

接口描述

通过该接口,可以查询配置的某次历史变更记录。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/history

请求参数

参数名类型必填参数描述
nidinteger历史记录的ID。
dataIdstring配置的dataId。
groupNamestring配置的groupName。
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
idstring历史记录的ID。
dataIdstring配置的dataId。
groupNamestring配置的groupName。
namespaceIdstring配置所属的命名空间。
contentstring
appNamestring配置所属的appName。
opTypestring操作类型,I为插入、U为更新、D为删除。
publishTypestring发布类型,formal为普通发布,gray为beta发布。
srcIpstring发布的来源IP。
srcUserstring发布的用户,仅在开启鉴权并登录用户后才发布配置才存在。
createTimeinteger配置创建时间。
modifyTimeinteger配置修改时间。
grayNamestring灰度发布规则名称, 固定为beta
extInfoJsonString扩展信息,目前包括src_usertypec_desc,若publishTypegray, 其中还包括grayRule

示例

  • 请求示例
Terminal window
curl "http://127.0.0.1:8080/v3/console/cs/history?dataId=111&groupName=DEFAULT_GROUP&nid=7"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"appName": "",
"content": "bbb11xx",
"createTime": 1272988800000,
"dataId": "111",
"encryptedDataKey": "",
"extInfo": "{\"src_user\":\"nacos\",\"type\":\"text\",\"c_desc\":\"111\"}",
"grayName": "",
"groupName": "DEFAULT_GROUP",
"id": "7",
"md5": "7d37afdb0b04d958d529bcb6de44fa71",
"modifyTime": 1741682102157,
"namespaceId": "public",
"opType": "I ",
"publishType": "formal",
"srcIp": "0:0:0:0:0:0:0:1",
"srcUser": "nacos",
"type": null
}
}

2.16. 查询配置最新状态的前一次变更历史

接口描述

通过该接口,可以查询配置最新状态的前一次变更历史。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/history/previous

请求参数

参数名类型必填参数描述
idinteger配置的存储ID。
dataIdstring配置的dataId。
groupNamestring配置的groupName。
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
idstring历史记录的ID。
dataIdstring配置的dataId。
groupNamestring配置的groupName。
namespaceIdstring配置所属的命名空间。
contentstring
appNamestring配置所属的appName。
opTypestring操作类型,I为插入、U为更新、D为删除。
publishTypestring发布类型,formal为普通发布,gray为beta发布。
srcIpstring发布的来源IP。
srcUserstring发布的用户,仅在开启鉴权并登录用户后才发布配置才存在。
createTimeinteger配置创建时间。
modifyTimeinteger配置修改时间。
grayNamestring灰度发布规则名称, 固定为beta
extInfoJsonString扩展信息,目前包括src_usertypec_desc,若publishTypegray, 其中还包括grayRule

示例

  • 请求示例
Terminal window
curl "http://127.0.0.1:8080/v3/console/cs/history/previous?id=838029534438625280&dataId=111&groupName=DEFAULT_GROUP"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"appName": "",
"content": "bbb11xx",
"createTime": 1272988800000,
"dataId": "111",
"encryptedDataKey": "",
"extInfo": "{\"src_user\":\"nacos\",\"type\":\"text\",\"c_desc\":\"111\"}",
"grayName": "",
"groupName": "DEFAULT_GROUP",
"id": "7",
"md5": "7d37afdb0b04d958d529bcb6de44fa71",
"modifyTime": 1741682102157,
"namespaceId": "public",
"opType": "I ",
"publishType": "formal",
"srcIp": "0:0:0:0:0:0:0:1",
"srcUser": "nacos",
"type": null
}
}

2.17. 查询命名空间下的配置列表

接口描述

通过该接口,可以查询命名空间下的配置列表,仅查询dataId和groupName,用于配置历史UI的下拉选择。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/cs/history/configs

请求参数

参数名类型必填参数描述
namespaceIdstring配置所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
dataIdstring配置的dataId。
groupNamestring配置的groupName。

其他字段均无用。

示例

  • 请求示例
Terminal window
curl "http://127.0.0.1:8080/v3/console/cs/history/configs?namespaceId=public"
  • 返回示例
{
"code": 0,
"message": "success",
"data": [
{
"appName": "",
"createTime": 0,
"dataId": "111",
"groupName": "DEFAULT_GROUP",
"id": "0",
"md5": null,
"modifyTime": 1741682102161,
"namespaceId": "public",
"type": "text"
},
{
"appName": "",
"createTime": 0,
"dataId": "qtc-user.yaml",
"groupName": "DEFAULT_GROUP",
"id": "0",
"md5": null,
"modifyTime": 1741682291519,
"namespaceId": "public",
"type": "text"
}
]
}

3. 服务管理

3.1. 创建服务

接口描述

通过该接口,可以创建一个空服务。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ns/service

请求参数

参数名类型必填参数描述
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
protectThresholdnumber服务的防护阈值,默认值为0.0
selectorstring服务的路由选择器,默认值为{"type":"none"},无选择器,另外还支持通过label 进行路由。
metadatastring服务的元数据,默认值为{}
ephemeralboolean服务是否临时,默认值为false即持久化服务。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring创建成功时,固定为ok

示例

  • 请求示例
Terminal window
curl -X POST "http://127.0.0.1:8080/v3/console/ns/service" -d "serviceName=test&groupName=DEFAULT_GROUP&namespaceId=public"
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

3.2. 删除服务

接口描述

通过该接口,可以删除一个服务。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ns/service

请求参数

参数名类型必填参数描述
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring删除成功时,固定为ok

示例

  • 请求示例
Terminal window
curl -X DELETE "http://127.0.0.1:8080/v3/console/ns/service?serviceName=test&groupName=DEFAULT_GROUP&namespaceId=public"
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

3.3. 更新服务元数据

接口描述

通过该接口,可以更新一个服务的元数据。仅能更新服务的元数据,如metadataselector 等。服务的serviceName、groupName、namespaceId等不能更新。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ns/service

请求参数

参数名类型必填参数描述
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
protectThresholdnumber服务的防护阈值,默认值为0.0
ephemeralboolean是否临时实例,如 true/false
selectorstring服务的路由选择器,默认值为{"type":"none"},无选择器,另外还支持通过label 进行路由。
metadatastring服务的元数据,默认值为{}

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring更新成功时,固定为ok

示例

  • 请求示例
Terminal window
curl -X PUT "http://127.0.0.1:8080/v3/console/ns/service" -d "serviceName=test&groupName=DEFAULT_GROUP&namespaceId=public&protectThreshold=0"
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

3.4. 获取支持的服务路由选择器类型列表

接口描述

通过该接口,可以获取支持的服务路由选择器类型列表,用于控制台UI在创建和更新服务时,选择对应的路由选择器类型的下拉选择框。

请求方式

GET

鉴权状态

任意有效鉴权身份信息。

请求URL

/v3/console/ns/service/selector/types

请求参数

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
labelstring通过label表达式进行路由选择过滤。
nonestring无选择器。

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/ns/service/selector/types"
  • 返回示例
{
"code": 0,
"message": "success",
"data": [
"label",
"none"
]
}

3.5. 查询服务列表

接口描述

通过该接口,可以查询指定命名空间下的服务列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ns/service/list

请求参数

参数名类型必填参数描述
pageNostring页码,起始为1
pageSizestring每页显示条数。
serviceNameParamstring服务名的pattern,为空时查询所有服务。
groupNameParamstring服务所属的groupName的pattern,为空时查询所有服务。
namespaceIdstring服务所属的命名空间ID。
ignoreEmptyServicestring是否仅返回有实例的服务,默认为false,即查询空服务。
withInstancesstring是否返回服务的实例详情,默认为false

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合条件的服务的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList服务列表。
pageItems[i].namestring服务名。
pageItems[i].groupNamestring服务的分组名。
pageItems[i].clusterCountstring服务下的集群数量。
pageItems[i].ipCountstring服务下的实例数量。
pageItems[i].healthyInstanceCountstring服务下的健康实例数量。
pageItems[i].triggerFlagstring是否触发了服务的保护。

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/ns/service/list?pageNo=1&pageSize=10&namespaceId=public"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"pageItems": [
{
"clusterCount": 1,
"groupName": "DEFAULT_GROUP",
"healthyInstanceCount": 1,
"ipCount": 1,
"name": "com.test.SyncCallbackService",
"triggerFlag": "false"
},
{
"clusterCount": 1,
"groupName": "DEFAULT_GROUP",
"healthyInstanceCount": 0,
"ipCount": 1,
"name": "test",
"triggerFlag": "true"
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 2
}
}

3.6. 查询服务的订阅者列表

接口描述

通过该接口,可以查询指定服务下的订阅者列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ns/service/subscribers

请求参数

参数名类型必填参数描述
pageNostring页码,起始为1
pageSizestring每页显示条数。
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
aggregationstring是否聚合查询。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合条件的服务的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList服务列表。
pageItems[i].ipstring订阅者IP。
pageItems[i].portinteger订阅者端口。
pageItems[i].addressstring订阅者地址, 一般为ip:port
pageItems[i].agentstring订阅者客户端版本。
pageItems[i].appNamestring订阅者所属应用。
pageItems[i].namespaceIdstring订阅者所属命名空间。
pageItems[i].groupNamestring订阅的分组名。
pageItems[i].serviceNamestring订阅的服务名。

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/ns/service/subscribers?pageNo=1&pageSize=10&serviceName=test&groupName=DEFAULT_GROUP"
  • 返回示例
{
"code": 0,
"data": {
"pageItems": [
{
"address": "127.0.0.1:0",
"agent": "Nacos-Java-Client:v3.0.0-BETA",
"appName": "unknown",
"groupName": "DEFAULT_GROUP",
"ip": "127.0.0.1",
"namespaceId": "public",
"port": 0,
"serviceName": "test"
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 1
},
"message": "success"
}

3.7. 查询服务详情

接口描述

通过该接口,可以查询指定服务详情。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ns/service

请求参数

参数名类型必填参数描述
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
namespaceIdstring服务所属的namespaceId。
groupNamestring服务所属的groupName。
serviceNamestring服务名。
ephemeralboolean服务的持久化属性,true为临时服务,false为持久化服务。
protectThresholdnumber服务防护阈值。
selectorjsonObject服务选择器。
metadatajsonObject服务元数据。
clusterMapjsonObject服务集群列表, key为cluster的名称,value为集群详细信息。
clusterMap.$ClusterName.clusterNamestring集群名。
clusterMap.$ClusterName.healthCheckerjsonObject健康检查器。
clusterMap.$ClusterName.healthyCheckPortinteger健康检查端口。
clusterMap.$ClusterName.useInstancePortForCheckboolean是否使用所注册的实例的IP:Port进行健康检查。
clusterMap.$ClusterName.metadatajsonObject集群元数据。

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/ns/service?serviceName=test"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"clusterMap": {
"DEFAULT": {
"clusterName": "DEFAULT",
"healthChecker": {
"type": "TCP"
},
"healthyCheckPort": 80,
"hosts": null,
"metadata": {},
"useInstancePortForCheck": true
}
},
"ephemeral": false,
"groupName": "DEFAULT_GROUP",
"metadata": {},
"namespaceId": "public",
"protectThreshold": 0.0,
"selector": {
"contextType": "NONE",
"type": "none"
},
"serviceName": "test"
}
}

3.8. 更新服务集群元数据

接口描述

通过该接口,可以更新指定服务集群的元数据。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ns/service/cluster

请求参数

参数名类型必填参数描述
clusterNamestring集群名。
serviceNamestring服务名。
checkPortstring健康检查端口。
useInstancePort4Checkstring是否使用所注册的实例的IP:Port进行健康检查。
healthCheckerstring健康检查器。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
metadatastring服务元数据。

healthChecker参数为健康检查器的JSON字符串,目前支持三种健康检查器:

  1. None: 无健康检查,{"type":"NONE"}
  2. TCP: TCP端口检查,{"type":"TCP"}
  3. HTTP: HTTP端口检查,{"type":"HTTP","path":"/liveness","headers":"health"}, 其中path为HTTP的uri,headers 为HTTP请求头。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring更新成功时,固定为ok

示例

  • 请求示例
Terminal window
curl -X PUT "http://127.0.0.1:8080/v3/console/ns/service/cluster" -d "serviceName=test&clusterName=DEFAULT&checkPort=80&useInstancePort4Check=true&healthChecker={\"type\":\"none\"}"
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

3.9. 查询服务的实例列表

接口描述

通过该接口,可以查询指定服务的实例列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ns/instance/list

请求参数

参数名类型必填参数描述
pageNointeger页码,起始为1。
pageSizeinteger每页记录数。
serviceNamestring服务名。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
clusterNamestring集群名,不传则查询所有集群的实例。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合条件的实例的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList实例列表。
pageItems[i].instanceIdstring实例ID。
pageItems[i].ipstring实例IP。
pageItems[i].portinteger实例端口。
pageItems[i].weightnumber实例权重。
pageItems[i].healthyboolean实例是否健康。
pageItems[i].enabledboolean实例是否已上线。
pageItems[i].ephemeralboolean实例是否临时。
pageItems[i].clusterNamestring实例所属集群。
pageItems[i].serviceNamestring实例所属服务,格式为groupName@@serviceName
pageItems[i].metadatamap<string, string>实例元数据。

示例

  • 请求示例
Terminal window
curl -X GET "http://127.0.0.1:8080/v3/console/ns/instance/list?&serviceName=test&clusterName=DEFAULT&groupName=DEFAULT_GROUP&pageSize=10&pageNo=1"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"pageItems": [
{
"clusterName": "DEFAULT",
"enabled": true,
"ephemeral": false,
"healthy": false,
"instanceHeartBeatInterval": 5000,
"instanceHeartBeatTimeOut": 15000,
"instanceId": "1.1.1.1#3306#DEFAULT#DEFAULT_GROUP@@test",
"instanceIdGenerator": "simple",
"ip": "1.1.1.1",
"ipDeleteTimeout": 30000,
"metadata": {},
"port": 3306,
"serviceName": "DEFAULT_GROUP@@test",
"weight": 1.0
}
],
"pageNumber": 1,
"pagesAvailable": 1,
"totalCount": 1
}
}

3.10. 更新实例元数据

接口描述

通过该接口,可以更新指定服务的实例元数据,包括权重和上下线状态;无法更新实例的服务名、分组名、命名空间、IP及端口。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ns/instance

请求参数

参数名类型必填参数描述
serviceNamestring服务名。
ipstring实例IP。
portinteger实例端口。
groupNamestring服务所属的groupName,默认值为DEFAULT_GROUP
namespaceIdstring服务所属的命名空间ID,默认值为public
clusterNamestring实例所属集群, 默认值为DEFAULT
ephemeralboolean实例是否临时,默认值为true
weightnumber实例权重。
healthyboolean实例健康状态。
enabledboolean实例是否已上线。
metadatastring实例元数据。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring更新成功时,固定为ok

示例

  • 请求示例
Terminal window
curl -X PUT "http://127.0.0.1:8080/v3/console/ns/instance" -d 'serviceName=test&clusterName=DEFAULT&groupName=DEFAULT_GROUP&ip=1.1.1.1&port=3306&ephemeral=true&weight=100&enabled=false&metadata=%7B%22%E5%95%A6%E5%95%A6%E5%95%A6%26%E5%95%B5%E5%95%B5%E5%95%B5%22%3A%22xxx%22%7D'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

4. MCP 管理

4.1. 查询MCP服务的详情

接口描述

通过该接口,可以查询托管在Nacos上指定MCP服务的服务的详细信息。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/mcp

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID,默认为public
mcpIdstringOne of two requiredMCP service ID (usually UUID). One of mcpId and mcpName must be provided (OpenAPI cannot express this constraint; at least one is required in practice). Prefer mcpId.
mcpNamestringOne of two requiredMCP service name template. One of mcpId and mcpName must be provided; prefer mcpId.
versionstringMCP服务的版本,未传入是返回最新版本

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
idstringMCP服务的ID,一般为UUID。
namestringMCP服务名。
namespaceIdstringMCP服务所属的命名空间ID。
protocolstringMCP的协议,如stdio,sse,streamable,http,dubbo等。
frontProtocolstringMCP的前端暴露协议,一般是提供给协议转换器(如网关)使用,若无转换器,则与protocol相同,如stdio,sse,streamable,http,dubbo等。
descriptionstringMCP服务的描述。
repositorystringMCP服务的存储仓库。
versionDetailVersionDetailMCP服务所查询的版本信息。
localServerConfigMap<String, Object>MCP服务若类型为stdio,存在此信息,记录本地MCP服务的启动信息。
remoteServerConfigRemoteServerConfigMCP服务若类型为非stdio,存在此信息,记录远端服务的信息 。
enabledbooleanMCP服务是否启用。
capabilitiesListMCP服务支持的能力类型,如TOOL,PROMPT,RESOURCE
backendEndpointsListMCP服务若类型为非stdio,存在此信息,记录访问远端服务的具体地址信息。
toolSpecMap<String, Object>MCP服务支持的能力类型包含TOOL时,存在此信息,记录工具的详细配置信息。
allVersionsList<VersionDetail>MCP服务的所有版本详情的列表。

其中VersionDetail结构如下:

参数名参数类型描述
versionstringMCP服务的版本号。
release_datestringMCP服务的版本发布时间。
is_latestbooleanMCP服务的版本是否为最新版本。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/mcp?namespaceId=public&mcpName=test&mcpId=d7a64724-a556-4fe4-82fa-e806d43e00dc'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"id": "",
"name": "test",
"protocol": "stdio",
"frontProtocol": "stdio",
"description": "ceshi",
"repository": null,
"versionDetail": {
"version": "1.0.0",
"release_date": "2025-05-22T06:40:37Z",
"is_latest": true
},
"remoteServerConfig": null,
"localServerConfig": {
"test": {}
},
"enabled": true,
"capabilities": [],
"backendEndpoints": null,
"toolSpec": null,
"allVersions": [
{
"version": "1.0.0",
"release_date": "2025-05-22T06:40:37Z",
"is_latest": true
}
],
"namespaceId": "public"
}
}

4.2. 更新MCP服务

接口描述

通过该接口,可以更新托管在Nacos上的MCP服务。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/mcp

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID,默认为public
latestboolean是否按最新版本更新,如 true
serverSpecificationstringMCP服务的描述详情
toolSpecificationstringMCP服务的工具描述详情
endpointSpecificationstringMCP服务的远端服务地址详情,仅在非stdio协议时生效
overrideExistingbooleanMCP服务更新时是否覆盖原endpointSpecification,默认不覆盖,仅在非stdio协议时生效

其中serverSpecificationtoolSpecificationendpointSpecification参数的详细内容如下:

serverSpecification

参数名参数类型描述
idstringMCP服务的ID,一般为UUID,必须传入,用于定位待更新的MCP服务。
namestringMCP服务名。
protocolstringMCP的协议,如stdio,sse,streamable,http,dubbo等。
frontProtocolstringMCP的前端暴露协议,一般是提供给协议转换器(如网关)使用,若无转换器,则与protocol相同,如stdio,sse,streamable,http,dubbo等。
descriptionstringMCP服务的描述。
repositorystringMCP服务的存储仓库。
versionDetailVersionDetailMCP服务的版本信息。
versionstringMCP服务的简易版本版本信息,主要用于兼容,若已设置versionDetail,则该字段无效。
localServerConfigMap<String, Object>MCP服务若类型为stdio,存在此信息,记录本地MCP服务的启动信息。
remoteServerConfigRemoteServerConfigMCP服务若类型为非stdio,存在此信息,记录远端服务的信息 。
enabledbooleanMCP服务是否启用。
capabilitiesListMCP服务支持的能力类型,如TOOL,PROMPT,RESOURCE

其中VersionDetail结构如下:

参数名参数类型描述
versionstringMCP服务的版本号。
release_datestringMCP服务的版本发布时间。
is_latestbooleanMCP服务的版本是否为最新版本。

toolSpecification

参数名参数类型描述
toolsList<McpTool>该MCP Server所提供的工具列表,参考标准MCP协议中对于MCP Tool的定义
toolsMetaMap<String, McpToolMeta>该MCP Server所提供的工具的额外元数据信息,可用于扩展标准MCP协议中未定义但又使用中需要的信息。key为McpToolname, value为拓展元数据。
securitySchemesList<SecurityScheme>MCP工具的安全方案,参考标准MCP协议。

其中McpTool结构如下:

参数名参数类型描述
namestringMCP 工具的名称
descriptionstringMCP 工具的描述
inputSchemaMap<String, Object>MCP工具的入参描述,参考标准MCP协议,主要包含,类型,是否必须,描述 等。

其中McpToolMeta 结构如下:

参数名参数类型描述
invokeContextmap<string, string>MCP 工具调用时的上下文信息,如后端服务的Path等。
enabledbooleanMCP工具是否启用。
templatesmap<string, string>MCP工具的模板信息。用于进行协议转换时进行参数的映射。

其中SecurityScheme 结构如下:

参数名参数类型描述
idstring安全方案的ID,将被MCP工具使用和引用。。
typestring安全方案的类型。可能的值包括:httpapiKeylocalEnv或其他自定义扩展。
schemestring安全方案的子方案类型。当 typehttp 时使用。可能的值包括:basicbearer
instring安全方案的位置。可能的值有:queryheader
namestring安全方案的名称。当 typeapiKeylocalEnv 时使用。例如,apiKey 的密钥名称或 localEnv 的环境名称。
defaultCredentialstring当配置参数中未输入身份时的默认凭证。可选。

endpointSpecification

参数名参数类型描述
typestringMCP endpoint的后端服务类型,可选值REFDIRECT.
datamap<string, string>MCP endpoint的后端服务的实际数据, 根据type的不同,传入的参数不同,如REF传入的为namespaceId, groupNameserviceNameDIRECT传入的为addressport

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastringMCP服务更新结果。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/mcp' \
-d 'namespaceId=public' \
-d 'mcpName=test' \
-d 'serverSpecification={"protocol":"stdio","frontProtocol":"stdio","name":"test","id":"d7a64724-a556-4fe4-82fa-e806d43e00dc","description":"ceshi","versionDetail":{"version":"1.0.0"},"enabled":true,"localServerConfig":{"test":{}}}'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "ok"
}

4.3. 创建MCP服务

接口描述

通过该接口,可以创建托管在Nacos上的MCP服务,可以是存量API转换的MCP服务,也可以是MCP市场中的MCP服务。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/mcp

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID,默认为public
serverSpecificationstringMCP服务的描述详情
toolSpecificationstringMCP服务的工具描述详情
endpointSpecificationstringMCP服务的远端服务地址详情,仅在非stdio协议时生效

其中serverSpecificationtoolSpecificationendpointSpecification参数的详细内容如下:

serverSpecification

参数名参数类型描述
idstringMCP服务的ID,一般为UUID,无需传入,系统自动生成。
namestringMCP服务名。
protocolstringMCP的协议,如stdio,sse,streamable,http,dubbo等。
frontProtocolstringMCP的前端暴露协议,一般是提供给协议转换器(如网关)使用,若无转换器,则与protocol相同,如stdio,sse,streamable,http,dubbo等。
descriptionstringMCP服务的描述。
repositorystringMCP服务的存储仓库。
versionDetailVersionDetailMCP服务的版本信息。
versionstringMCP服务的简易版本版本信息,主要用于兼容,若已设置versionDetail,则该字段无效。
localServerConfigMap<String, Object>MCP服务若类型为stdio,存在此信息,记录本地MCP服务的启动信息。
remoteServerConfigRemoteServerConfigMCP服务若类型为非stdio,存在此信息,记录远端服务的信息 。
enabledbooleanMCP服务是否启用。
capabilitiesListMCP服务支持的能力类型,如TOOL,PROMPT,RESOURCE

其中VersionDetail结构如下:

参数名参数类型描述
versionstringMCP服务的版本号。
release_datestringMCP服务的版本发布时间。
is_latestbooleanMCP服务的版本是否为最新版本。

toolSpecification

参数名参数类型描述
toolsList<McpTool>该MCP Server所提供的工具列表,参考标准MCP协议中对于MCP Tool的定义
toolsMetaMap<String, McpToolMeta>该MCP Server所提供的工具的额外元数据信息,可用于扩展标准MCP协议中未定义但又使用中需要的信息。key为McpToolname, value为拓展元数据。
securitySchemesList<SecurityScheme>MCP工具的安全方案,参考标准MCP协议。

其中McpTool结构如下:

参数名参数类型描述
namestringMCP 工具的名称
descriptionstringMCP 工具的描述
inputSchemaMap<String, Object>MCP工具的入参描述,参考标准MCP协议,主要包含,类型,是否必须,描述 等。

其中McpToolMeta 结构如下:

参数名参数类型描述
invokeContextmap<string, string>MCP 工具调用时的上下文信息,如后端服务的Path等。
enabledbooleanMCP工具是否启用。
templatesmap<string, string>MCP工具的模板信息。用于进行协议转换时进行参数的映射。

其中SecurityScheme 结构如下:

参数名参数类型描述
idstring安全方案的ID,将被MCP工具使用和引用。。
typestring安全方案的类型。可能的值包括:httpapiKeylocalEnv或其他自定义扩展。
schemestring安全方案的子方案类型。当 typehttp 时使用。可能的值包括:basicbearer
instring安全方案的位置。可能的值有:queryheader
namestring安全方案的名称。当 typeapiKeylocalEnv 时使用。例如,apiKey 的密钥名称或 localEnv 的环境名称。
defaultCredentialstring当配置参数中未输入身份时的默认凭证。可选。

endpointSpecification

参数名参数类型描述
typestringMCP endpoint的后端服务类型,可选值REFDIRECT.
datamap<string, string>MCP endpoint的后端服务的实际数据, 根据type的不同,传入的参数不同,如REF传入的为namespaceId, groupNameserviceNameDIRECT传入的为addressport

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastring新建MCP服务的id。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/mcp' \
-d 'namespaceId=public' \
-d 'mcpName=test' \
-d 'serverSpecification={"protocol":"stdio","frontProtocol":"stdio","name":"test","id":"","description":"ceshi","versionDetail":{"version":"1.0.0"},"enabled":true,"localServerConfig":{"test":{}}}'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "58e5b430-b16d-4f28-9334-edb64303dc23"
}

4.4. 删除MCP服务

接口描述

通过该接口,可以删除托管在Nacos上的MCP服务。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/mcp

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID,默认为public
mcpIdstringOne of two requiredMCP service ID (usually UUID). One of mcpId and mcpName must be provided (OpenAPI cannot express this constraint; at least one is required in practice). Prefer mcpId.
mcpNamestringOne of two requiredMCP service name template. One of mcpId and mcpName must be provided; prefer mcpId.
versionstringMCP服务的版本,未传入是为最新版本

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastringMCP服务删除结果。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/mcp?namespaceId=public&mcpName=test&mcpId=d7a64724-a556-4fe4-82fa-e806d43e00dc'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "ok"
}

4.5. 查询MCP服务的服务列表

接口描述

通过该接口,可以查询托管在Nacos上的MCP服务的服务列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/mcp/list

请求参数

参数名参数类型是否必填描述
pageNointeger当前页,默认为1
pageSizeinteger页条目数,默认为20,最大为500
namespaceIdstringMCP服务的命名空间ID,默认为public
mcpNamestringMCP服务的名字模版,为空时查询所有MCP服务,当searchblur时,可使用*进行模糊搜索
searchstring搜索的类型,可选之bluraccurate,默认为blur

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合条件的服务的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList服务列表。
pageItems[i].idstringMCP服务的ID,一般为UUID。
pageItems[i].namestringMCP服务名。
pageItems[i].protocolstringMCP的协议,如stdio,sse,streamable,http,dubbo等。
pageItems[i].frontProtocolstringMCP的前端暴露协议,一般是提供给协议转换器(如网关)使用,若无转换器,则与protocol相同,如stdio,sse,streamable,http,dubbo等。
pageItems[i].descriptionstringMCP服务的描述。
pageItems[i].repositorystringMCP服务的存储仓库。
pageItems[i].versionDetailVersionDetailMCP服务当前最新的版本信息。
pageItems[i].localServerConfigMap<String, Object>MCP服务若类型为stdio,存在此信息,记录本地MCP服务的启动信息。
pageItems[i].remoteServerConfigRemoteServerConfigMCP服务若类型为非stdio,存在此信息,记录远端服务的信息 。
pageItems[i].latestPublishedVersionstringMCP服务最新版本的版本号。
pageItems[i].versionDetailsList<VersionDetail>MCP服务版本详情的列表。
pageItems[i].capabilitiesListMCP服务支持的能力类型,如TOOL,PROMPT,RESOURCE

其中VersionDetail结构如下:

参数名参数类型描述
versionstringMCP服务的版本号。
release_datestringMCP服务的版本发布时间。
is_latestbooleanMCP服务的版本是否为最新版本。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/mcp/list?pageNo=1&pageSize=100&namespaceId=public&search=blur'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"totalCount": 1,
"pageNumber": 1,
"pagesAvailable": 1,
"pageItems": [
{
"id": "d7a64724-a556-4fe4-82fa-e806d43e00dc",
"name": "test",
"protocol": "stdio",
"frontProtocol": "stdio",
"description": "ceshi",
"repository": null,
"versionDetail": {
"version": "1.0.0",
"release_date": "2025-05-22T06:40:37Z",
"is_latest": null
},
"remoteServerConfig": null,
"localServerConfig": null,
"enabled": true,
"capabilities": null,
"latestPublishedVersion": "1.0.0",
"versionDetails": [
{
"version": "1.0.0",
"release_date": "2025-05-22T06:40:37Z",
"is_latest": null
}
]
}
]
}
}

4.6. 导入MCP工具

接口描述

通过该接口,可以通过指定MCPURL的方式直接获取MCP工具并导入,避免逐个填写。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/mcp/importToolsFromMcp

请求参数

参数名参数类型是否必填描述
transportTypestringMCP服务的传输协议类型,mcp-ssemcp-streamable
baseUrlstringMCP服务的baseURL
endpointstringMCP服务的可访问端点
authTokenstringMCP服务访问的身份Token

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
dataList<McpSchema.Tool>MCP工具元数据信息,符合MCP工具元数据标准定义

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/mcp/importToolsFromMcp?transportType=mcp-sse&baseUrl=%2Fsse&endpoint=http%3A%2F%2Flocalhost'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : [ {
"name" : "getNacosInformation",
"description" : "Get nacos detail information by nacos cluster name, the information includes nacos hosts and accessToken, accessToken is optional.",
"inputSchema" : {
"type" : "object",
"properties" : {
"arg0" : {
"type" : "string",
"description" : "nacos cluster name"
}
},
"required" : [ "arg0" ],
"additionalProperties" : false
}
} ]
}

4.7. 验证待导入的MCP服务

接口描述

通过该接口,可以验证当前待导入的MCP服务内容是否符合规则,返回的内容中包含有效个数和无效个数,无效的服务在对应字段中有错误信息。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/mcp/import/validate

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID
importTypestring导入的类型,可选值有file,jsonurl
datastring导入数据的内容
cursorstring分页的起始索引
limitinteger分页的页大小
searchstring导入列表的可选模糊搜索关键字。仅当 importType 为url时使用。

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
validboolean导入服务是否合法。
totalCountinteger导入服务总数。
validCountinteger导入服务有效个数。
invalidCountinteger导入服务无效个数。
duplicateCountinteger导入服务重复个数。
serversList<McpServerValidationItem>导入服务列表。
errorsList<String>导入服务错误列表。

其中McpServerValidationItem描述如下:

参数名参数类型描述
serverNamestring服务名称。
serverIdstring服务ID。
statusstring服务状态。
selectedboolean服务是否被选中。
existsboolean服务是否已存在。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/mcp/import/validate' \
-d 'namespaceId=public' \
-d 'importType=url' \
-d 'data=' \
-d 'limit=10'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : {
"valid" : true,
"totalCount" : 3,
"validCount" : 3,
"invalidCount" : 0,
"duplicateCount" : 0,
"servers" : [ {
"serverName" : "server1",
"serverId" : "id1",
"status" : "valid",
"selected" : true,
"exists" : false
}, {
"serverName" : "server2",
"serverId" : "id2",
"status" : "valid",
"selected" : false,
"exists" : false
} ],
"errors" : [ ]
}
}

4.8. 导入的MCP服务

接口描述

通过该接口,可以通过文件,JSON和指定MCPURL的方式直接导入MCP服务,避免逐个填写。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/mcp/import/execute

请求参数

参数名参数类型是否必填描述
namespaceIdstringMCP服务的命名空间ID
importTypestring导入的类型,可选值有file,jsonurl
datastring导入数据的内容
cursorstring分页的起始索引
limitinteger分页的页大小
searchstring导入列表的可选模糊搜索关键字。仅当 importType 为url时使用。
overrideExistingboolean导入时若服务已存在时是否覆盖。默认为false
skipInvalidboolean导入时是否忽略错误无效的服务。默认为false
selectedServersstring选择部分服务进行导入,为空时导入所有

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
successboolean导入服务是否成功。
totalCountinteger导入服务总数。
successCountinteger导入服务成功个数。
failedCountinteger导入服务失败个数。
skippedCountinteger导入服务跳过个数。
resultsList<McpServerImportResult>导入服务列表。

其中McpServerImportResult描述如下:

参数名参数类型描述
serverNamestring服务名称。
serverIdstring服务ID。
statusstring服务导入状态。
errorMessageboolean服务导入失败的错误信息,仅在导入失败时存在。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/mcp/import/execute' \
-d 'namespaceId=public' \
-d 'importType=url' \
-d 'data=' \
-d 'overrideExisting=false' \
-d 'skipInvalid=false' \
-d 'selectedServers=[]' \
-d 'limit=10'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : {
"success" : true,
"totalCount" : 5,
"successCount" : 4,
"failedCount" : 1,
"skippedCount" : 0,
"results" : [ {
"serverName" : "server1",
"serverId" : "id1",
"status" : "success"
}, {
"serverName" : "server2",
"status" : "failed",
"errorMessage" : "Connection failed"
} ]
}
}

5. A2A 注册中心

5.1. 查询AgentCard的列表

接口描述

通过该接口,可以查询托管在Nacos上的AgentCard的列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/a2a/list

请求参数

参数名参数类型是否必填描述
pageNointeger当前页,默认为1
pageSizeinteger页条目数,默认为100
namespaceIdstringAgentCard的命名空间ID,默认为public
agentNamestringAgentCard的名称,为空是查询所有AgentCard
searchstringAgentCard名称的匹配模式,可选之bluraccurate,默认为blur

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
totalCountinteger符合条件的服务的总数。
pageNumberinteger当前页码,起始为1
pagesAvailableinteger可用页码。
pageItemsList服务列表。
pageItems[i].protocolVersionstringAgentCard的A2A协议版本。
pageItems[i].namestringAgentCard的名称。
pageItems[i].descriptionstringAgentCard的描述。
pageItems[i].versionstringAgentCard的版本号。
pageItems[i].iconUrlstringAgentCard的iconURL。
pageItems[i].capabilitiesAgentCapabilityAgentCard的能力,匹配A2A标准能力
pageItems[i].skillsList<AgentSkill>AgentCard的技能列表,匹配A2A标准技能
pageItems[i].latestPublishedVersionstringAgentCard的最新发布版本。
pageItems[i].versionDetailsList<AgentVersionDetail>AgentCard的所有版本详情。
pageItems[i].registrationTypestringAgentCard的默认注册类型,可选URLSERVICE

其中AgentVersionDetail包含内容如下:

参数名参数类型描述
versionstringAgentCard的版本号。
createdAtstring该版本的创建时间。
updatedAtstring该版本的最后更新时间。
latestboolean该版本是否标记为最新发布版本。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/a2a/list?pageNo=1&pageSize=100&namespaceId=public&search=blur'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : {
"totalCount" : 1,
"pageNumber" : 1,
"pagesAvailable" : 1,
"pageItems" : [ {
"protocolVersion" : "0.2.9",
"name" : "GeoSpatial Route Planner Agent",
"description" : "Provides advanced route planning, traffic analysis, and custom map generation services. This agent can calculate optimal routes, estimate travel times considering real-time traffic, and create personalized maps with points of interest.",
"version" : "1.2.0",
"iconUrl" : "https://georoute-agent.example.com/icon.png",
"capabilities" : {
"streaming" : true,
"pushNotifications" : true,
"stateTransitionHistory" : false,
"extensions" : null
},
"skills" : [ {
"id" : "route-optimizer-traffic",
"name" : "Traffic-Aware Route Optimizer",
"description" : "Calculates the optimal driving route between two or more locations, taking into account real-time traffic conditions, road closures, and user preferences (e.g., avoid tolls, prefer highways).",
"tags" : [ "maps", "routing", "navigation", "directions", "traffic" ],
"examples" : [ "Plan a route from '1600 Amphitheatre Parkway, Mountain View, CA' to 'San Francisco International Airport' avoiding tolls.", "{\"origin\": {\"lat\": 37.422, \"lng\": -122.084}, \"destination\": {\"lat\": 37.7749, \"lng\": -122.4194}, \"preferences\": [\"avoid_ferries\"]}" ],
"inputModes" : [ "application/json", "text/plain" ],
"outputModes" : [ "application/json", "application/vnd.geo+json", "text/html" ]
}, {
"id" : "custom-map-generator",
"name" : "Personalized Map Generator",
"description" : "Creates custom map images or interactive map views based on user-defined points of interest, routes, and style preferences. Can overlay data layers.",
"tags" : [ "maps", "customization", "visualization", "cartography" ],
"examples" : [ "Generate a map of my upcoming road trip with all planned stops highlighted.", "Show me a map visualizing all coffee shops within a 1-mile radius of my current location." ],
"inputModes" : [ "application/json" ],
"outputModes" : [ "image/png", "image/jpeg", "application/json", "text/html" ]
} ],
"latestPublishedVersion" : "1.2.0",
"versionDetails" : [ {
"version" : "1.2.0",
"createdAt" : "2025-09-12T03:33:51Z",
"updatedAt" : "2025-09-12T07:21:49Z",
"latest" : true
} ],
"registrationType" : "URL"
} ]
}
}

5.2. 查询指定AgentCard的版本列表

接口描述

通过该接口,可以查询指定托管在Nacos上的AgentCard的版本列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/a2a/version/list

请求参数

参数名参数类型是否必填描述
namespaceIdstringAgentCard所属的命名空间,默认public
agentNamestringAgentCard的名称

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
data[i].versionstringAgentCard的版本号。
data[i].createdAtstring该版本的创建时间。
data[i].updatedAtstring该版本的最后更新时间。
data[i].latestboolean该版本是否标记为最新发布版本。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/a2a/version/list?namespaceId=public&agentName=GeoSpatial+Route+Planner+Agent'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : [ {
"version" : "1.2.0",
"createdAt" : "2025-09-12T03:33:51Z",
"updatedAt" : "2025-09-12T07:21:49Z",
"latest" : true
} ]
}

5.3. 查询AgentCard的详情

接口描述

通过该接口,可以查询托管在Nacos上指定AgentCard的详细信息。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/a2a

请求参数

参数名参数类型是否必填描述
namespaceIdstringAgentCard所属的命名空间,默认public
agentNamestringAgentCard的名称
versionstringAgentCard的版本号,为空时返回最新版本详情
registrationTypestringAgentCard的默认注册类型,可选URLSERVICE。未填写时根据此AgentCard的默认registrationType进行url的生成

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
protocolVersionstringAgentCard的A2A协议版本。
namestringAgentCard的名称。
descriptionstringAgentCard的描述。
versionstringAgentCard的版本号。
iconUrlstringAgentCard的iconURL。
capabilitiesAgentCapabilityAgentCard的能力,匹配A2A标准能力
skillsList<AgentSkill>AgentCard的技能列表,匹配A2A标准技能
urlstringAgentCard的默认访问的URL。
preferredTransportstringAgentCard的默认访问URL的传输协议,应该为JSONRPC,GRPC,HTTP+JSON
additionalInterfacesList<AgentInterface>AgentCard的所有可访问接口列表,匹配A2A标准
providerAgentProviderAgentCard的提供商信息,匹配A2A标准
documentationUrlstringAgentCard的文档 URL。
securitySchemesMap<String, SecurityScheme>AgentCard的安全配置定义。匹配A2A标准
securityList<Map<String, List<String>>>AgentCard的所有安全要求对象列表。
defaultInputModesList<String>AgentCard的所有默认输入模式。
defaultOutputModesList<String>AgentCard的所有默认输出模式。
supportsAuthenticatedExtendedCardstringAgentCard是否支持认证的扩展卡。
registrationTypestringAgentCard的默认注册类型,可选URLSERVICE
latestVersionstringAgentCard当前版本时否为最新版本。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/a2a?namespaceId=public&agentName=GeoSpatial+Route+Planner+Agent&version=1.0.0&registrationType=SERVICE'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : {
"protocolVersion" : "0.2.9",
"name" : "GeoSpatial Route Planner Agent",
"description" : "Provides advanced route planning, traffic analysis, and custom map generation services. This agent can calculate optimal routes, estimate travel times considering real-time traffic, and create personalized maps with points of interest.",
"version" : "1.2.0",
"iconUrl" : "https://georoute-agent.example.com/icon.png",
"capabilities" : {
"streaming" : true,
"pushNotifications" : true,
"stateTransitionHistory" : false,
"extensions" : null
},
"skills" : [ {
"id" : "route-optimizer-traffic",
"name" : "Traffic-Aware Route Optimizer",
"description" : "Calculates the optimal driving route between two or more locations, taking into account real-time traffic conditions, road closures, and user preferences (e.g., avoid tolls, prefer highways).",
"tags" : [ "maps", "routing", "navigation", "directions", "traffic" ],
"examples" : [ "Plan a route from '1600 Amphitheatre Parkway, Mountain View, CA' to 'San Francisco International Airport' avoiding tolls.", "{\"origin\": {\"lat\": 37.422, \"lng\": -122.084}, \"destination\": {\"lat\": 37.7749, \"lng\": -122.4194}, \"preferences\": [\"avoid_ferries\"]}" ],
"inputModes" : [ "application/json", "text/plain" ],
"outputModes" : [ "application/json", "application/vnd.geo+json", "text/html" ]
}, {
"id" : "custom-map-generator",
"name" : "Personalized Map Generator",
"description" : "Creates custom map images or interactive map views based on user-defined points of interest, routes, and style preferences. Can overlay data layers.",
"tags" : [ "maps", "customization", "visualization", "cartography" ],
"examples" : [ "Generate a map of my upcoming road trip with all planned stops highlighted.", "Show me a map visualizing all coffee shops within a 1-mile radius of my current location." ],
"inputModes" : [ "application/json" ],
"outputModes" : [ "image/png", "image/jpeg", "application/json", "text/html" ]
} ],
"url" : "https://georoute-agent.example.com/a2a/v1",
"preferredTransport" : "JSONRPC",
"additionalInterfaces" : [ {
"url" : "https://georoute-agent.example.com/a2a/v1",
"transport" : "JSONRPC"
}, {
"url" : "https://georoute-agent.example.com/a2a/grpc",
"transport" : "GRPC"
}, {
"url" : "https://georoute-agent.example.com/a2a/json",
"transport" : "HTTP+JSON"
} ],
"provider" : {
"organization" : "Example Geo Services Inc.",
"url" : "https://www.examplegeoservices.com"
},
"documentationUrl" : "https://docs.examplegeoservices.com/georoute-agent/api",
"securitySchemes" : {
"google" : {
"type" : "openIdConnect",
"openIdConnectUrl" : "https://accounts.google.com/.well-known/openid-configuration"
}
},
"security" : [ {
"google" : [ "openid", "profile", "email" ]
} ],
"defaultInputModes" : [ "application/json", "text/plain" ],
"defaultOutputModes" : [ "application/json", "image/png" ],
"supportsAuthenticatedExtendedCard" : true,
"registrationType" : "URL",
"latestVersion" : true
}
}

5.4. 更新AgentCard

接口描述

通过该接口,可以更新托管在Nacos上的AgentCard。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/a2a

请求参数

参数名参数类型是否必填描述
namespaceIdstringAgentCard所属的命名空间,默认public
agentCardstringAgentCard的完整对象,详情请参考标准AgentCard
registrationTypestringAgentCard的默认注册类型,可选URLSERVICE。未填写时根据此AgentCard的默认registrationType进行url的生成
setAsLatestboolean是否设置此版本为最新发布版本,默认为false

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastringAgentCard服务更新结果。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/a2a' \
-d 'namespaceId=public' \
-d 'agentCard={"protocolVersion":"0.2.9","name":"GeoSpatial Route Planner Agent","description":"Provides advanced route planning, traffic analysis, and custom map generation services. This agent can calculate optimal routes, estimate travel times considering real-time traffic, and create personalized maps with points of interest.","url":"https://georoute-agent.example.com/a2a/v1","preferredTransport":"JSONRPC","additionalInterfaces":[{"url":"https://georoute-agent.example.com/a2a/v1","transport":"JSONRPC"},{"url":"https://georoute-agent.example.com/a2a/grpc","transport":"GRPC"},{"url":"https://georoute-agent.example.com/a2a/json","transport":"HTTP+JSON"}],"provider":{"organization":"Example Geo Services Inc.","url":"https://www.examplegeoservices.com"},"iconUrl":"https://georoute-agent.example.com/icon.png","version":"1.2.0","documentationUrl":"https://docs.examplegeoservices.com/georoute-agent/api","capabilities":{"streaming":true,"pushNotifications":true,"stateTransitionHistory":false},"securitySchemes":{"google":{"type":"openIdConnect","openIdConnectUrl":"https://accounts.google.com/.well-known/openid-configuration"}},"security":[{"google":["openid","profile","email"]}],"defaultInputModes":["application/json","text/plain"],"defaultOutputModes":["application/json","image/png"],"skills":[{"id":"route-optimizer-traffic","name":"Traffic-Aware Route Optimizer","description":"Calculates the optimal driving route between two or more locations, taking into account real-time traffic conditions, road closures, and user preferences (e.g., avoid tolls, prefer highways).","tags":["maps","routing","navigation","directions","traffic"],"examples":["Plan a route from '1600 Amphitheatre Parkway, Mountain View, CA' to 'San Francisco International Airport' avoiding tolls.","{\"origin\": {\"lat\": 37.422, \"lng\": -122.084}, \"destination\": {\"lat\": 37.7749, \"lng\": -122.4194}, \"preferences\": [\"avoid_ferries\"]}"],"inputModes":["application/json","text/plain"],"outputModes":["application/json","application/vnd.geo+json","text/html"]},{"id":"custom-map-generator","name":"Personalized Map Generator","description":"Creates custom map images or interactive map views based on user-defined points of interest, routes, and style preferences. Can overlay data layers.","tags":["maps","customization","visualization","cartography"],"examples":["Generate a map of my upcoming road trip with all planned stops highlighted.","Show me a map visualizing all coffee shops within a 1-mile radius of my current location."],"inputModes":["application/json"],"outputModes":["image/png","image/jpeg","application/json","text/html"]}],"supportsAuthenticatedExtendedCard":true,"signatures":[{"protected":"eyJhbGciOiJFUzI1NiIsInR5cCI6IkpPU0UiLCJraWQiOiJrZXktMSIsImprdSI6Imh0dHBzOi8vZXhhbXBsZS5jb20vYWdlbnQvandrcy5qc29uIn0","signature":"QFdkNLNszlGj3z3u0YQGt_T9LixY3qtdQpZmsTdDHDe3fXV9y9-B3m2-XgCpzuhiLt8E0tV6HXoZKHv4GtHgKQ"}]}' \
-d 'registrationType=SERVICE' \
-d 'setAsLatest=true'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "ok"
}

5.5. 创建AgentCard

接口描述

通过该接口,可以创建托管在Nacos上的AgentCard。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/a2a

请求参数

参数名参数类型是否必填描述
namespaceIdstringAgentCard所属的命名空间,默认public
agentCardstringAgentCard的完整对象,详情请参考标准AgentCard
registrationTypestringAgentCard的默认注册类型,可选URLSERVICE。未填写时根据此AgentCard的默认registrationType进行url的生成, 默认值为URL

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastringAgentCard发布结果。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/a2a' \
-d 'namespaceId=public' \
-d 'agentCard={"protocolVersion":"0.2.9","name":"GeoSpatial Route Planner Agent","description":"Provides advanced route planning, traffic analysis, and custom map generation services. This agent can calculate optimal routes, estimate travel times considering real-time traffic, and create personalized maps with points of interest.","url":"https://georoute-agent.example.com/a2a/v1","preferredTransport":"JSONRPC","additionalInterfaces":[{"url":"https://georoute-agent.example.com/a2a/v1","transport":"JSONRPC"},{"url":"https://georoute-agent.example.com/a2a/grpc","transport":"GRPC"},{"url":"https://georoute-agent.example.com/a2a/json","transport":"HTTP+JSON"}],"provider":{"organization":"Example Geo Services Inc.","url":"https://www.examplegeoservices.com"},"iconUrl":"https://georoute-agent.example.com/icon.png","version":"1.2.0","documentationUrl":"https://docs.examplegeoservices.com/georoute-agent/api","capabilities":{"streaming":true,"pushNotifications":true,"stateTransitionHistory":false},"securitySchemes":{"google":{"type":"openIdConnect","openIdConnectUrl":"https://accounts.google.com/.well-known/openid-configuration"}},"security":[{"google":["openid","profile","email"]}],"defaultInputModes":["application/json","text/plain"],"defaultOutputModes":["application/json","image/png"],"skills":[{"id":"route-optimizer-traffic","name":"Traffic-Aware Route Optimizer","description":"Calculates the optimal driving route between two or more locations, taking into account real-time traffic conditions, road closures, and user preferences (e.g., avoid tolls, prefer highways).","tags":["maps","routing","navigation","directions","traffic"],"examples":["Plan a route from '1600 Amphitheatre Parkway, Mountain View, CA' to 'San Francisco International Airport' avoiding tolls.","{\"origin\": {\"lat\": 37.422, \"lng\": -122.084}, \"destination\": {\"lat\": 37.7749, \"lng\": -122.4194}, \"preferences\": [\"avoid_ferries\"]}"],"inputModes":["application/json","text/plain"],"outputModes":["application/json","application/vnd.geo+json","text/html"]},{"id":"custom-map-generator","name":"Personalized Map Generator","description":"Creates custom map images or interactive map views based on user-defined points of interest, routes, and style preferences. Can overlay data layers.","tags":["maps","customization","visualization","cartography"],"examples":["Generate a map of my upcoming road trip with all planned stops highlighted.","Show me a map visualizing all coffee shops within a 1-mile radius of my current location."],"inputModes":["application/json"],"outputModes":["image/png","image/jpeg","application/json","text/html"]}],"supportsAuthenticatedExtendedCard":true,"signatures":[{"protected":"eyJhbGciOiJFUzI1NiIsInR5cCI6IkpPU0UiLCJraWQiOiJrZXktMSIsImprdSI6Imh0dHBzOi8vZXhhbXBsZS5jb20vYWdlbnQvandrcy5qc29uIn0","signature":"QFdkNLNszlGj3z3u0YQGt_T9LixY3qtdQpZmsTdDHDe3fXV9y9-B3m2-XgCpzuhiLt8E0tV6HXoZKHv4GtHgKQ"}]}' \
-d 'registrationType=SERVICE'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "ok"
}

5.6. 删除AgentCard

接口描述

通过该接口,可以删除托管在Nacos上的AgentCard。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/a2a

请求参数

参数名参数类型是否必填描述
namespaceIdstringAgentCard所属的命名空间,默认public
agentNamestringAgentCard的名称
versionstringAgentCard的版本号,为空时返回最新版本详情

返回数据

返回体遵循Nacos open API 统一返回体格式,下表只阐述data字段中的返回参数。

参数名参数类型描述
datastringAgentCard删除结果。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/a2a?namespaceId=public&agentName=GeoSpatial+Route+Planner+Agent&version=1.0.0'
  • 返回示例
{
"code" : 0,
"message" : "success",
"data" : "ok"
}

6. Prompt 管理

Prompt 管理 API 提供 Prompt 的发布、查询、标签绑定与版本管理能力。

6.1. 发布Prompt

接口描述

通过该接口,可以发布新版本的Prompt。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/prompt

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键/标识。
versionstring版本号,如 1.0.0
templatestringPrompt 模板正文内容。
commitMsgstring本次发布的提交说明。
descriptionstringPrompt 的描述信息。
bizTagsstring业务标签,用于分类检索,多个标签可逗号分隔。

返回数据

参数名参数类型描述
databoolean是否发布成功。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/prompt' \
-d 'namespaceId=public' \
-d 'promptKey=my-prompt' \
-d 'version=1.0.0' \
-d 'template=' \
-d 'commitMsg=' \
-d 'description=' \
-d 'bizTags='
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

6.2. 删除Prompt

接口描述

通过该接口,可以删除指定Prompt。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/prompt

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystring要删除的 Prompt 的唯一键。

返回数据

参数名参数类型描述
databoolean是否删除成功。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/prompt?namespaceId=public&promptKey=my-prompt'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

6.3. 查询Prompt详情

接口描述

通过该接口,可按标签/版本/最新优先查询Prompt详情。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/prompt/detail

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。
versionstring指定版本号;不传时与 labelmd5 一起决定返回版本(标签或最新等)。
labelstring标签名,如 stablelatest,返回该标签指向的版本。
md5string内容 MD5,用于精确匹配某一版本。

返回数据

参数名参数类型描述
data.promptKeystringPrompt 唯一键。
data.versionstring版本号。
data.commitMsgstring该版本的提交说明。
data.srcUserstring发布该版本的用户。
data.gmtModifiedinteger最后修改时间戳。
data.templatestringPrompt 模板正文。
data.md5string内容 MD5。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/prompt/detail?namespaceId=public&promptKey=my-prompt&version=1.0.0&label=&md5='
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"version": "1.0.0",
"template": "",
"commitMsg": ""
}
}

6.4. 绑定标签

接口描述

通过该接口,可将标签绑定到指定Prompt版本。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/prompt/label

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。
labelstring标签名,如 stablelatest
versionstring要绑定到的版本号。

返回数据

参数名参数类型描述
databoolean是否绑定成功。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/prompt/label' \
-d 'namespaceId=public' \
-d 'promptKey=my-prompt' \
-d 'label=stable' \
-d 'version=1.0.0'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

6.5. 解绑标签

接口描述

通过该接口,可解绑Prompt的标签。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/prompt/label

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。
labelstring要解绑的标签名。

返回数据

参数名参数类型描述
databoolean是否解绑成功。

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/prompt/label?namespaceId=public&promptKey=my-prompt&label=stable'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

6.6. 查询Prompt列表

接口描述

通过该接口,可以分页查询Prompt列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/prompt/list

请求参数

参数名类型必填参数描述
pageNointeger页码,从 1 开始。
pageSizeinteger每页条数。
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystring按 Prompt 键过滤,支持模糊或精确(由 search 决定)。
searchstring搜索模式:blur 模糊匹配,accurate 精确匹配。
bizTagsstring按业务标签过滤。

返回数据

参数名参数类型描述
totalCountinteger总条数。
pageNumberinteger当前页码。
pagesAvailableinteger总页数。
pageItemsList当前页的 Prompt 摘要列表。
pageItems[i].schemaVersioninteger元数据 schema 版本。
pageItems[i].promptKeystringPrompt 唯一键。
pageItems[i].descriptionstring描述。
pageItems[i].bizTagsarray业务标签。
pageItems[i].latestVersionstring最新版本号。
pageItems[i].gmtModifiedinteger最后修改时间戳。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/prompt/list?pageNo=1&pageSize=10&namespaceId=public&promptKey=&search=blur&bizTags='
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"totalCount": 1,
"pageNumber": 1,
"pagesAvailable": 1,
"pageItems": [
{
"promptKey": "my-prompt",
"description": ""
}
]
}
}

6.7. 查询Prompt元数据

接口描述

通过该接口,可以查询指定Prompt的元数据信息。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/prompt/metadata

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。

返回数据

参数名参数类型描述
data.schemaVersioninteger元数据 schema 版本。
data.promptKeystringPrompt 唯一键。
data.descriptionstring描述。
data.bizTagsarray业务标签。
data.latestVersionstring最新版本号。
data.gmtModifiedinteger最后修改时间戳。
data.versionsarray版本列表摘要。
data.labelsobject标签与版本号的映射。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/prompt/metadata?namespaceId=public&promptKey=my-prompt'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"promptKey": "my-prompt",
"description": "",
"bizTags": ""
}
}

6.8. 更新Prompt元数据

接口描述

通过该接口,可更新Prompt的元数据(如描述、业务标签)。

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/prompt/metadata

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。
descriptionstring更新后的描述。
bizTagsstring更新后的业务标签。

返回数据

参数名参数类型描述
databoolean是否更新成功。

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/prompt/metadata' \
-d 'namespaceId=public' \
-d 'promptKey=my-prompt' \
-d 'description=' \
-d 'bizTags='
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

6.9. 查询Prompt版本列表

接口描述

通过该接口,可以分页查询指定Prompt的版本列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/prompt/versions

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
promptKeystringPrompt 的唯一键。
pageNointeger页码,从 1 开始。
pageSizeinteger每页条数。

返回数据

参数名参数类型描述
totalCountinteger总条数。
pageNumberinteger当前页码。
pagesAvailableinteger总页数。
pageItemsList当前页的版本列表。
pageItems[i].promptKeystringPrompt 唯一键。
pageItems[i].versionstring版本号。
pageItems[i].commitMsgstring该版本的提交说明。
pageItems[i].srcUserstring发布该版本的用户。
pageItems[i].gmtModifiedinteger最后修改时间戳。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/prompt/versions?namespaceId=public&promptKey=my-prompt&pageNo=1&pageSize=10'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"totalCount": 1,
"pageNumber": 1,
"pagesAvailable": 1,
"pageItems": [
{
"version": "1.0.0",
"commitMsg": ""
}
]
}
}

7. Skills 管理

Skills 管理 API 提供 Skill 的注册、查询、更新、删除及列表、ZIP 上传能力。

7.1. 查询Skill详情

接口描述

通过该接口,可以查询托管在Nacos上指定Skill的详细信息。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/skills

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
skillNamestringSkill 名称/唯一标识。
versionstring版本号;不传则返回最新版本。

返回数据

参数名参数类型描述
data.namespaceIdstring所属命名空间 ID。
data.namestringSkill 名称。
data.descriptionstringSkill 描述。
data.instructionstringSkill 使用说明/指令。
data.resourceobjectSkill 关联资源信息。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/skills?namespaceId=public&skillName=my-skill&version=1.0.0'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"name": "my-skill",
"description": "",
"instruction": "",
"resource": {},
"versionDetail": {
"version": "1.0.0"
}
}
}

7.2. 删除Skill

接口描述

通过该接口,可以删除托管在Nacos上的Skill。

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills

请求参数

参数名类型必填参数描述
namespaceIdstring命名空间 ID,不传默认为 public
skillNamestring要删除的 Skill 名称。
versionstring版本号;不传则删除该 Skill 下所有版本(或按实现语义)。

返回数据

参数名参数类型描述
datastring操作结果,成功时为 ok

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/skills?namespaceId=public&skillName=my-skill&version=1.0.0'
  • 返回示例
{
"code": 0,
"message": "success",
"data": "ok"
}

7.3. 查询Skill列表

接口描述

通过该接口,可以查询托管在Nacos上的Skill列表。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/skills/list

请求参数

参数名类型必填参数描述
pageNointeger页码,从 1 开始。
pageSizeinteger每页条数。
namespaceIdstring命名空间 ID,不传默认为 public
skillNamestring按 Skill 名称过滤,支持模糊或精确(由 search 决定)。
searchstring搜索模式:blur 模糊匹配,accurate 精确匹配。

返回数据

参数名参数类型描述
totalCountinteger总条数。
pageNumberinteger当前页码。
pagesAvailableinteger总页数。
pageItemsList当前页的 Skill 摘要列表。
pageItems[i].namespaceIdstring所属命名空间 ID。
pageItems[i].namestringSkill 名称。
pageItems[i].descriptionstring描述。
pageItems[i].updateTimeinteger最后更新时间戳。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/skills/list?pageNo=1&pageSize=100&namespaceId=public&skillName=&search=blur'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"totalCount": 1,
"pageNumber": 1,
"pagesAvailable": 1,
"pageItems": [
{
"name": "my-skill",
"description": "",
"versionDetail": {
"version": "1.0.0"
}
}
]
}
}

7.4. 上传Skill(ZIP)

接口描述

通过该接口,可通过ZIP文件上传Skill。

请求方式

POST

请求体类型:multipart/form-data

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/upload

请求参数

参数名类型必填参数描述
filefile包含 Skill 定义的 ZIP 文件。
namespaceIdstring命名空间 ID,不传默认为 public
overwriteboolean导入时若 Skill 已存在是否覆盖,默认 false

返回数据

参数名参数类型描述
datastring解析并注册后的 Skill 名称。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/upload' \
-F "file=@/path/to/skill.zip" \
-F "namespaceId=public"
  • 返回示例
{
"code": 0,
"message": "success",
"data": "my-skill"
}

7.5. Update Skill Business Tags

接口描述

This interface allows updating the business tag list of a skill without changing version status.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/biz-tags

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
bizTagsstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/skills/biz-tags' -d "namespaceId=namespaceId&skillName=skillName&bizTags=bizTags"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.6. Delete Skill Draft Version

接口描述

This interface allows deleting the current draft version of a specified skill.

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/skills/draft?namespaceId=namespaceId&skillName=skillName'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.7. Create Skill Draft Version

接口描述

This interface allows creating a draft version based on an existing version or a brand-new SkillCard.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
basedOnVersionstring-
targetVersionstring-
skillCardstringSkill card JSON; required if basedOnVersion is not set

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/draft' -d "namespaceId=namespaceId&skillName=skillName&basedOnVersion=basedOnVersion&targetVersion=targetVersion&skillCard=skillCard"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.8. Update Skill Draft Content

接口描述

This interface allows updating the SkillCard content of the current draft version.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
skillCardstringSkill card JSON string containing complete Skill information

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/skills/draft' -d "namespaceId=namespaceId&skillName=skillName&skillCard=skillCard"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.9. Update Skill Version Labels

接口描述

This interface allows updating skill version routing labels (e.g. latest label) without changing version status.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/labels

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
labelsstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/skills/labels' -d "namespaceId=namespaceId&skillName=skillName&labels=labels"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.10. Offline Skill

接口描述

This interface allows executing an offline operation on a specific version or the entire skill, making it not callable.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/offline

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
scopestringUse ‘skill’ for skill-level offline; otherwise version-level
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/offline' -d "namespaceId=namespaceId&skillName=skillName&scope=scope&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.11. Online Skill

接口描述

This interface allows executing an online operation on a specific version or the entire skill, making it callable.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/online

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
scopestringUse ‘skill’ for skill-level online; otherwise version-level
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/online' -d "namespaceId=namespaceId&skillName=skillName&scope=scope&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.12. Publish Skill Version

接口描述

This interface allows publishing an approved skill version.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/publish

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
versionstring-
updateLatestLabelboolean-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/publish' -d "namespaceId=namespaceId&skillName=skillName&version=version&updateLatestLabel=updateLatestLabel"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.13. Update Skill Visibility Scope

接口描述

This interface allows setting the visibility scope of a skill to PUBLIC or PRIVATE.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/scope

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
scopestringPUBLIC or PRIVATE

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/skills/scope' -d "namespaceId=namespaceId&skillName=skillName&scope=scope"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.14. Submit Skill Version for Review

接口描述

This interface allows submitting a skill draft version to the pipeline for review.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/skills/submit

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/skills/submit' -d "namespaceId=namespaceId&skillName=skillName&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.15. Get Skill Version Detail

接口描述

This interface allows querying the detail of a specific Skill version by namespace, skill name, and version number.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/skills/version

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.data.namespaceIdstring-
data.data.namestring-
data.data.descriptionstring-
data.data.skillMdstring-
data.data.resourceobject-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/skills/version?namespaceId=namespaceId&skillName=skillName&version=version'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

7.16. Download Skill Version ZIP

接口描述

This interface allows downloading the ZIP package of a specific Skill version.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/skills/version/download

请求参数

参数名类型必填参数描述
namespaceIdstring-
skillNamestring-
versionstring-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/skills/version/download?namespaceId=namespaceId&skillName=skillName&version=version'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8. AgentSpec 管理

AgentSpec 管理 API 提供 AgentSpec 的查询、草稿、发布、上下线及 ZIP 上传等能力。

8.1. Delete AgentSpec

接口描述

This interface allows deleting an AgentSpec and all its versions by namespace and name.

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/agentspecs?namespaceId=namespaceId&agentSpecName=agentSpecName'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.2. Get AgentSpec

接口描述

This interface allows getting the latest published version of an AgentSpec by namespace and name.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/agentspecs

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.data.namespaceIdstring-
data.data.namestring-
data.data.descriptionstring-
data.data.updateTimeinteger-
data.data.enableboolean-
data.data.bizTagsstring-
data.data.fromstring-
data.data.scopestring-
data.data.labelsobject-
data.data.editingVersionstring-
data.data.reviewingVersionstring-
data.data.onlineCntinteger-
data.data.downloadCountinteger-
data.data.versionsarray-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/agentspecs?namespaceId=namespaceId&agentSpecName=agentSpecName&version=version'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.3. Update AgentSpec Business Tags

接口描述

This interface allows updating the business tag list of an AgentSpec without changing version status.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/biz-tags

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
bizTagsstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/agentspecs/biz-tags' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&bizTags=bizTags"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.4. Delete AgentSpec Draft Version

接口描述

This interface allows deleting the current draft version of a specified AgentSpec.

请求方式

DELETE

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X DELETE 'http://127.0.0.1:8080/v3/console/ai/agentspecs/draft?namespaceId=namespaceId&agentSpecName=agentSpecName'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.5. Create AgentSpec Draft Version

接口描述

This interface allows creating an AgentSpec draft version based on an existing version.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
basedOnVersionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/draft' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&basedOnVersion=basedOnVersion"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.6. Update AgentSpec Draft Content

接口描述

This interface allows updating the card content of the current AgentSpec draft version.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/draft

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
agentSpecCardstringAgentSpec card JSON string containing complete AgentSpec information

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/agentspecs/draft' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&agentSpecCard=agentSpecCard"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.7. Update AgentSpec Version Labels

接口描述

This interface allows updating AgentSpec version routing labels (e.g. latest label) without changing version status.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/labels

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
labelsstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/agentspecs/labels' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&labels=labels"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.8. List AgentSpecs

接口描述

This interface allows paginated listing of AgentSpecs by namespace and name.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/agentspecs/list

请求参数

参数名类型必填参数描述
pageNointeger-
pageSizeinteger-
namespaceIdstring-
agentSpecNamestring-
searchstringSearch mode: accurate or blur

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/agentspecs/list?pageNo=pageNo&pageSize=pageSize&namespaceId=namespaceId&agentSpecName=agentSpecName&search=search'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.9. Offline AgentSpec

接口描述

This interface allows executing an offline operation on a specific version or the entire AgentSpec, making it not callable.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/offline

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
scopestringUse ‘agentspec’ for agentspec-level offline; otherwise version-level
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/offline' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&scope=scope&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.10. Online AgentSpec

接口描述

This interface allows executing an online operation on a specific version or the entire AgentSpec, making it callable.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/online

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
scopestringUse ‘agentspec’ for agentspec-level online; otherwise version-level
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/online' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&scope=scope&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.11. Publish AgentSpec Version

接口描述

This interface allows publishing an approved AgentSpec version.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/publish

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
versionstring-
updateLatestLabelboolean-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/publish' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&version=version&updateLatestLabel=updateLatestLabel"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.12. Update AgentSpec Visibility Scope

接口描述

This interface allows setting the visibility scope of an AgentSpec to PUBLIC or PRIVATE.

请求方式

PUT

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/scope

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
scopestringPUBLIC or PRIVATE

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X PUT 'http://127.0.0.1:8080/v3/console/ai/agentspecs/scope' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&scope=scope"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.13. Submit AgentSpec Version for Review

接口描述

This interface allows submitting an AgentSpec draft version to the pipeline for review.

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/submit

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/submit' -d "namespaceId=namespaceId&agentSpecName=agentSpecName&version=version"
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.14. Upload AgentSpec

接口描述

This interface allows uploading a ZIP-packaged AgentSpec; the package is parsed and the AgentSpec is created or updated.

请求方式

POST

请求体类型:multipart/form-data(如文件上传),请求示例中需使用 -F-H 'Content-Type: multipart/form-data'

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/ai/agentspecs/upload

请求参数

参数名类型必填参数描述
namespaceIdstring-
overwriteboolean-
参数名类型必填参数描述
namespaceIdstring-
overwriteboolean-
filefileZIP file containing agentspec package

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/ai/agentspecs/upload?namespaceId=namespaceId&overwrite=overwrite' -F "namespaceId=" -F "overwrite=" -F "file="
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

8.15. Get AgentSpec Version

接口描述

This interface allows getting a specific version of an AgentSpec by namespace, name, and version.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/agentspecs/version

请求参数

参数名类型必填参数描述
namespaceIdstring-
agentSpecNamestring-
versionstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.data.namespaceIdstring-
data.data.namestring-
data.data.descriptionstring-
data.data.bizTagsstring-
data.data.contentstring-
data.data.resourceobject-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/agentspecs/version?namespaceId=namespaceId&agentSpecName=agentSpecName&version=version'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

9. Pipeline 管理

Pipeline 管理 API 提供执行记录查询能力。

9.1. List Pipeline Executions

接口描述

This interface allows paginated listing of Pipeline execution records by resource type, name, namespace, and version.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/pipelines

请求参数

参数名类型必填参数描述
resourceTypestring-
resourceNamestring-
namespaceIdstring-
versionstring-
pageNointeger-
pageSizeinteger-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.datastring-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/pipelines?resourceType=resourceType&resourceName=resourceName&namespaceId=namespaceId&version=version&pageNo=pageNo&pageSize=pageSize'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

9.2. Get Pipeline Execution

接口描述

This interface allows retrieving a Pipeline execution record by pipeline ID.

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/ai/pipelines/{pipelineId}

请求参数

参数名类型必填参数描述
pipelineIdstring-

返回数据

参数名参数类型描述
data.codeinteger-
data.messagestring-
data.data.executionIdstring-
data.data.resourceTypestring-
data.data.resourceNamestring-
data.data.namespaceIdstring-
data.data.versionstring-
data.data.statusstring-
data.data.pipelinearray-
data.data.createTimeinteger-
data.data.updateTimeinteger-

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/ai/pipelines/{pipelineId}'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {}
}

10. Copilot

Copilot 相关 API 提供配置获取/保存、Prompt 调试与优化、Skill 生成与优化等能力(部分接口为 SSE 流式返回)。

10.1. 获取Copilot配置

接口描述

获取当前Copilot配置,仅返回apiKey、model、studioUrl、studioProject。

请求方式

GET

鉴权状态

需要具有对应命名空间读取权限的用户身份。

请求URL

/v3/console/copilot/config

请求参数

返回数据

参数名参数类型描述
data.enabledbooleanCopilot 功能是否启用。
data.defaultNamespacestring默认使用的命名空间 ID。
data.apiKeystring调用大模型等外部服务的 API Key(脱敏或原文由实现决定)。
data.modelstring默认使用的模型标识。
data.studioUrlstring关联的 Studio 服务地址。
data.studioProjectstring关联的 Studio 项目标识。

示例

  • 请求示例
Terminal window
curl -X GET 'http://127.0.0.1:8080/v3/console/copilot/config'
  • 返回示例
{
"code": 0,
"message": "success",
"data": {
"apiKey": "",
"model": "",
"studioUrl": "",
"studioProject": ""
}
}

10.2. 保存Copilot配置

接口描述

创建或更新Copilot配置,仅接受apiKey、model、studioUrl、studioProject,其他字段使用默认值。

请求方式

POST

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/copilot/config

请求参数

无(请求体可传 apiKey、model、studioUrl、studioProject 等字段,具体以实际接口为准)。

返回数据

参数名参数类型描述
databoolean是否保存成功。

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/copilot/config'
  • 返回示例
{
"code": 0,
"message": "success",
"data": true
}

10.3. 流式调试Prompt

接口描述

通过该接口,可使用用户输入流式调试Prompt并返回模型响应,返回SSE流。

请求方式

POST

请求体类型:application/json

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/copilot/prompt/debug

请求参数

参数名类型必填参数描述
userInputstring用户输入内容。
promptstring待调试的 Prompt。

返回数据

无(SSE 流式返回)

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/copilot/prompt/debug' -H 'Content-Type: application/json' -d '{"userInput":"","prompt":""}'
  • 返回示例
{}

10.4. 流式优化Prompt

接口描述

通过该接口,可流式优化Prompt,返回SSE流。

请求方式

POST

请求体类型:application/json

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/copilot/prompt/optimize

请求参数

参数名类型必填参数描述
optimizationGoalstring优化目标。
promptstring待优化的 Prompt。

返回数据

无(SSE 流式返回)

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/copilot/prompt/optimize' -H 'Content-Type: application/json' -d '{"optimizationGoal":"","prompt":""}'
  • 返回示例
{}

10.5. 流式生成Skill

接口描述

通过该接口,可基于背景信息流式生成Skill,返回SSE流。

请求方式

POST

请求体类型:application/json

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/copilot/skill/generate

请求参数

参数名类型必填参数描述
backgroundInfostring背景信息。
selectedMcpToolsarray选中的 MCP 工具。
conversationHistoryobject对话历史。

返回数据

无(SSE 流式返回)

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/copilot/skill/generate' -H 'Content-Type: application/json' -d '{"backgroundInfo":"","selectedMcpTools":"","conversationHistory":""}'
  • 返回示例
{}

10.6. 流式优化Skill

接口描述

通过该接口,可基于目标与对话历史流式优化Skill,返回SSE流。

请求方式

POST

请求体类型:application/json

鉴权状态

需要具有对应命名空间写入权限的用户身份。

请求URL

/v3/console/copilot/skill/optimize

请求参数

参数名类型必填参数描述
conversationHistoryobject对话历史。
targetFileNamestring目标文件名。
optimizationGoalstring优化目标。
skillstring待优化的 Skill 内容。
selectedMcpToolsarray选中的 MCP 工具。

返回数据

无(SSE 流式返回)

示例

  • 请求示例
Terminal window
curl -X POST 'http://127.0.0.1:8080/v3/console/copilot/skill/optimize' -H 'Content-Type: application/json' -d '{"conversationHistory":"","targetFileName":"","optimizationGoal":"","skill":"","selectedMcpTools":""}'
  • 返回示例
{}