java實現kubernates的api訪問—Fabric8

此文僅供瞭解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、使用說明工具

  1. 準備好相關的jar包ui

  2. 建立訪問API Server的客戶端spa

    代碼參見三server

  3. 操做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等的增刪改查代碼作出詳細的描述,敬請關注!!!

相關文章
相關標籤/搜索