使用kubectl连接到远程kubernetes群集时由未知机构签署的证书

使用kubectl连接到远程kubernetes群集时由未知机构签署的证书,kubernetes,Kubernetes,我正在使用kubectl连接远程kubernetes群集(v1.15.2),我正在将配置从远程服务器复制到本地macOS: scp -r root@ip:~/.kube/config ~/.kube 并将url更改为https://kube-ctl.example.com,我向internet公开了api服务器: apiVersion: v1 clusters: - cluster: certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZ

我正在使用kubectl连接远程kubernetes群集(v1.15.2),我正在将配置从远程服务器复制到本地macOS:

scp -r root@ip:~/.kube/config ~/.kube
并将url更改为
https://kube-ctl.example.com
,我向internet公开了api服务器:

apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSURvakNDQW9xZ0F3SUJBZ0lVU3FpUlZSU3FEOG1PemRCT1MyRzlJdGE0R2Nrd0RRWUpLb1pJaHZjTkFRRUwKQlFB92FERUxNQWtHQTFVRUJoTUNRMDR4RURBT0JnTlZCQWdUQjBKbGFVcHBibWN4RURBT0JnTlZCQWNUQjBKbAphVXBwYm1jeEREQUtCZ05WQkFvVEEyczRjekVTTUJBR0ExVUVDeE1KTkZCaGNtRmthV2R0TVJNd0VRWURWUVFECkV3cHJkV0psY201bGRHVnpNQ0FYR3RFNU1Ea3hNekUxTkRRd01Gb1lEekl4TVRrd09ESXdNVFUwTkRBd1dqQm8KTVFzd0NRWURWUVFHRXdKRFRqRVFNQTRHQTFVRUNCTUhRbVZwU21sdVp6RVFNQTRHQTFVRUJ4TUhRbVZwU21sdQpaekVNTUFvR0ExVUVDaE1EYXpoek1SSXdFQVlEVlFRTEV3azBVR0Z5WVdScFoyMHhFekFSQmdOVkJBTVRDbXQxClltVnlibVYwWlhNd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUJBUUNzOGFFR2R2TUgKb0E1eTduTjVydnAvQkEyTVM1RG1TNWwzQ0p4S3VMOGJ1bkF3alF1c0lTalUxVWlqeVdGOW03VzA3elZJaVJpRwpiYzZGT3JkSEJ2QXgzazBpT2pPRlduTHp1UjdaSFhqQ3lTbDJRam9YN3gzL0l1MERQelNHTXJLSzZETGpTRTk4CkdadEpjUi9OSmpiVFFJc3FXbWFEdUIyc3dmcEc1ZmlZU1A1KzVpcld1TG1pYjVnWnJYeUJJNlJ0dVV4K1NvdW0KN3RDKzJaVG5QdFF0QnFUZHprT3p3THhwZ0Zhd1kvSU1mbHBsaUlMTElOamcwRktxM21NOFpUa0xvNXcvekVmUApHT25GNkNFWlR6bkdrTWc2aUVGenNBcDU5N2lMUDBNTkR4YUNjcTRhdTlMdnMzYkdOZmpqdDd3WkxIVklLa0lGCm44Mk92cExGaElq2kFnTUJBQUdqUWpCQU1BNEdBMVVkRHdFQi93UUVBd0lCQmpBUEJnTlZIUk1CQWY4RUJUQUQKQVFIL01CMEdBMVVkRGdRV0JCUm0yWHpJSHNmVzFjMEFGZU9SLy9Qakc4dWdzREFOQmdrcWhraUc5dzBCQVFzRgpBQU9DQVFFQW1mOUozN3RYTys1dWRmT2RLejdmNFdMZyswbVJUeTBRSEVIblk5VUNLQi9vN2hLUVJHRXI3VjNMCktUeGloVUhvbHY1QzVUdG8zbUZJY2FWZjlvZlp0VVpvcnpxSUFwNE9Od1JpSnQ1Yk94K1d6SW5qN2JHWkhnZjkKSk8rUmNxQnQrUWsrejhTMmJKRG04WFdvMW5WdjJRNU1pUndPdnRIbnRxd3MvTlJ2bHBGV25ISHBEVExjOU9kVwpoMllzWVpEMmV4d0FRVDkxSlExVjRCdklrZGFPeW9USHZ6U2oybThSTzh6b3JBd09kS1NTdG9TZXdpOEhMeGI2ClhmaTRFbjR4TEE3a3pmSHFvcDZiSFF1L3hCa0JzYi9hd29kdDJKc2FnOWFZekxEako3S1RNYlQyRW52MlllWnIKSUhBcjEyTGVCRGRHZVd1eldpZDlNWlZJbXJvVnNRPT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
    server: https://k8s-ctl.example.com
  name: kubernetes
contexts:
- context:
    cluster: kubernetes
    namespace: kube-system
    user: admin
  name: kubernetes
current-context: kubernetes
kind: Config
preferences: {}
users:
- name: admin
  user:
当我在本地Mac中获取集群pod信息时:

kubectl get pods --all-namespaces
请给出以下错误:

Unable to connect to the server: x509: certificate signed by unknown authority
当我访问
https://k8s-ctl.example.com
在google chrome中,结果是:

{
kind: "Status",
apiVersion: "v1",
metadata: { },
status: "Failure",
message: "Unauthorized",
reason: "Unauthorized",
code: 401
}
我应该如何使用kubectl客户端成功访问远程k8s群集

有一种方法我尝试使用这个
.kube/config
通过命令生成,但得到了相同的结果:

apiVersion: v1
clusters:
- cluster:
    certificate-authority: ssl/ca.pem
    server: https://k8s-ctl.example.com
  name: default
contexts:
- context:
    cluster: default
    user: admin
  name: default
current-context: default
kind: Config
preferences: {}
users:
- name: admin
  user:
    client-certificate: ssl/admin.pem
    client-key: ssl/admin-key.pem

当kubectl与kube API服务器交互时,它将验证kube API服务器证书,并将
客户端证书中的证书发送到kube API服务器,以进行相互TLS身份验证。我认为问题在于以下两个方面

  • 用于生成
    客户端证书的ca
    不是用于启动kube API服务器的ca
  • 证书颁发机构数据中的ca
    不是用于生成kube API服务器证书的ca

  • 如果您确保使用相同的ca来生成所有证书,那么它应该可以正常工作

    我重复了您的问题,并且在您创建集群时,您需要按照以下步骤从不同的控制台访问集群

    首先,您必须复制在将集群引导到本地计算机中的
    ~/.kube/
    目录时创建的以下证书:

    ca.pem
    admin.pem
    admin-key.pem
    
    将这些文件复制到本地计算机后,执行以下命令:

    kubectl config set-cluster kubernetes-the-hard-way \
      --certificate-authority=~/.kube/ca.pem \
      --embed-certs=true \
      --server=https://${KUBERNETES_PUBLIC_ADDRESS}:6443
    

    注意,您必须用集群的远程地址替换
    ${KUBERNETES\u PUBLIC\u ADDRESS}
    变量

    我正在用艰难的方式安装kubernetes@阿尔吉亚萨杜
    kubectl config set-credentials admin \
      --client-certificate=~/.kube/admin.pem \
      --client-key=~/.kube/admin-key.pem
    
    kubectl config set-context kubernetes-the-hard-way \
      --cluster=kubernetes-the-hard-way \
      --user=admin
    
    kubectl config use-context kubernetes-the-hard-way