0

0

K3s private registry 配置 tls 后出现 "x509: certificate signed by unknown"

冷炫風刃

冷炫風刃

发布时间:2026-01-21 19:27:09

|

200人浏览过

|

来源于php中文网

原创

K3s 中 containerd 拉取私有镜像仓库镜像时因不自动信任系统 CA 证书,需将自签名或内网 CA 证书(PEM 格式)放入 /var/lib/rancher/k3s/agent/etc/containerd/certs.d//ca.crt,路径须与镜像地址完全一致,并重启 k3s 生效。

k3s private registry 配置 tls 后出现 \

这是 K3s 连接私有镜像仓库(private registry)时启用 TLS 后最常见的证书错误。根本原因是 K3s 的 containerd 组件(而非 kubelet 或 API server)在拉取镜像时,**不自动信任系统 CA 证书**,也不加载主机上配置的 Docker-style `ca.crt`,它只认自己配置的证书路径。

确认证书来源是否被 containerd 识别

K3s 内嵌的 containerd 默认不会读取 /etc/ssl/certs/ca-certificates.crt 或用户手动放的证书文件。你必须显式告诉它:这个私有 registry 的证书由谁签发、证书文件在哪。

  • 私有 registry 使用自签名证书 → 需把该证书(如 my-registry.crt)拷贝到 K3s 节点的 /var/lib/rancher/k3s/agent/images/ 目录(K3s v1.25+ 推荐路径),或更通用的 /var/lib/rancher/k3s/agent/etc/containerd/certs.d/your-registry:port/ 下的 ca.crt
  • 私有 registry 使用内网 CA 签发(如企业内部 Root CA)→ 把该 Root CA 证书(不是中间证书,是最终签发者)放入上述路径
  • 用 Let’s Encrypt 或公网可信 CA → 不需要额外配置证书,但务必确保 registry 域名与证书 Subject Alternative Name(SAN)完全匹配(例如不能用 IP 访问带域名证书的地址)

正确配置 containerd 的 registry 证书目录结构

K3s v1.21+ 使用 containerd 的 certs.d 机制,路径必须严格匹配 registry 地址(含端口)。例如 registry 地址是 harbor.internal:8443

  • 创建目录:sudo mkdir -p /var/lib/rancher/k3s/agent/etc/containerd/certs.d/harbor.internal:8443
  • 放入证书:sudo cp harbor-ca.crt /var/lib/rancher/k3s/agent/etc/containerd/certs.d/harbor.internal:8443/ca.crt
  • 确保权限为 root:root,且 ca.crt 是 PEM 格式(以 -----BEGIN CERTIFICATE----- 开头)

⚠️ 注意:路径中的域名和端口必须和你在 docker pull 或 YAML 中写的 image 名字**完全一致**(比如写的是 harbor.internal/v1/nginx:latest,那就用 harbor.internal;如果写了端口,如 harbor.internal:8443,路径里也必须带 :8443)。

Viggle AI
Viggle AI

Viggle AI是一个AI驱动的3D动画生成平台,可以帮助用户创建可控角色的3D动画视频。

下载

重启 containerd 并验证配置生效

K3s 不会自动重载 containerd 的 certs.d 配置,修改后需重启 K3s(它会连带重启 containerd):

  • sudo systemctl restart k3s(systemd 环境)
  • 等几秒后检查 containerd 是否已加载新配置:sudo crictl pull harbor.internal:8443/myapp:latest
  • 如果仍报 x509 错误,用 sudo ctr --namespace=k8s.io images pull harbor.internal:8443/myapp:latest 测试(ctr 是 containerd 原生命令,错误信息更直接)
  • 还可临时进入 containerd 容器(sudo nsenter -n -t $(pgrep containerd) -c sh)检查 /etc/containerd/certs.d/ 挂载是否可见(K3s 会 bind mount 上述路径)

其他易忽略点

即使证书路径对了,以下情况也会触发相同错误:

  • 证书过期 → 用 openssl x509 -in ca.crt -text -noout | grep "Not After" 检查有效期
  • 证书链不完整 → 如果 registry 用了中间 CA,ca.crt 文件里应包含 Root CA + 所有中间证书(按顺序拼接,每个以 -----BEGIN CERTIFICATE----- 开始)
  • registry DNS 解析异常 → 在节点上执行 curl -v https://harbor.internal:8443/v2/,看是否能建立 TLS 连接并返回 401(说明证书已信任,只是没鉴权)
  • K3s 启动参数覆盖了默认配置 → 检查 /etc/systemd/system/k3s.service 中是否有 --containerd 或自定义 containerd.toml,避免配置冲突

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

230

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

499

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3510

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

21

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

23

2026.01.13

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

Docker 17 中文开发手册
Docker 17 中文开发手册

共0课时 | 0人学习

极客学院Docker视频教程
极客学院Docker视频教程

共33课时 | 17.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号