我想安装一个具有安全配置文件的包,该配置文件无权访问/tmp
,但有自己的临时目录,例如/tmp/jeroen
. 但是,即使我尝试传递TMPDIR
环境变量,它仍然会失败,因为它尝试使用/tmp
. 下面是一个使用RAppArmor和unixtools的玩具示例(请参阅此处的测试配置文件)
> library(RAppArmor)
> library(unixtools)
> dir.create("/tmp/jeroen")
> set.tempdir("/tmp/jeroen")
> setwd(tempdir());
> aa_change_profile("r-test")
Switching profiles...
> print(tempdir());
[1] "/tmp/jeroen"
> install.packages("plyr", lib="/tmp/jeroen", configure.vars="TMPDIR=/tmp/jeroen")
trying URL 'http://cran.rstudio.com/src/contrib/plyr_1.8.tar.gz'
Content type 'application/x-gzip' length 384462 bytes (375 Kb)
opened URL
==================================================
downloaded 375 Kb
Fatal error: cannot create 'R_TempDir'
The downloaded source packages are in
‘/tmp/jeroen/downloaded_packages’
查看kern.log
文件(记录安全消息)时,发现问题R CMD INSTALL
仍然是尝试使用/tmp
被拒绝的文件:
Jul 24 19:41:34 Jeroen-Antec kernel: [16270.696805] type=1400 audit(1374687694.097:599):
apparmor="DENIED" operation="mkdir" parent=5798 profile="r-test" name="/tmp/RtmpcUOJuQ/"
pid=5802 comm="R" requested_mask="c" denied_mask="c" fsuid=1000 ouid=1000
有什么办法可以告诉我R CMD INSTALL
改用/tmp/jeroen
吗?