當前位置: 首頁>>代碼示例>>Java>>正文


Java KubernetesClient類代碼示例

本文整理匯總了Java中io.fabric8.kubernetes.client.KubernetesClient的典型用法代碼示例。如果您正苦於以下問題:Java KubernetesClient類的具體用法?Java KubernetesClient怎麽用?Java KubernetesClient使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


KubernetesClient類屬於io.fabric8.kubernetes.client包,在下文中一共展示了KubernetesClient類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: createKubernetesClient

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
static KubernetesClient createKubernetesClient(ContainerEngineCluster gkeCluster) {
  try {
    final GoogleCredential credential = GoogleCredential.getApplicationDefault()
        .createScoped(ContainerScopes.all());
    final Container gke = new Container.Builder(credential.getTransport(), credential.getJsonFactory(), credential)
        .setApplicationName("hype")
        .build();

    final Cluster cluster = gke.projects().zones().clusters()
        .get(gkeCluster.project(), gkeCluster.zone(), gkeCluster.cluster())
        .execute();

    final io.fabric8.kubernetes.client.Config kubeConfig = new ConfigBuilder()
        .withMasterUrl("https://" + cluster.getEndpoint())
        .withCaCertData(cluster.getMasterAuth().getClusterCaCertificate())
        .withClientCertData(cluster.getMasterAuth().getClientCertificate())
        .withClientKeyData(cluster.getMasterAuth().getClientKey())
        .build();

    return new DefaultKubernetesClient(kubeConfig).inNamespace(NAMESPACE);
  } catch (IOException e) {
    throw Throwables.propagate(e);
  }
}
 
開發者ID:spotify,項目名稱:hype,代碼行數:25,代碼來源:DockerRunner.java

示例2: fetchPods

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
private void fetchPods(KubernetesClient dockerClient) throws ParseException {
    final Map<String, KubernetesNode> dockerNodeMap = nodes.stream().distinct().collect(toMap(KubernetesNode::getName, node -> node));

    final List<Pod> pods = dockerClient.pods().inNamespace(Constants.KUBERNETES_NAMESPACE_KEY)
            .withLabel(Constants.CREATED_BY_LABEL_KEY, Constants.PLUGIN_ID)
            .list().getItems();

    LOG.info("Running pods " + pods.size());

    for (Pod pod : pods) {
        final KubernetesPod kubernetesPod = new KubernetesPod(pod);
        final KubernetesNode kubernetesNode = dockerNodeMap.get(kubernetesPod.getNodeName());
        if (kubernetesNode != null) {
            kubernetesNode.add(kubernetesPod);
        }
    }
}
 
開發者ID:gocd,項目名稱:kubernetes-elastic-agents,代碼行數:18,代碼來源:KubernetesCluster.java

示例3: unregisteredAfterTimeout

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
private KubernetesAgentInstances unregisteredAfterTimeout(PluginSettings settings, Agents knownAgents) throws Exception {
    Period period = settings.getAutoRegisterPeriod();
    KubernetesAgentInstances unregisteredInstances = new KubernetesAgentInstances();
    KubernetesClient client = factory.kubernetes(settings);

    for (String instanceName : instances.keySet()) {
        if (knownAgents.containsAgentWithId(instanceName)) {
            continue;
        }
        Pod pod = client.pods().inNamespace(Constants.KUBERNETES_NAMESPACE_KEY).withName(instanceName).get();
        Date createdAt = getSimpleDateFormat().parse(pod.getMetadata().getCreationTimestamp());
        DateTime dateTimeCreated = new DateTime(createdAt);

        if (clock.now().isAfter(dateTimeCreated.plus(period))) {
            unregisteredInstances.register(kubernetesInstanceFactory.fromKubernetesPod(pod));
        }
    }
    return unregisteredInstances;
}
 
開發者ID:gocd,項目名稱:kubernetes-elastic-agents,代碼行數:20,代碼來源:KubernetesAgentInstances.java

