Ket*_*har 4 java kubernetes kubernetes-pod kubernetes-cluster
我正在使用 Kubernetes Java 客户端 API https://github.com/kubernetes-client/java来获取所有存在的命名空间。我收到错误-
io.kubernetes.client.ApiException: java.net.ConnectException: Failed to connect to localhost/127.0.0.1:443
at io.kubernetes.client.ApiClient.execute(ApiClient.java:801)
at io.kubernetes.client.apis.CoreV1Api.listNamespaceWithHttpInfo(CoreV1Api.java:15939)
at io.kubernetes.client.apis.CoreV1Api.listNamespace(CoreV1Api.java:15917)
at com.cloud.kubernetes.KubernetesNamespacesAPI.fetchAllNamespaces(KubernetesNamespacesAPI.java:25)
at com.cloud.spark.sharedvariable.ClouzerConfigurations.setKubernetesEnvironment(ClouzerConfigurations.java:45)
Run Code Online (Sandbox Code Playgroud)
我尝试创建集群角色绑定并向用户授予权限。
这是我的代码片段:
public static List<String> fetchAllNamespaces(){
try {
return COREV1_API.listNamespace(null, "true", null, null, null, 0, null, Integer.MAX_VALUE, Boolean.FALSE)
.getItems().stream().map(v1Namespace -> v1Namespace.getMetadata().getName())
.collect(Collectors.toList());
}catch(Exception e) {
e.printStackTrace();
return new ArrayList<>();
}
}
Run Code Online (Sandbox Code Playgroud)
如果我遗漏了什么,请告诉我。提前致谢。
小智 6
我也面临着同样的例外。在对客户端库的源代码进行多次调查之后,我认为您需要确定两件事。
您使用哪种方式配置连接
这里的第一件事可能与您的案例或库无关。api 客户端库支持三种配置方式,可以从 pod 内部或集群外与 K8S apiserver 进行通信。
如果您在 Pod 内使用该库,通常它会尝试使用第三种方式。
你如何引导你的客户。
您必须记住调用
Configuration.setDefaultApiClient(apiClient);
Run Code Online (Sandbox Code Playgroud)
在初始化 CoreV1Api 或 CRD api 之前。原因很简单,因为在所有的Api类下,例如io.kubernetes.client.api.CoreV1Api类下
public class CoreV1Api {
private ApiClient apiClient;
public CoreV1Api() {
this(Configuration.getDefaultApiClient());
}
...
}
Run Code Online (Sandbox Code Playgroud)
如果您没有设置配置的defaultApiClient,它将使用所有默认配置,其中basePath将为localhost:443,然后您将面临错误。
在示例包下,客户已经创建了很多示例和用例。完整的配置逻辑可能如下:
public class Example {
public static void main(String[] args) throws IOException, ApiException {
ApiClient client = Config.defaultClient();
Configuration.setDefaultApiClient(client);
// now you are safe to construct a CoreV1Api.
CoreV1Api api = new CoreV1Api();
V1PodList list =
api.listPodForAllNamespaces(null, null, null, null, null, null, null, null, null);
for (V1Pod item : list.getItems()) {
System.out.println(item.getMetadata().getName());
}
}
}
Run Code Online (Sandbox Code Playgroud)
请记住,如果您使用默认构造函数来初始化 XXXApi,顺序很重要。