R 尝试从 Artifactory 安装旧的不可用包

R tries to install old not available packages from Artifactory

解决方案

删除 Artifactory 缓存中的 .RDS


问题

我在 Ubuntu 和 CRAN 的公司镜像上使用 R 3.6.2 时遇到了一个非常奇怪的问题。假设我 运行 以下命令:

install.packages('rlang')

我得到的结果是无法找到版本 0.4.2。当我手动查看存储库时,我发现 0.4.2 确实不存在,但 0.4.3 确实存在。首先我认为存储库存储索引的 PACKAGES 文件有问题。但我调查了一下,它指向 rlang.

的正确可用版本

当执行 install.packages() 时,R 从哪里获取它放入查询 URL 中的版本号?

更新

我试过 install.packages("http://private.com/src/contrib/rlang_0.4.3.tar.gz", repos=NULL) 并且有效。接下来,我将尝试在新的 Ubuntu 环境中重现该问题。也许我在安装 R 并将其升级到 3.6.2

时搞砸了

当我降级到 R 版本 3.4.4 时,问题仍然存在。也许这与公司镜像有关?我会试试官方的。


感谢 Dirks 我发现 available.packages() 镜像有问题,而不是 R 安装。

> AP <- available.packages()
> res <- AP[ AP[,1] == "rlang", ]
> str(res)
 Named chr [1:17] "rlang" "0.4.2" NA "R (>= 3.2.0)" NA NA ...
 - attr(*, "names")= chr [1:17] "Package" "Version" "Priority" "Depends" ...

由于镜像中 PACKAGES 的可读版本包含 0.4.3 我认为 PACKAGES.rds 有问题。接下来我将尝试读取该对象以确认我的假设。


Dirk 建议我检查索引的时间戳,我想我发现了问题。 0.4.3 不久前发布。虽然可读索引仅在其他几个人之前更新过,但 .rds 文件(可能由 R 使用)自 2020-01-16 以来就没有更新过。因此 R 尝试下载一个不再属于存储库的版本。

现在我想知道谁负责更新 RDS 文件?存储库本身?我会在下次报告...也许在随机批处理作业更新存储库后问题会自行解决。

rlang 包:

时间戳:

PACKAGES 内容:


我手动下载了 PACKAGES.rds 并在上面使用了 readRDS()。它指向旧版本。我还检查了镜像的回购协议。它的 PACKAGES.rds 指向正确的版本。此外,我确保问题仍然存在,与我使用的发行版和图像无关。

如果你这样做

?install.packages()

它将为您提供有关执行检索的函数的一些信息,您可以输入一个 "repo" 参数。大多数时候,如果我遇到软件包安装问题并且不太担心确切的版本 运行 a:

install.packages("rlang", dependencies = TRUE)

通常对我来说很好

这个问题你可以问R! available.packages() 函数告诉你 "everything" 它知道,一个条目是 'Repository'。

所以:

R> AP <- available.packages()       ## all known packages given options("repos")
R> res <- AP[ AP[,1] == "rlang", ]  ## find rlang
R>
R> str(res)
 Named chr [1:17] "rlang" "0.4.3" NA "R (>= 3.2.0)" NA NA ...
 - attr(*, "names")= chr [1:17] "Package" "Version" "Priority" "Depends" ...
R> 
R> names(res)
 [1] "Package"               "Version"              
 [3] "Priority"              "Depends"              
 [5] "Imports"               "LinkingTo"            
 [7] "Suggests"              "Enhances"             
 [9] "License"               "License_is_FOSS"      
[11] "License_restricts_use" "OS_type"              
[13] "Archs"                 "MD5sum"               
[15] "NeedsCompilation"      "File"                 
[17] "Repository"           
R> 
R> res["Repository"]
                               Repository 
"https://cloud.r-project.org/src/contrib" 
R> 

这并不奇怪,因为这是我使用的默认配置的默认存储库(并在 Debian / Ubuntu 包中编码)。