示例4: shouldCreateKubernetesClusterObject

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
@Test
public void shouldCreateKubernetesClusterObject() throws Exception {
    final KubernetesClient kubernetesClient = mock(KubernetesClient.class);

    NodeOperationsImpl nodes = mock(NodeOperationsImpl.class);
    PodOperationsImpl pods = mock(PodOperationsImpl.class);

    when(nodes.list()).thenReturn(new NodeList());
    when(kubernetesClient.nodes()).thenReturn(nodes);

    when(pods.inNamespace(Constants.KUBERNETES_NAMESPACE_KEY)).thenReturn(pods);
    when(pods.withLabel(Constants.CREATED_BY_LABEL_KEY, Constants.PLUGIN_ID)).thenReturn(pods);
    when(pods.list()).thenReturn(new PodList());
    when(kubernetesClient.pods()).thenReturn(pods);

    final KubernetesCluster cluster = new KubernetesCluster(kubernetesClient);

    verify(kubernetesClient, times(1)).nodes();
    verify(kubernetesClient, times(1)).pods();
}
 
開發者ID:gocd,項目名稱:kubernetes-elastic-agents,代碼行數:21,代碼來源:KubernetesClusterTest.java

示例5: selectNamespace

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
/**
 * Choose a namespace that sounds like the specified namespace.
 * @param client        The client instance to use to query namespaces.
 * @param namespace     The specified namespace.
 * @return              The closest namespace if resemblance is over 80%, else null.
 */
 public static final String selectNamespace(KubernetesClient client, String namespace) {
     if (client.isAdaptable(OpenShiftClient.class)) {
         return selectName(client.adapt(OpenShiftClient.class).projects()
                 .list()
                 .getItems()
                 .stream()
                 .map(n -> n.getMetadata().getName()), namespace);
     } else {
         return selectName(client.namespaces()
                 .list()
                 .getItems()
                 .stream()
                 .map(n -> n.getMetadata().getName()), namespace);
     }
}
 
開發者ID:fabric8io,項目名稱:kubernetes-alexa,代碼行數:22,代碼來源:IntentContext.java

示例6: getData

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
private static Map<String, String> getData(KubernetesClient client, String name, String namespace) {
    Map<String, String> result = new HashMap<>();
    try {
        ConfigMap map = namespace == null || namespace.isEmpty()
                ? client.configMaps().withName(name).get()
                : client.configMaps().inNamespace(namespace).withName(name).get();

        if (map != null) {
            for (Map.Entry<String, String> entry : map.getData().entrySet()) {
                String key = entry.getKey();
                String value = entry.getValue();
                if (key.equals(APPLICATION_YAML) || key.equals(APPLICATION_YML)) {
                    result.putAll(YAML_TO_PROPETIES.andThen(PROPERTIES_TO_MAP).apply(value));
                } else if (key.equals(APPLICATION_PROPERTIES)) {
                    result.putAll(KEY_VALUE_TO_PROPERTIES.andThen(PROPERTIES_TO_MAP).apply(value));
                } else {
                    result.put(key, value);
                }
            }
        }
    } catch (Exception e) {
        LOGGER.warn("Can't read configMap with name: [" + name + "] in namespace:[" + namespace + "]. Ignoring");
    }
    return result;
}
 
開發者ID:fabric8io,項目名稱:spring-cloud-kubernetes,代碼行數:26,代碼來源:ConfigMapPropertySource.java

示例7: createTestEnvironment

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
public static KubernetesTestEnvironment createTestEnvironment(Strategy strategy) throws IOException, ResourceConfigException, ResourceException {
    Map<String, String> environmentVariables = TestEnvironmentUtil.loadEnvironmentVariables(
            KUBERNETES_URL_ENV,
            KUBERNETES_USERNAME_ENV,
            KUBERNETES_PASSWORD_ENV,
            KUBERNETES_NAMESPACE_PREFIX_ENV
    );

    String namespace = createNewTestNamespace(environmentVariables);

    KubernetesEnvironmentConfig environmentConfig = createEnvironmentConfig(environmentVariables, strategy, namespace);
    ClientFactory clientFactory = createClientFactory(environmentConfig);

    KubernetesClient kubernetesClient = createKubernetesClient(environmentConfig);
    NamespaceResource namespaceResource = createNamespaceResource(clientFactory, namespace);
    return new KubernetesTestEnvironment(clientFactory, environmentConfig, namespaceResource, kubernetesClient);
}
 
