java - 使用 Java Kubernetes 客户端 API 部署 Pod 并为其分配节点

标签 java kubernetes kubeadm

我正在使用 kubeadm 创建 kubernetes 集群。如何将 Pod 部署到特定节点上。下面的代码用于在简单的 minikube 集群中部署 pod。谢谢

        ApiClient client = Config.defaultClient();
        Configuration.setDefaultApiClient(client);

        CoreV1Api api = new CoreV1Api();
        V1ObjectMeta meta = new V1ObjectMeta();

        meta.name("ms2-pod");
        Map<String, String> labels = new HashMap<>();
        labels.put("app", "ms2-pod");
        meta.labels(labels);
        V1ContainerPort port = new V1ContainerPort();
        port.containerPort(9090);
        V1Container container = new V1Container();
        container.name("ms2-container");
        container.image("ms2");
        container.imagePullPolicy("IfNotPresent");
        container.ports(Arrays.asList(port));

        V1PodSpec spec = new V1PodSpec();
        spec.containers(Arrays.asList(container));
        V1Pod podBody = new V1Pod();
        podBody.apiVersion("v1");
        podBody.kind("Pod");
        podBody.metadata(meta);
        podBody.spec(spec);

        V1Pod pod = api.createNamespacedPod("default", podBody, null, null, null);

我们如何使用 Java 中的 K8S 客户端 Api 充分利用 kubeadm 集群内的 kubectl 功能?

最佳答案

您可以使用node selectors or node affinity or anti-affinity取决于你想做什么。

  • Node Name ,这是将 pod 调度到特定节点的最简单方法,由于其局限性,不推荐使用。
  • 节点选择器将允许您使用 label selectors 选择具有特定标签的节点。
  • 节点关联性的工作方式几乎与节点选择器相同,但允许您指定选择器中定义的规则是必需的还是首选的。即使不满足约束,也允许 pod 被调度到任何其他节点。

下面是使用节点选择器的示例(假设您将名为“nodeLabelKey”且值为“nodeLabelValue”的标签添加到节点):

    ApiClient client = Config.defaultClient();
    Configuration.setDefaultApiClient(client);

    CoreV1Api api = new CoreV1Api();
    V1ObjectMeta meta = new V1ObjectMeta();

    meta.name("ms2-pod");
    Map<String, String> labels = new HashMap<>();
    labels.put("app", "ms2-pod");
    meta.labels(labels);
    V1ContainerPort port = new V1ContainerPort();
    port.containerPort(9090);
    V1Container container = new V1Container();
    container.name("ms2-container");
    container.image("ms2");
    container.imagePullPolicy("IfNotPresent");
    container.ports(Arrays.asList(port));

    V1PodSpec spec = new V1PodSpec();
    spec.containers(Arrays.asList(container));
    V1Pod podBody = new V1Pod();
    podBody.apiVersion("v1");
    podBody.kind("Pod");
    podBody.metadata(meta);
    podBody.spec(spec);

    Map<String, String> nodeSelectorMap = new HashMap<>();
    nodeSelectorMap.put("nodeLabelKey", "nodeLabelValue");
    spec.nodeSelector(nodeSelectorMap);

    V1Pod pod = api.createNamespacedPod("default", podBody, null, null, null);

关于java - 使用 Java Kubernetes 客户端 API 部署 Pod 并为其分配节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57080909/

相关文章:

kubernetes - 如何将 kubernetes 从 v1.10.0 升级到 v1.10.11

java - 使用流根据java中的条件拆分列表

java - 哪个ireport版本对应哪个jasperreport版本?

ssl - 为多个 Kubernetes 节点生成单个证书

库伯内斯 (AKS) : Expose multiple ports of different service to common load balancer

kubernetes - 容器运行时网络未准备好: cni config uninitialized

java - 你什么时候决定为你的对象使用访问者?

java - POSTGRES (EclipseLink) 中的 JSON 数据存储

kubernetes - 部署在 minikube 上找不到 PVC

kubernetes - 删除 node-role.kubernetes.io/master :NoSchedule taint