【Error】 the public key is not available: NO_PUBKEY 4F4EA0AAE5267A6C

安装了php第三方源后apt-get update遇到如下错误:

$ sudo apt-get update -y
Hit:1 http://downloads.metasploit.com/data/releases/metasploit-framework/apt lucid InRelease
Get:2 http://security.ubuntu.com/ubuntu xenial-security InRelease [107 kB]
Hit:3 http://archive.ubuntu.com/ubuntu xenial InRelease
Get:4 http://ppa.launchpad.net/ondrej/php/ubuntu xenial InRelease [23.9 kB]
Get:5 http://archive.ubuntu.com/ubuntu xenial-updates InRelease [109 kB]
Ign:4 http://ppa.launchpad.net/ondrej/php/ubuntu xenial InRelease
Get:6 http://archive.ubuntu.com/ubuntu xenial-backports InRelease [107 kB]
Fetched 347 kB in 2s (140 kB/s)
Reading package lists... Done
W: GPG error: http://ppa.launchpad.net/ondrej/php/ubuntu xenial InRelease: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 4F4EA0AAE5267A6C
W: The repository 'http://ppa.launchpad.net/ondrej/php/ubuntu xenial InRelease' is not signed.
N: Data from such a repository can't be authenticated and is therefore potentially dangerous to use.
N: See apt-secure(8) manpage for repository creation and user configuration details.

解决办法:

$ apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4F4EA0AAE5267A6C
Executing: /tmp/tmp.wyAfMZc8sV/gpg.1.sh --keyserver
keyserver.ubuntu.com
--recv-keys
4F4EA0AAE5267A6C
gpg: requesting key E5267A6C from hkp server keyserver.ubuntu.com
gpg: key E5267A6C: public key "Launchpad PPA for Ond\xc5\x99ej Sur�" imported
gpg: Total number processed: 1
gpg:               imported: 1  (RSA: 1)

参考:://www.virtualmin.com/node/42118

<think>嗯,用户遇到了在Ubuntu系统使用sudo apt update时出现NO_PUBKEY 3B4FE6ACC0B21F32的错误。这个问题通常是因为系统缺少对应的公钥,导致无法验证软件包的签名。首先,我需要回忆一下处理这类问题的常见方法。根据之前看到的引用资料,解决方法主要是通过apt-key命令从密钥服务器下载缺失的公钥。比如引用[2]和[3]提到使用apt-key adv命令配合keyserver.ubuntu.com来获取密钥。 接下来,用户可能需要具体的步骤指导,所以应该分步骤说明如何操作。比如第一步是执行sudo apt-key adv命令,指定正确的密钥服务器地址和缺失的密钥ID。这里需要注意密钥服务器的端口,引用[3]中使用了hkp://keyserver.ubuntu.com:80,而其他引用可能省略了端口,但默认应该是可行的。 另外,需要确认用户是否需要同时处理多个密钥,比如引用[4]和[5]提到了同时处理两个公钥的情况,但当前用户的问题只涉及3B4FE6ACC0B21F32。不过可能需要提醒用户如果有多个缺失,可以一并添加。 还需要注意命令的正确性,比如--recv-keys后面是否要加空格,或者是否应该用--recv。根据不同的引用,有的用--recv-keys,有的用--recv,可能需要统一。查阅man apt-key的话,应该是apt-key adv --keyserver ... --recv-keys KEYID,所以正确的命令应该是sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32。 另外,更新完成后需要再次运行sudo apt update来验证是否解决问题,这也是必要的步骤。同时,如果用户更换了软件源,比如清华源,可能需要检查源列表是否正确,避免其他错误。 可能用户的问题根源在于更换了软件源之后没有导入对应的公钥,所以补充说明这一点会有帮助。例如引用[3]提到更换清华源时出现的问题,用户可能是在换源后遇到此错误,因此需要导入新源的公钥。 最后,生成的相关问题要覆盖可能相关的其他情况,比如多个密钥缺失、其他解决方法如手动下载密钥、不同密钥服务器的选择等,这样可以提供更全面的信息。例如引用[5]中提到了另一个密钥40976EAF437D05B5,用户可能在后续遇到类似问题,所以相关问题可以包括同时添加多个密钥的情况。</think>### 分步解决方案: 当Ubuntu系统出现`NO_PUBKEY 3B4FE6ACC0B21F32`错误时,说明缺少用于验证软件包签名的公钥。以下是具体解决步骤: 1. **从密钥服务器下载缺失的公钥** 打开终端,运行以下命令(将`3B4FE6ACC0B21F32`替换为实际报错的公钥ID): ```bash sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32 ``` 此命令会从Ubuntu官方密钥服务器获取公钥并添加到本地信任列表中[^2][^3]。 2. **更新软件源列表** 完成公钥添加后,重新运行更新命令: ```bash sudo apt update ``` 此时应不再报错,系统可正常验证软件包签名。 3. **检查软件源配置(可选)** 若问题因更换软件源(如清华源、阿里云源)导致,需检查`/etc/apt/sources.list`文件中的源地址是否完整且与密钥匹配[^3][^4]。 --- ### 其他注意事项 - **多密钥缺失**:若同时缺少多个公钥(如`3B4FE6ACC0B21F32`和`40976EAF437D05B5`),可一次性下载: ```bash sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32 40976EAF437D05B5 ``` 参考[^5]。 - **网络问题**:若默认密钥服务器访问失败,可尝试更换端口(如`hkp://keyserver.ubuntu.com:80`)。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值