SSLError & ClosedPoolError

分析日志

从您提供的日志文件内容来看,存在几个明显的问题导致了实例无法创建:

  1. SSL证书验证失败 :日志中多次出现SSLError(SSLError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:897)'),)错误。这表明客户端在尝试与 Kubernetes API 服务器建立安全连接时,无法验证服务器的 SSL 证书。这可能是因为客户端没有正确配置信任的 CA 证书,或者服务器提供的证书不被客户端信任。

  2. API服务器节点不可用 :错误K8sConnectionFailed('No more API server nodes in the cluster',)表明尝试连接到 Kubernetes 集群的 API 服务器时,没有可用的节点。这可能意味着所有的 API 服务器实例都已宕机或无法访问。

  3. 连接重试失败 :日志中的MaxRetryError表明在尝试重新连接到 Kubernetes API 服务器时,已达到最大重试次数而未能成功建立连接。

  4. 集群信息获取失败RetryFailedError: 'Exceeded retry deadline'WARNING: Can not get cluster from dcs表明在尝试获取集群信息时,重试已超过截止时间,且无法从分布式配置存储(DCS)中获取集群信息。

  5. 连接池关闭ClosedPoolError("HTTPSConnectionPool(host='KUBERNETES_PORT_443_TCP_ADDR', port=443): Pool is closed.",)表明尝试重用连接池时,连接池已被关闭。

解决这些问题通常需要以下步骤:

  • 检查并确保 Kubernetes API 服务器的 SSL 证书被客户端正确信任。
  • 检查 Kubernetes 集群的状态,确保 API 服务器节点是活跃且可访问的。
  • 检查网络连接和防火墙设置,确保没有网络问题阻止客户端与 API 服务器的通信。
  • 如果问题依旧存在,可能需要联系集群管理员或查看 Kubernetes 集群的详细日志来进一步诊断问题。

openssl s_client -connect 246.96.0.1:443 -showcerts -CAfile ./ca.crt

该命令使用 OpenSSL 的 s_client 工具来与远程服务器建立一个 SSL/TLS 连接。下面是命令参数的详细解析:

  • openssl: 这是调用 OpenSSL 工具的命令,OpenSSL 是一个用于安全套接字层加密的开源工具包。

  • s_client: 这是 OpenSSL 工具中的一个子命令,用于作为一个简单的 SSL/TLS 客户端与服务器进行通信。

  • -connect: 这个选项告诉 s_client 命令我们想要连接到一个远程服务器。

  • 246.96.0.1:443: 这是服务器的 IP 地址和端口号。在这个例子中,246.96.0.1 是服务器的 IP 地址,而 443 是 HTTPS 服务通常使用的端口号。

  • -showcerts: 这个选项会让 OpenSSL 显示服务器返回的所有证书(包括链中的任何中间证书),这对于验证服务器的身份非常有用。

  • -CAfile ./ca.crt: 这个选项指定了一个包含受信任的 CA(证书颁发机构)证书的文件。./ca.crt 是文件的路径,告诉 OpenSSL 应该信任这个文件中的 CA 证书来验证服务器的证书。

总的来说,这个命令尝试与 IP 地址为 246.96.0.1 的服务器上的 HTTPS 服务建立一个安全的连接,并使用本地指定的 CA 证书文件(./ca.crt)来验证服务器证书的有效性。如果服务器的证书与本地 CA 证书匹配,连接将成功建立,并且服务器的证书链将被显示出来。如果证书验证失败,连接将不会建立。

查看证书

ls -l /etc/pki/tls/certs

K8S PKI证书

/etc/kubernetes/ssl

在 Kubernetes 集群中,/etc/kubernetes/ssl 目录通常包含用于集群内各种组件之间安全通信的 SSL 证书和密钥。这些证书对于维护集群的安全性至关重要。如果这个目录中的证书过期,可能会有以下影响:

  1. 服务间通信失败:Kubernetes 集群中的各个组件(如 API 服务器、节点(Node)、控制平面组件等)使用这些证书进行安全通信。证书过期会导致这些组件之间的 TLS 握手失败,进而无法正常通信。

  2. API 访问问题 :如果 API 服务器的证书过期,集群外部的客户端(如 kubectl 命令行工具)将无法通过 HTTPS 与 API 服务器建立安全连接,导致无法执行任何管理任务。

  3. 节点加入受阻:新节点加入集群或现有节点重新加入时,需要验证集群的 CA 证书。如果 CA 证书过期,节点将无法通过验证,从而无法加入集群。

  4. 服务中断:由于组件间无法正常通信,可能会导致集群管理功能受损,影响集群的稳定性和运行的服务。

  5. 安全风险:过期的证书可能被中间人攻击者利用,危及集群的安全性。

  6. 自动化工具和 CI/CD 流程中断:许多自动化工具和持续集成/持续部署(CI/CD)流程依赖于与 Kubernetes API 服务器的通信。证书过期将导致这些流程中断。

  7. 监控和日志收集问题:如果用于监控和日志收集服务的证书过期,可能会导致这些服务无法正常运行,影响对集群状态的监控和日志的收集。

解决证书过期问题的步骤通常包括:

  • 检查证书过期日期 :使用 openssl 命令检查证书的有效期,例如 openssl x509 -in /etc/kubernetes/ssl/cert.pem -text -noout
  • 更新证书:如果证书即将过期或已经过期,需要联系证书颁发机构(CA)或使用集群的证书管理工具来更新证书。
  • 重新签发证书:在必要时,可能需要重新签发新的证书并替换旧的证书。
  • 更新集群组件配置:在更新证书后,需要确保集群中的所有组件都配置了新的证书路径或自动加载了新的证书。
  • 重启服务:在更新证书后,可能需要重启受影响的 Kubernetes 服务以使新证书生效。

在处理证书过期问题时,应确保对集群的影响最小化,并在维护窗口期间进行操作。同时,建议设置提醒或监控系统来跟踪证书的有效期,以避免此类问题的发生。

相关推荐
李少兄39 分钟前
Docker 命令总结:从入门到入土
docker·容器·eureka
想学习java初学者2 小时前
Docker compose部署elasticsearch(单机版)
运维·docker·容器
微刻时光4 小时前
Docker部署Nginx
运维·nginx·docker·容器·经验
小安运维日记4 小时前
CKA认证 | Day3 K8s管理应用生命周期(上)
运维·云原生·容器·kubernetes·云计算·k8s
陈小肚4 小时前
k8s 1.28.2 集群部署 docker registry 接入 MinIO 存储
docker·容器·kubernetes
小扳4 小时前
Docker 篇-Docker 详细安装、了解和使用 Docker 核心功能(数据卷、自定义镜像 Dockerfile、网络)
运维·spring boot·后端·mysql·spring cloud·docker·容器
politeboy5 小时前
关于k8s中镜像的服务端口被拒绝的问题
云原生·容器·kubernetes
weixin_438197385 小时前
K8S创建云主机配置docker仓库
linux·云原生·容器·eureka·kubernetes
南猿北者13 小时前
docker Network(网络)
网络·docker·容器
ggaofeng16 小时前
通过命令学习k8s
云原生·容器·kubernetes