我按照https://cloud.r-project.org/bin/linux/ubuntu/README.html安装 R
$ echo "deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/" | sudo tee -a /etc/apt/sources.list
$ sudo apt-get update
...
Err:14 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/ InRelease
The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 51716619E084DAB9
Reading package lists... Done
E: The repository 'http://ppa.launchpad.net/adrozdoff/emacs/ubuntu bionic Release' does not have a Release file.
N: Updating from such a repository can't be done securely, and is therefore disabled by default.
N: See apt-secure(8) manpage for repository creation and user configuration details.
N: Skipping acquire of configured file 'contrib/binary-i386/Packages' as repository 'https://download.virtualbox.org/virtualbox/debian bionic InRelease' doesn't support architecture 'i386'
W: GPG error: https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/ InRelease: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 51716619E084DAB9
E: The repository 'https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/ InRelease' is not signed.
N: Updating from such a repository can't be done securely, and is therefore disabled by default.
N: See apt-secure(8) manpage for repository creation and user configuration details.
...
$ sudo apt-get install r-base
错误消息是否apt-get update
意味着我必须为存储库添加公钥?
如果我离开它会有什么后果?
为什么我还能跑apt-get install r-base
?
为什么以下失败?
$ sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 51716619E084DAB9
Executing: /tmp/apt-key-gpghome.Z9eYn6e4zV/gpg.1.sh --keyserver keyserver.ubuntu.com --recv-keys 51716619E084DAB9
gpg: keyserver receive failed: Server indicated a failure
谢谢。
我在 gogle 上发现了这个(西班牙语):
正如我在控制台的日志中看到的那样,您必须添加一些键(不仅与 R 相关,也许其他的与程序的依赖关系有关)
该页面说的是密钥管理器,可以轻松解决添加密钥的问题:
你应该做这个:
然后:
我还在这里找到了另一种方式(英语,askubuntu 论坛;请参阅接受的答案)
我希望这可以解决您的问题。
UBUNTU PACKAGES FOR R中提到的存储库包括最新版本 3.6。但是,对于 18.04,Ubuntu 的 Universe 存储库仍然有 v3.4。即使您不添加 R 的官方存储库,您仍然可以安装 r-base,但显然那将是 v3.4。
是的,如果您想继续使用该存储库。APT 是一个非常安全的包管理工具。它使用该公钥来验证下载的包。如需完整文档,请阅读SecureAPT - Debian。
APT 将继续抱怨,您将无法从 R 的官方存储库下载软件包。
因为 r-base 在 Ubuntu 的 Universe 存储库中也可用。您可以运行
apt-cache policy r-base
以检查您将从哪个存储库获得哪个版本。似乎是一个临时的服务器端问题。我尝试使用相同的命令添加密钥,它成功了。
签署您的存储库只是使其安全和验证包的另一种方法。官方存储库将始终具有 gpg 密钥。如果您拥有一个存储库,您可以选择是否要在您的组织中维护证书和签名方法。
默认情况下,apt 将始终查找 gpg,如果没有它,它将忽略存储库的内容。您可以通过将
--allow-unauthenticated
选项添加到 apt-get 来跳过 gpg 检查。这需要 sudo 操作。示例:
sudo apt-get --allow-unauthenticated upgrade
,sudo apt-get -y --allow-unauthenticated install foo
.您也可以通过在
/etc/apt/apt.conf.d/
目录中使用您自己的配置文件来使此选项永久化。在您的 conf 文件中只需添加
APT::Get::AllowUnauthenticated "true";
节。我可以通过此处和r-project站点中提供的以下说明解决此问题(2021 年 1 月) 。总结是
但它失败了:“gpg:密钥服务器接收失败:服务器指示失败”
根据信息。在 r-project 站点,这可能是由于“防火墙阻止了端口 11371”。在这种情况下,可以做的是:
0xE19F5F87128899B192B1A2C2AD5F960A256A04AF
在https://keyserver.ubuntu.com上搜索。4 [编辑]。添加存储库。这里有点棘手。该命令的公式为:
我在哪里找到了不同的选项,例如
deb https://cloud.r-project.org/bin/linux/debian buster-cran35/
deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/
deb http://cloud.r-project.org/bin/linux/debian buster-cran40/
等。取决于您想要的系统和版本。
5.安装R