此文僅供瞭解kubernates的開發人員寫api接口時參考。java
1、前言api
java訪問kubernates API的方式有不少,用java語言開發的有兩種,一個是基於Jersey的,一個是基於Fabric8。由於Kubernates API Server就是RESRFul Web Service,而Jersey是一個方便簡化開發RESRFul Web Service的框架因此採用jersey會比較省力,但仍是須要開發者本身作不少工做。Fabric8中的kubernates-client-1.3.83.jar,kubernates-model-1.0.12.jar等工具包包對kubernates api作了很好的封裝,訪問代碼比較簡單。框架
2、使用說明工具
準備好相關的jar包ui
建立訪問API Server的客戶端spa
代碼參見三server
操做kubernates的各項資源接口
經常使用的資源(資源解釋後續會加上):資源
Nodes開發
Namespaces
Services
Replicationcontrollers
Pods
Events
Resourcequotas
能夠經過api對以上資源作增刪改查各類操做。
3、具體代碼實現
1.建立訪問k8s API server的客戶端代碼示例
Config config = new ConfigBuilder().withMasterUrl("http://10.45.32.153:8080/").build();
KubernetesClient client = new DefaultKubernetesClient(config);
// http://10.45.32.153:8080/ 是API Server的地址
2.查詢k8s資源的代碼示例(每種資源的查詢方式大同小異)
幾乎全部的資源均可以查,如今咱們以查詢namesapce爲例進行講解。
A 查詢全部的namespace列表
List<Namespace> nameSpaceList =client.namespaces().list().getItems();
B 根據條件查詢namespace
Namespace space = client.namespaces().withName(tenant.getAccount()).get();
能夠根據不少種條件進行過濾
3.建立資源示例代碼(這是最核心的部分,每種資源的建立方式不一樣)
A建立租戶
Namespace ns = new NamespaceBuilder().withNewMetadata()
.withName(tenant.getAccount()).endMetadata().build();
// 屬性設置
ObjectMeta metadata = new ObjectMeta();
Map<String,String> labels = new HashMap<String, String>();
labels.put("label1", tenant.getAccount());
metadata.setLabels(labels);
metadata.setNamespace(tenant.getAccount());
metadata.setName(tenant.getAccount());
ns.setMetadata(metadata);
// 執行建立操做
client.namespaces().create(ns);
B建立結果
註釋:該代碼沒有給namespace設置quotas
4.修改租戶配額示例代碼
5.刪除租戶示例代碼
client.namespaces().withName(tenant.getAccount()).delete();
後續會對namespace,service,rc,pod等的增刪改查代碼作出詳細的描述,敬請關注!!!