2.1 注册第三方应用

第三方应用负责人需要向Apollo管理员提供一些第三方应用基本信息。

基本信息如下:

  • 第三方应用的AppId、应用名、部门
  • 第三方应用负责人

Apollo管理员在 创建第三方应用,创建之前最好先查询此AppId是否已经创建。创建成功之后会生成一个token,如下图所示:

2.2 给已注册的第三方应用授权

第三方应用不应该能操作任何Namespace的配置,所以需要给token绑定可以操作的Namespace。Apollo管理员在 页面给token赋权。赋权之后,第三方应用就可以通过Apollo提供的Http REST接口来管理已授权的Namespace的配置了。

2.3 第三方应用调用Apollo Open API

2.3.1 调用Http REST接口

任何语言的第三方应用都可以调用Apollo的Open API,在调用接口时,需要设置注意以下两点:

  • Http Header中增加一个Authorization字段,字段值为申请的token
  • Http Header的Content-Type字段需要设置成application/json;charset=UTF-8
2.3.2 Java应用通过apollo-openapi调用Apollo Open API

从1.1.0版本开始,Apollo提供了客户端,所以Java语言的第三方应用可以更方便地调用Apollo Open API。

首先引入依赖:

  1. String portalUrl = "http://localhost:8070"; // portal url
  2. String token = "e16e5cd903fd0c97a116c873b448544b9d086de9"; // 申请的token
  3. ApolloOpenApiClient client = ApolloOpenApiClient.newBuilder()
  4. .withPortalUrl(portalUrl)
  5. .withToken(token)
  6. .build();

后续就可以通过ApolloOpenApiClient的接口直接操作Apollo Open API了,接口说明参见下面的Rest接口文档。

2.3.3 .Net core应用调用Apollo Open API

.Net core也提供了open api的客户端,详见

2.3.4 Shell Scripts调用Apollo Open API

封装了bash的function,底层使用curl来发送HTTP请求

3.1 URL路径参数说明

3.2 API接口列表

3.2.1 获取App的环境,集群信息
  • URL :
  • Method : GET
  • Request Params : 无
  • 返回值Sample
  1. [
  2. {
  3. "env":"FAT",
  4. "clusters":[ //集群列表
  5. "default",
  6. "FAT381"
  7. ]
  8. },
  9. {
  10. "env":"UAT",
  11. "clusters":[
  12. "default"
  13. ]
  14. },
  15. {
  16. "env":"PRO",
  17. "clusters":[
  18. "default",
  19. "SHAOY",
  20. "SHAJQ"
  21. ]
  22. }
  23. ]
3.2.2 获取App信息
  • URL :
  • Method : GET
  • Request Params :
参数名 必选 类型 说明
appIds false String appId列表,以逗号分隔,如果为空则返回所有App信息
  • 返回值Sample
  1. [
  2. {
  3. "name":"first_app",
  4. "appId":"100003171",
  5. "orgId":"development",
  6. "orgName":"研发部",
  7. "ownerName":"apollo",
  8. "ownerEmail":"test@test.com",
  9. "dataChangeCreatedBy":"apollo",
  10. "dataChangeLastModifiedBy":"apollo",
  11. "dataChangeCreatedTime":"2019-05-08T09:13:31.000+0800",
  12. "dataChangeLastModifiedTime":"2019-05-08T09:13:31.000+0800"
  13. },
  14. {
  15. "name":"apollo-demo",
  16. "orgId":"development",
  17. "orgName":"产品研发部",
  18. "ownerName":"apollo",
  19. "ownerEmail":"apollo@cmcm.com",
  20. "dataChangeCreatedBy":"apollo",
  21. "dataChangeLastModifiedBy":"apollo",
  22. "dataChangeCreatedTime":"2018-12-23T12:35:16.000+0800",
  23. "dataChangeLastModifiedTime":"2019-04-08T13:58:36.000+0800"
  24. }
  25. ]
3.2.3 获取集群接口
  • URL
  • Method : GET
  • Request Params :无
  • 返回值Sample
  1. "name":"default",
  2. "appId":"100004458",
  3. "dataChangeCreatedBy":"apollo",
  4. "dataChangeLastModifiedBy":"apollo",
  5. "dataChangeCreatedTime":"2018-12-23T12:35:16.000+0800",
  6. "dataChangeLastModifiedTime":"2018-12-23T12:35:16.000+0800"
  7. }
3.2.4 创建集群接口

