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


相关推荐
杨了个杨898225 分钟前
nginx常见功能部署
运维·服务器·nginx
小天源2 小时前
linux漏洞一键扫描
linux·运维·服务器·漏洞扫描
eWidget2 小时前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
m0_696212683 小时前
个人微信api
运维·服务器
en-route3 小时前
SSH Key 与 GPG Key 区别详解:Git 使用中的身份与签名机制
运维·git·ssh
小白鸽i5 小时前
【LINUX】将源码驱动文件编译并生效
linux·运维·服务器
做萤石二次开发的哈哈6 小时前
萤石开放平台 音视频 | 产品概述
运维·服务器·萤石云·萤石·萤石开放平台
0思必得06 小时前
[Web自动化] 处理爬虫异常
运维·爬虫·python·selenium·自动化·web自动化
胡斌附体6 小时前
linux(ubuntu)拉取源码进行docker容器部署
linux·git·ubuntu·docker·node·nvm
开发者联盟league7 小时前
k8s 创建token
云原生·容器·kubernetes