You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
arthas/tutorials/katacoda/case-http-api-cn/http-api.md

60 lines
2.4 KiB
Markdown

### 概览
Http API
提供类似RESTful的交互接口请求和响应均为JSON格式的数据。相对于Telnet/WebConsole的输出非结构化文本数据Http
API可以提供结构化的数据支持更复杂的交互功能比如特定应用场景的一系列诊断操作。
#### 访问地址
Http API接口地址为`http://ip:port/api`必须使用POST方式提交请求参数。如POST
`http://127.0.0.1:8563/api`
注意telnet服务的3658端口与Chrome浏览器有兼容性问题建议使用http端口8563来访问http接口。
#### 请求数据格式
```json
{
"action": "exec",
"requestId": "req112",
"sessionId": "94766d3c-8b39-42d3-8596-98aee3ccbefb",
"consumerId": "955dbd1325334a84972b0f3ac19de4f7_2",
"command": "version",
"execTimeout": "10000"
}
```
请求数据格式说明:
* `action` : 请求的动作/行为,可选值请参考"请求Action"小节。
* `requestId` : 可选请求ID由客户端生成。
* `sessionId` : Arthas会话ID一次性命令不需要设置会话ID。
* `consumerId` : Arthas消费者ID用于多人共享会话。
* `command` : Arthas command line 。
* `execTimeout` : 命令同步执行的超时时间(ms)默认为30000。
注意: 不同的action使用到参数不同根据具体的action来设置参数。
#### 请求Action
目前支持的请求Action如下
* `exec` : 同步执行命令,命令正常结束或者超时后中断命令执行后返回命令的执行结果。
* `async_exec` : 异步执行命令,立即返回命令的调度结果,命令执行结果通过`pull_results`获取。
* `interrupt_job` : 中断会话当前的命令类似Telnet `Ctrl + c`的功能。
* `pull_results` : 获取异步执行的命令的结果以http 长轮询long-polling方式重复执行
* `init_session` : 创建会话
* `join_session` : 加入会话用于支持多人共享同一个Arthas会话
* `close_session` : 关闭会话
#### 响应状态
响应中的state属性表示请求处理状态取值如下
* `SCHEDULED`异步执行命令时表示已经创建job并已提交到命令执行队列命令可能还没开始执行或者执行中
* `SUCCEEDED`:请求处理成功(完成状态);
* `FAILED`请求处理失败完成状态通常附带message说明原因
* `REFUSED`请求被拒绝完成状态通常附带message说明原因