可以通过此接口创建集群,调用此接口需要授予第三方APP对目标APP的管理权限。

  • URL
  • Method : POST
  • Request Params :无
  • 请求内容(Request Body, JSON格式)
参数名 必选 类型 说明
name true String Cluster的名字
appId true String Cluster所属的AppId
dataChangeCreatedBy true String namespace的创建人,格式为域账号,也就是sso系统的User ID
  • 返回值 Sample
  1. {
  2. "name":"someClusterName",
  3. "appId":"100004458",
  4. "dataChangeCreatedBy":"apollo",
  5. "dataChangeLastModifiedBy":"apollo",
  6. "dataChangeCreatedTime":"2018-12-23T12:35:16.000+0800",
  7. "dataChangeLastModifiedTime":"2018-12-23T12:35:16.000+0800"
  8. }
3.2.5 获取集群下所有Namespace信息接口
  • URL :
  • Method: GET
  • Request Params: 无
  • 返回值Sample:
3.2.6 获取某个Namespace信息接口
  • URL
  • Method : GET
  • Request Params :无
  • 返回值Sample
  1. {
  2. "appId": "100003171",
  3. "clusterName": "default",
  4. "namespaceName": "application",
  5. "comment": "default app namespace",
  6. "format": "properties", //Namespace格式可能取值为:propertiesxmljsonymlyaml
  7. "isPublic": false, //是否为公共的Namespace
  8. "items": [ // Namespace下所有的配置集合
  9. {
  10. "key": "batch",
  11. "value": "100",
  12. "dataChangeCreatedBy": "song_s",
  13. "dataChangeLastModifiedBy": "song_s",
  14. "dataChangeCreatedTime": "2016-07-21T16:03:43.000+0800",
  15. "dataChangeLastModifiedTime": "2016-07-21T16:03:43.000+0800"
  16. }
  17. ],
  18. "dataChangeCreatedBy": "song_s",
  19. "dataChangeLastModifiedBy": "song_s",
  20. "dataChangeCreatedTime": "2016-07-20T14:05:58.000+0800",
  21. "dataChangeLastModifiedTime": "2016-07-20T14:05:58.000+0800"
  22. }
3.2.7 创建Namespace

可以通过此接口创建Namespace,调用此接口需要授予第三方APP对目标APP的管理权限。

  • URL
  • Method : POST
  • Request Params :无
  • 请求内容(Request Body, JSON格式)
  • 返回值 Sample
  1. {
  2. "name": "FX.public-0420-11",
  3. "appId": "100003173",
  4. "format": "properties",
  5. "isPublic": true,
  6. "comment": "test",
  7. "dataChangeCreatedBy": "zhanglea",
  8. "dataChangeLastModifiedBy": "zhanglea",
  9. "dataChangeCreatedTime": "2017-04-20T18:25:49.033+0800",
  10. "dataChangeLastModifiedTime": "2017-04-20T18:25:49.033+0800"
  11. }
  • 返回值说明
3.2.8 获取某个Namespace当前编辑人接口

Apollo在生产环境(PRO)有限制规则:每次发布只能有一个人编辑配置,且该次发布的人不能是该次发布的编辑人。 也就是说如果一个用户A修改了某个namespace的配置,那么在这个namespace发布前,只能由A修改,其它用户无法修改。同时,该用户A无法发布自己修改的配置,必须找另一个有发布权限的人操作。 这个接口就是用来获取当前namespace是否有人锁定的接口。在非生产环境(FAT、UAT),该接口始终返回没有人锁定。

  • URL
  • Method : GET
  • Request Params :无
  • 返回值 Sample(未锁定)
  1. {
  2. "namespaceName": "application",
  3. "isLocked": false
  4. }
  • 返回值Sample(被锁定)
  1. {
  2. "isLocked": true,
  3. "lockedBy": "song_s" //锁owner
  4. }
3.2.9 读取配置接口
  • URL
  • Method : GET
  • Request Params :无
  • 返回值Sample
  1. {
  2. "value": "3000",
  3. "comment": "超时时间",
  4. "dataChangeCreatedBy": "zhanglea",
  5. "dataChangeLastModifiedBy": "zhanglea",
  6. "dataChangeCreatedTime": "2016-08-11T12:06:41.818+0800",
  7. "dataChangeLastModifiedTime": "2016-08-11T12:06:41.818+0800"
  8. }
3.2.10 新增配置接口
  • URL
  • Method : POST
  • Request Params :无
  • 请求内容(Request Body, JSON格式)
