docker源文件配置以及密钥文件

从镜像站下载密钥

1️⃣ 重新导入正确的 Docker 公钥

如果你想使用 清华镜像站 ,可以使用以下命令下载并导入 docker-ce 的公钥:

bash 复制代码
curl -fsSL https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu/gpg | sudo tee /etc/apt/trusted.gpg.d/docker.asc
2️⃣ 如果使用 Docker 官方公钥,执行以下命令
bash 复制代码
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo tee /etc/apt/trusted.gpg.d/docker.asc

这将把 Docker 官方的 GPG 公钥添加到你的系统中。

3️⃣ 清理缓存并更新包列表

重新导入公钥后,运行以下命令来清理和更新包列表:

bash 复制代码
sudo apt clean
sudo apt update

4️⃣ 检查镜像源配置(如果需要)

如果你使用的是 清华镜像站 ,确保你的 Docker 配置文件指向正确的镜像源。你可以检查 /etc/apt/sources.list.d/docker.list 文件,确保它指向正确的镜像:

bash 复制代码
cat /etc/apt/sources.list.d/docker.list

示例(如果是清华镜像源):

text 复制代码
deb [arch=amd64] https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu/ $(lsb_release -cs) stable

如果你要使用 Docker 官方源:

text 复制代码
deb [arch=amd64] https://download.docker.com/linux/ubuntu/ $(lsb_release -cs) stable

5️⃣ 如果问题依旧

如果问题依旧存在,检查 /etc/apt/trusted.gpg.d/ 目录下的密钥文件,确保没有错误的密钥文件并重新尝试添加正确的公钥:

bash 复制代码
ls /etc/apt/trusted.gpg.d/

然后清理掉无效的密钥文件,保留有效的密钥文件(例如 docker.asc)。

docker.list中存储密钥的位置和实际不符合

问题出在 signed-by=/etc/apt/keyrings/docker.asc 的设置上。由于你将 Docker 公钥存储在 /etc/apt/keyrings/ 目录下,而不是传统的 /etc/apt/trusted.gpg.d/ 目录,所以 apt 可能无法正确识别该公钥。

解决步骤:

1️⃣ 将公钥移动到 /etc/apt/trusted.gpg.d/

如果你希望使用传统的 trusted.gpg.d/ 目录来存储 Docker 公钥,你需要将它从 keyrings/ 目录中移动到 trusted.gpg.d/ 目录:

bash 复制代码
sudo mv /etc/apt/keyrings/docker.asc /etc/apt/trusted.gpg.d/docker.asc
2️⃣ 检查并更新 Docker 仓库配置

接着,确认 /etc/apt/sources.list.d/docker.list 文件中的源配置是正确的。你可以直接用编辑器打开并确认:

bash 复制代码
sudo nano /etc/apt/sources.list.d/docker.list

确保它的内容如下:

text 复制代码
deb [arch=amd64] https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu noble stable

注意,移除 signed-by=/etc/apt/keyrings/docker.asc 部分,因为我们已经将公钥放到了 trusted.gpg.d 目录中。

3️⃣ 更新包列表

完成上述步骤后,运行以下命令更新包列表:

bash 复制代码
sudo apt update

4️⃣ 验证是否解决问题

如果成功,apt update 命令应该不再出现 NO_PUBKEY 错误,Docker 仓库的签名也能正常验证。


相关推荐
SkyWalking中文站10 小时前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
程序员老赵12 小时前
Docker 部署 Redmine:老牌开源项目管理部署实测记录
docker·开源·团队管理
程序员老赵14 小时前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
火车叼位14 小时前
写给初级开发者:SSL、SSH、HTTPS 与证书体系全解析
运维
小猿姐1 天前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生
SkyWalking中文站2 天前
认识 Horizon UI · 5/17:3D 基础设施地图
运维·监控·自动化运维
SkyWalking中文站2 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控
雪梨酱QAQ3 天前
Kubeneters HA Cluster部署
运维
lichenyang4533 天前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4533 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器