開發者ID:qaware,項目名稱:gradle-cloud-deployer,代碼行數:18,代碼來源:KubernetesTestEnvironmentUtil.java

示例8: getResource

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
@Override
public Resource<Pod> getResource(ObserverKey observerKey, KubernetesClient client) {
    return new Resource<Pod>() {
        @Override
        public Watch watchResources(Watcher watcher) {
            return client.pods().inNamespace(client.getNamespace()).withLabels(observerKey.getLabelFilter()).watch(watcher);
        }

        @Override
        public Set<Pod> listResources() {
            return client.pods().inNamespace(client.getNamespace()).withLabels(observerKey.getLabelFilter()).list().getItems().stream()
                    .filter(pod -> filterPod(observerKey, pod))
                    .map(Pod::new)
                    .collect(Collectors.toSet());
        }
    };
}
 
開發者ID:EnMasseProject,項目名稱:enmasse,代碼行數:18,代碼來源:PodSenseSubscriptionConfig.java

示例9: getResource

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
@Override
public Resource<TestResource> getResource(ObserverKey observerKey, KubernetesClient client) {
    return new Resource<TestResource>() {
        @Override
        public Watch watchResources(Watcher watcher) {
            return testWatch;
        }

        @Override
        public Set<TestResource> listResources() {
            try {
                return stream.take();
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        }
    };
}
 
開發者ID:EnMasseProject,項目名稱:enmasse,代碼行數:19,代碼來源:TestSubscriptionConfig.java

示例10: findServiceEntryAndSetValue

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
private static void findServiceEntryAndSetValue(
    Object bean, List<Field> serverNameFields, JsonObject env, KubernetesClient client)
    throws KubernetesClientException {
  Objects.requireNonNull(client, "no client available");
  serverNameFields.forEach(
      serviceNameField -> {
        final ServiceName serviceNameAnnotation =
            serviceNameField.getAnnotation(ServiceName.class);
        final String serviceName = serviceNameAnnotation.value();
        final boolean withLabel = serviceNameField.isAnnotationPresent(WithLabel.class);
        final boolean withLabels = serviceNameField.isAnnotationPresent(WithLabels.class);
        if (isServiceNameOnly(withLabel, withLabels)) {
          resolveByServiceName(bean, env, client, serviceNameField, serviceName);
        } else {
          resolveServiceByLabelOnly(bean, env, client, serviceNameField, withLabel, withLabels);
        }
      });
}
 
開發者ID:amoAHCP,項目名稱:vxms,代碼行數:19,代碼來源:KubeDiscovery.java

示例11: resolveServiceByLabelOnly

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
private static void resolveServiceByLabelOnly(
    Object bean,
    JsonObject env,
    KubernetesClient client,
    Field serviceNameField,
    boolean withLabel,
    boolean withLabels)
    throws KubernetesClientException {
  final Map<String, String> labels =
      getLabelsFromAnnotation(env, serviceNameField, withLabel, withLabels);
  final ServiceList serviceListResult = getServicesByLabel(labels, client);
  Optional.ofNullable(serviceListResult)
      .ifPresent(
          list -> {
            if (!list.getItems().isEmpty() && list.getItems().size() == 1) {
              final Service serviceEntry = list.getItems().get(0);
              resolveHostAndSetValue(bean, env, serviceNameField, serviceEntry);
            } else if (!list.getItems().isEmpty() && list.getItems().size() > 1) {
              handleNonUniqueLabelsError(labels);
            }
          });
}
 
開發者ID:amoAHCP,項目名稱:vxms,代碼行數:23,代碼來源:KubeDiscovery.java

示例12: logLastLines

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
/**
 * Log the last lines of containers logs
 */
private void logLastLines(List<ContainerStatus> containers, String podId, String namespace, KubernetesSlave slave,
                          Map<String, Integer> errors, KubernetesClient client) {
    for (ContainerStatus containerStatus : containers) {
        String containerName = containerStatus.getName();
        PrettyLoggable<String, LogWatch> tailingLines = client.pods().inNamespace(namespace)
                .withName(podId).inContainer(containerStatus.getName()).tailingLines(30);
        String log = tailingLines.getLog();
        if (!StringUtils.isBlank(log)) {
            String msg = errors != null ? String.format(" exited with error %s", errors.get(containerName))
                    : "";
            LOGGER.log(Level.SEVERE,
                    "Error in provisioning; agent={0}, template={1}. Container {2}{3}. Logs: {4}",
                    new Object[]{slave, slave.getTemplate(), containerName, msg, tailingLines.getLog()});
        }
    }
}
 
開發者ID:carlossg,項目名稱:jenkins-kubernetes-plugin,代碼行數:20,代碼來源:KubernetesLauncher.java

示例13: runWithOverriddenNamespace

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
@Test
public void runWithOverriddenNamespace() throws Exception {
    String overriddenNamespace = testingNamespace + "-overridden-namespace";
    KubernetesClient client = cloud.connect();
    // Run in our own testing namespace
    if (client.namespaces().withName(overriddenNamespace).get() == null) {
        client.namespaces().createOrReplace(
                new NamespaceBuilder().withNewMetadata().withName(overriddenNamespace).endMetadata().build());
    }

    WorkflowJob p = r.jenkins.createProject(WorkflowJob.class, "overriddenNamespace");
    p.setDefinition(new CpsFlowDefinition(loadPipelineScript("runWithOverriddenNamespace.groovy"), true));

    WorkflowRun b = p.scheduleBuild2(0).waitForStart();
    assertNotNull(b);
    NamespaceAction.push(b, overriddenNamespace);

    r.assertBuildStatusSuccess(r.waitForCompletion(b));
    r.assertLogContains(overriddenNamespace, b);
}
 
開發者ID:carlossg,項目名稱:jenkins-kubernetes-plugin,代碼行數:21,代碼來源:KubernetesPipelineTest.java

示例14: runWithStepOverriddenNamespace

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
@Test
/**
 * Step namespace should have priority over anything else.
 */
public void runWithStepOverriddenNamespace() throws Exception {
    String overriddenNamespace = testingNamespace + "-overridden-namespace";
    String stepNamespace = testingNamespace + "-overridden-namespace2";
    KubernetesClient client = cloud.connect();
    // Run in our own testing namespace
    if (client.namespaces().withName(stepNamespace).get() == null) {
        client.namespaces().createOrReplace(
                new NamespaceBuilder().withNewMetadata().withName(stepNamespace).endMetadata().build());
    }

    WorkflowJob p = r.jenkins.createProject(WorkflowJob.class, "stepOverriddenNamespace");
    p.setDefinition(new CpsFlowDefinition(loadPipelineScript("runWithStepOverriddenNamespace.groovy")
            .replace("OVERRIDDEN_NAMESPACE", stepNamespace), true));

    WorkflowRun b = p.scheduleBuild2(0).waitForStart();
    assertNotNull(b);
    NamespaceAction.push(b, overriddenNamespace);

    r.assertBuildStatusSuccess(r.waitForCompletion(b));
    r.assertLogContains(stepNamespace, b);
}
 
開發者ID:carlossg,項目名稱:jenkins-kubernetes-plugin,代碼行數:26,代碼來源:KubernetesPipelineTest.java

示例15: createAndSaveKubernetesAppDeployers

import io.fabric8.kubernetes.client.KubernetesClient; //導入依賴的package包/類
protected Deployer createAndSaveKubernetesAppDeployers(String account,
		KubernetesDeployerProperties kubernetesProperties) {
	KubernetesClient kubernetesClient = new DefaultKubernetesClient()
			.inNamespace(kubernetesProperties.getNamespace());
	ContainerFactory containerFactory = new DefaultContainerFactory(
			kubernetesProperties);
	KubernetesAppDeployer kubernetesAppDeployer = new KubernetesAppDeployer(
			kubernetesProperties, kubernetesClient, containerFactory);
	Deployer deployer = new Deployer(account, "kubernetes", kubernetesAppDeployer);
	deployer.setDescription(
			String.format("master url = [%s], namespace = [%s], api version = [%s]",
					kubernetesClient.getMasterUrl(), kubernetesClient.getNamespace(),
					kubernetesClient.getApiVersion()));
	return deployer;
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-skipper,代碼行數:16,代碼來源:KubernetesPlatformAutoConfiguration.java


注:本文中的io.fabric8.kubernetes.client.KubernetesClient類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。