参数名 必选 类型 说明
key true String 配置的key,长度不能超过128个字符。非properties格式,key固定为content
value true String 配置的value,长度不能超过20000个字符,非properties格式,value为文件全部内容
comment false String 配置的备注,长度不能超过256个字符
dataChangeCreatedBy true String item的创建人,格式为域账号,也就是sso系统的User ID
  • Request body sample :
  • 返回值Sample
  1. {
  2. "key": "timeout",
  3. "value": "3000",
  4. "comment": "超时时间",
  5. "dataChangeCreatedBy": "zhanglea",
  6. "dataChangeLastModifiedBy": "zhanglea",
  7. "dataChangeCreatedTime": "2016-08-11T12:06:41.818+0800",
  8. "dataChangeLastModifiedTime": "2016-08-11T12:06:41.818+0800"
  9. }
3.2.11 修改配置接口
  • URL
  • Method : PUT
  • Request Params
参数名 必选 类型 说明
createIfNotExists false Boolean 当配置不存在时是否自动创建
  • 请求内容(Request Body, JSON格式)
  • Request body sample :

    1. {
    2. "key":"timeout",
    3. "value":"3000",
    4. "comment":"超时时间",
    5. "dataChangeLastModifiedBy":"zhanglea"
    6. }
  • 返回值 :无

3.2.12 删除配置接口
  • URL
  • Method : DELETE
  • Request Params
参数名 必选 类型 说明
key true String 配置的key。非properties格式,key固定为content
operator true String 删除配置的操作者,域账号
  • 返回值 : 无
3.2.13 发布配置接口
  • URL
  • Method : POST
  • Request Params :无
  • Request Body
参数名 必选 类型 说明
releaseTitle true String 此次发布的标题,长度不能超过64个字符
releaseComment false String 发布的备注,长度不能超过256个字符
releasedBy true String 发布人,域账号,注意:如果ApolloConfigDB.ServerConfig中的namespace.lock.switch设置为true的话(默认是false),那么该环境不允许发布人和编辑人为同一人。所以如果编辑人是zhanglea,发布人就不能再是zhanglea。
  • Request Body example
  1. {
  2. "releaseTitle":"2016-08-11",
  3. "releaseComment":"修改timeout值",
  4. "releasedBy":"zhanglea"
  5. }
  • 返回值Sample
  1. {
  2. "appId": "test-0620-01",
  3. "clusterName": "test",
  4. "namespaceName": "application",
  5. "name": "2016-08-11",
  6. "configurations": {
  7. "timeout": "3000",
  8. },
  9. "comment": "修改timeout值",
  10. "dataChangeCreatedBy": "zhanglea",
  11. "dataChangeLastModifiedBy": "zhanglea",
  12. "dataChangeCreatedTime": "2016-08-11T14:03:46.232+0800",
  13. "dataChangeLastModifiedTime": "2016-08-11T14:03:46.235+0800"
  14. }
3.2.14 获取某个Namespace当前生效的已发布配置接口
  • URL
  • Method : GET
  • Request Params :无
  • 返回值Sample
  1. {
  2. "appId": "test-0620-01",
  3. "clusterName": "test",
  4. "namespaceName": "application",
  5. "name": "2016-08-11",
  6. "configurations": {
  7. "timeout": "3000",
  8. },
  9. "comment": "修改timeout值",
  10. "dataChangeCreatedBy": "zhanglea",
  11. "dataChangeLastModifiedBy": "zhanglea",
  12. "dataChangeCreatedTime": "2016-08-11T14:03:46.232+0800",
  13. }
3.2.15 回滚已发布配置接口
  • URL
  • Method : PUT
  • 返回值 : 无

正常情况下,接口返回的Http状态码是200,下面列举了Apollo会返回的非200错误码说明。

4.1 400 - Bad Request

客户端传入参数的错误,如操作人不存在,namespace不存在等等,客户端需要根据提示信息检查对应的参数是否正确。

4.2 401 - Unauthorized

接口传入的token非法或者已过期,客户端需要检查token是否传入正确。

4.3 403 - Forbidden

接口要访问的资源未得到授权,比如只授权了对A应用下Namespace的管理权限,但是却尝试管理B应用下的配置。

4.4 404 - Not Found

接口要访问的资源不存在,一般是URL或URL的参数错误。

4.5 405 - Method Not Allowed

4.6 500 - Internal Server Error

其它类型的错误默认都会返回500,对这类错误如果应用无法根据提示信息找到原因的话,可以找Apollo研发团队一起排查问题。