先說CloudFoundry的命令行工具CLI。咱們在CloudFoundry環境下工做,第一個使用的命令就是cf login。nginx
若是在環境變量裏維護CF_TRACE的值爲true:json
則咱們能發現,諸如cf login這種命令,實際上也是經過消費Restful API來完成的。windows
下圖是cf login這個命令的api endpoint請求細節,供你們參考:api
API endpoint: https://api.cf.eu10.hana.ondemand.com安全
REQUEST: [2018-09-21T14:50:57+08:00]app
GET /v2/info HTTP/1.1ssh
Host: api.cf.eu10.hana.ondemand.com工具
Accept: application/jsonui
Content-Type: application/jsonspa
User-Agent: go-cli 6.36.1+e3799ad7e.2018-04-04 / windows
RESPONSE: [2018-09-21T14:50:59+08:00]
HTTP/1.1 200 OK
Connection: close
Content-Length: 550
Content-Type: application/json;charset=utf-8
Date: Fri, 21 Sep 2018 06:50:58 GMT
Server: nginx
X-Content-Type-Options: nosniff
X-Vcap-Request-Id: abf32f52-294a-41f5-5919-be948d78f0dd::a32b17bb-da82-4d45-930f-f0344c8a83b3
{"name":"","build":"","support":"","version":0,"description":"Cloud Foundry at SAP Cloud Platform","authorization_endpoint":"https://login.cf.eu10.hana.ondemand.com","token_endpoint":"[PRIVATE DATA HIDDEN]","min_cli_version":null,"min_recommended_cli_version":null,"api_version":"2.115.0","app_ssh_endpoint":"ssh.cf.eu10.hana.ondemand.com:2222","app_ssh_host_key_fingerprint":"f3:12:47:b5:3a:19:6e:6c:4e:9d:90:2e:6f:8e:87:cc","app_ssh_oauth_client":"ssh-proxy","doppler_logging_endpoint":"wss://doppler.cf.eu10.hana.ondemand.com:443"}
REQUEST: [2018-09-21T14:50:59+08:00]
GET /login HTTP/1.1
Host: login.cf.eu10.hana.ondemand.com
Accept: application/json
Content-Type: application/json
User-Agent: go-cli 6.36.1+e3799ad7e.2018-04-04 / windows
API響應結果:
RESPONSE: [2018-09-21T14:51:00+08:00]
HTTP/1.1 200 OK
Connection: close
Content-Length: 551
Cache-Control: no-store
Content-Language: en-US
Content-Type: application/json;charset=UTF-8
Date: Fri, 21 Sep 2018 06:50:59 GMT
Set-Cookie: X-Uaa-Csrf=8uoxBvyG8QCwo29efrrZNh; Max-Age=86400; Expires=Sat, 22-Sep-2018 06:51:00 GMT; Path=/; Secure; HttpOnly
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Content-Type-Options: nosniff
X-Frame-Options: DENY
X-Vcap-Request-Id: f6b29d8f-f78e-4c5e-61f3-5c9d906828ed
X-Xss-Protection: 1; mode=block
{"app":{"version":"4.19.0"},"links":{"uaa":"https://uaa.cf.eu10.hana.ondemand.com","passwd":"https://accounts.sap.com/ui/createForgottenPasswordMail?spName=cf.eu10.hana.ondemand.com","login":"https://login.cf.eu10.hana.ondemand.com","register":"https://accounts.sap.com/ui/public/showRegisterForm?spName=cf.eu10.hana.ondemand.com"},"zone_name":"uaa","entityID":"login.cf.eu10.hana.ondemand.com","commit_id":"7897100","idpDefinitions":{},"prompts":{"username":["text","Email"],"password":["password","Password"]},"timestamp":"2018-06-13T12:02:09-0700"}
Email>
再看Kubernetes。咱們用的不少的命令:
kubectl get pods,返回pods列表。
而用命令行
kubectl --v=8 get pods
則發現,get pods這個命令實際上也是發請求發往Kubernetes的API server:
https://<ip>:6443/api/v1/namespaces/default/pods?limit=500
API請求明細以下:
API server是Kubernetes最重要的核心組件之一:
1. 提供集羣管理的REST API接口,包括認證受權、數據校驗以及集羣狀態變動等
2. 提供其餘模塊之間的數據交互和通訊的樞紐(其餘模塊經過API Server查詢或修改
數據,只有API Server才直接操做etcd)
kube-apiserver支持同時提供https(默認監聽在6443端口)和http API(默認監聽在
127.0.0.1的8080端口),其中http API是非安全接口,不作任何認證受權機制,不建議
生產環境啓用。兩個接口提供的REST API格式相同,參考Kubernetes API Reference查
看全部API的調用格式。
在實際使用中,一般經過kubectl來訪問apiserver,也能夠經過Kubernetes各個語言的
client庫來訪問apiserver。
好比上面get pods命令對應的API的文檔:
https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.10/#list-62
要獲取更多Jerry的原創文章,請關注公衆號"汪子熙":