如何使用 Kubernetes Azure 和 AWS SDK for Java 部署应用程序


public void runKubernetes() {
KubernetesCluster k8sCluster = this.getKubernetesCluster("xyz-aks");
System.out.println("___________________________________________");
System.out.println("Kubernetes Cluster String: " + k8sCluster.name());
DefaultKubernetesClient kubeclient = new DefaultKubernetesClient();
System.out.println("Kube client Master URL :"+kubeclient.getMasterUrl());
NodeList kubenodes = kubeclient.nodes().list();
for (Node node : kubenodes.getItems()) {
System.out.println( node.getKind() + " => " + node.getMetadata().getName() +": " + node.getMetadata().getClusterName());
}
}

我得到客户端和节点。现在,我有yaml文件,我想以编程方式部署该yaml(创建服务,部署和pod(。

我可以做以下事情

kubectl create -f pod-sample.yaml 

但我想使用 JAVA SDK 做同样的事情。

我正在为Kubernetes使用以下Java库:

io.fabric8.kubernetes

我相信你可以解析部署定义的 YAML 或 JSON。例如,对于 YAML,您可以在此处使用任何 Java 库

  • JvYaml # RbYaml 的 Java 端口
  • SnakeYAML # Java 5/YAML 1.1
  • YamlBeans # To/from JavaBeans
  • JYaml # 原始 Java 实现
  • Camel # YAML 1.2 for Java.用户友好的 OOP 库。

杰克逊似乎是更受欢迎的JSON,它也支持YAML扩展。

然后,一旦你解析说出名称,例如创建一个服务:

Service myservice = client.services().inNamespace(parsedNamespaceStr).createNew()
.withNewMetadata()
.withName(parsedServiceName)
.addToLabels(parsedLabel1, parseLabel2)
.endMetadata()
.done();

最新更新