说明:
官方API:
http://kubernetes.io/kubernetes/third_party/swagger-ui/#/
注意:
k8s的api是严格按照restful风格的,即同样的
/api/v1/namespaces/{namespace}/pods
如果是POST则是创建pod,如果是DELETE则是删除pod
本文摘抄一些我们日常使用需要的api,以提供给agent调用
POST /api/v1/namespaces/{namespace}/pods //此处我们的namespaces是default
类型:application/json
参数:参考官方
DELETE /api/v1/namespaces/{namespace}/pods
GET /api/v1/namespaces/{namespace}/pods
GET /api/v1/namespaces/{namespace}/pods/{name}
POST /api/v1/namespaces/{namespace}/replicationcontrollers
DELETE /api/v1/namespaces/{namespace}/replicationcontrollers/{name}
GET /api/v1/namespaces/{namespace}/replicationcontrollers
GET /api/v1/namespaces/{namespace}/replicationcontrollers/{name}
PUT /api/v1/namespaces/{namespace}/replicationcontrollers/{name}
POST /api/v1/namespaces/{namespace}/services
DELETE /api/v1/namespaces/{namespace}/services/{name}
GET /api/v1/namespaces/{namespace}/services/{name}
GET /api/v1/namespaces/{namespace}/services
POST /api/v1/nodes
GET /api/v1/nodes
DELETE /api/v1/nodes/{name}
GET /api/v1/nodes/{name}
不难发现,一旦统一风格后,restful api就显得非常清楚明了,路径一致,只需要改变请求方法即可.
具体执行一个请求,比如在10.1.1.1上部署了整个k8s环境,并且配置了api server端口为8080。
此时机子上面跑了一个pod:test-pod。
我们测试一下通过http请求删除pod,而不是kubectl delete pod name.
请求path:
10.1.1.1:8080/api/v1/namespaces/default/pods
请求方法:
http delete
测试代码如下:
待续.
http://10.1.1.1:8080/api/v1/namespaces/default/pods
确实列出了所有pod的信息.验证了restful api
其他资料:
Kubernetes权威指南之Kubernetes API详解
http://www.infoq.com/cn/articles/Kubernetes-API?amp&&