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 仓库的签名也能正常验证。


相关推荐
SPC的存折3 分钟前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_4 分钟前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
sszdzq21 分钟前
docker 安装 doris
运维·docker·容器
dashizhi20151 小时前
共享文件禁止拖动本地磁盘、共享文件禁止另存为、禁止打印共享文件、禁止复制共享文件的方法
运维·服务器·网络·安全·电脑
IMPYLH2 小时前
Linux 的 nproc 命令
linux·运维·服务器·bash
AC赳赳老秦2 小时前
OpenClaw email技能:批量发送邮件、自动回复,高效处理工作邮件
运维·人工智能·python·django·自动化·deepseek·openclaw
海的透彻3 小时前
docker容器进程探究
运维·docker·容器
大强同学3 小时前
Obsidian 日记:从模板到 Dataview 自动化
运维·自动化
陌陌卡上3 小时前
我在 Debian 11 上把 K8s 单机搭起来了,过程没你想的那么顺(/opt 目录版)
运维·k8s·系统·debian11
❀͜͡傀儡师3 小时前
ShadowBroker:实时全球情报地图,开源情报(OSINT)的终极聚合平台
docker·容器·llama