【发布时间】:2017-07-12 15:57:32
【问题描述】:
Rstudio 的编织按钮无法编织包含 rJava 包的 rmarkdown (Rmd) 文件。但是,如果我使用rmarkdown::render(),相同的 Rmd 文件会毫无问题地呈现为 html。
我可以使用以下代码重现错误:
test.Rmd 的内容:
---
title: "test"
output: html_document
---
```{r}
library(rJava)
```
单击编织按钮按钮将返回:
processing file: test.Rmd
Error : .onLoad failed in loadNamespace() for 'rJava', details:
call: dyn.load(file, DLLpath = DLLpath, ...)
error: unable to load shared object '/Library/Frameworks/R.framework/Versions/3.3/Resources/library/rJava/libs/rJava.so':
dlopen(/Library/Frameworks/R.framework/Versions/3.3/Resources/library/rJava/libs/rJava.so, 6): Library not loaded: @rpath/libjvm.dylib
Referenced from: /Library/Frameworks/R.framework/Versions/3.3/Resources/library/rJava/libs/rJava.so
Reason: image not found
Quitting from lines 7-8 (test.Rmd)
Error: package or namespace load failed for 'rJava'
Execution halted
rmarkdown::render("test.Rmd") 工作正常。此外,正常运行library(rJava)(不是编织)也可以正常运行(在 RStudio 中)。
在 macOS Sierra 10.12 中使用 RStudio 版本 1.0.136、knitr 1.15.1、rmarkdown 1.3、rJava 0.9-8、R 3.3.2。
更新:根据@r2evans 的要求添加Sys.getenv() 的输出。 DYLD_FALLBACK_LIBRARY_PATH 的值是有区别的,但是不知道这个有没有意义。我用 XXX 替换了一些私人信息。
在 Knit 按钮生成的 html 文件中:
## __CF_USER_TEXT_ENCODING
## 0x1F5:0x0:0x52
## Apple_PubSub_Socket_Render
## /private/tmp/com.apple.launchd.HvKScioyGU/Render
## DISPLAY :0
## DYLD_FALLBACK_LIBRARY_PATH
## /Library/Frameworks/R.framework/Resources/lib
## EDITOR vi
## GIT_ASKPASS rpostback-askpass
## HOME XXX
## LANG en_CA.UTF-8
## LC_CTYPE en_CA.UTF-8
## LN_S ln -s
## LOGNAME XXX
## MAKE make
## NOT_CRAN true
## PAGER /usr/bin/less
## PATH /usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Library/TeX/texbin
## PWD XXX
## R_ARCH
## R_BROWSER /usr/bin/open
## R_BZIPCMD /usr/bin/bzip2
## R_DOC_DIR /Library/Frameworks/R.framework/Resources/doc
## R_GZIPCMD /usr/bin/gzip
## R_HOME /Library/Frameworks/R.framework/Resources
## R_INCLUDE_DIR /Library/Frameworks/R.framework/Resources/include
## R_LIBS /Library/Frameworks/R.framework/Versions/3.3/Resources/library
## R_LIBS_SITE
## R_LIBS_USER ~/Library/R/3.3/library
## R_PAPERSIZE a4
## R_PAPERSIZE_USER a4
## R_PDFVIEWER /usr/bin/open
## R_PLATFORM x86_64-apple-darwin13.4.0
## R_PRINTCMD lpr
## R_QPDF /Library/Frameworks/R.framework/Resources/bin/qpdf
## R_RD4PDF times,inconsolata,hyper
## R_SESSION_TMPDIR /var/folders/15/vdvn4fvx0zn0gc93_5krp6h00000gn/T//RtmpiYlwpU
## R_SHARE_DIR /Library/Frameworks/R.framework/Resources/share
## R_SYSTEM_ABI osx,gcc,gxx,gfortran,?
## R_TEXI2DVICMD /usr/local/bin/texi2dvi
## R_UNZIPCMD /usr/bin/unzip
## R_ZIPCMD /usr/bin/zip
## RMARKDOWN_MATHJAX_PATH
## /Applications/RStudio.app/Contents/Resources/resources/mathjax-26
## RMARKDOWN_PREVIEW_DIR
## /var/folders/15/vdvn4fvx0zn0gc93_5krp6h00000gn/T//RtmpLe3D9z
## RS_RPOSTBACK_PATH /Applications/RStudio.app/Contents/MacOS/rpostback
## RS_SHARED_SECRET XXX
## RSTUDIO 1
## RSTUDIO_PANDOC /Applications/RStudio.app/Contents/MacOS/pandoc
## RSTUDIO_SESSION_PORT
## XXX
## RSTUDIO_USER_IDENTITY
## XXX
## RSTUDIO_WINUTILS bin/winutils
## SED /usr/bin/sed
## SHELL /bin/bash
## SHLVL 0
## SSH_AUTH_SOCK XXX
## TAR /usr/bin/tar
## TMPDIR /var/folders/15/vdvn4fvx0zn0gc93_5krp6h00000gn/T/
## USER XXX
## XPC_FLAGS 0x0
## XPC_SERVICE_NAME 0
在rmarkdown::render()产生的文件中:
## __CF_USER_TEXT_ENCODING
## 0x1F5:0x0:0x52
## Apple_PubSub_Socket_Render
## /private/tmp/com.apple.launchd.HvKScioyGU/Render
## DISPLAY :0
## DYLD_FALLBACK_LIBRARY_PATH
## /Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Users/Jayme/lib:/usr/local/lib:/usr/lib::::::::
## EDITOR vi
## GIT_ASKPASS rpostback-askpass
## HOME XXX
## LANG en_CA.UTF-8
## LC_CTYPE en_CA.UTF-8
## LN_S ln -s
## LOGNAME XXX
## MAKE make
## PAGER /usr/bin/less
## PATH /usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Library/TeX/texbin
## R_BROWSER /usr/bin/open
## R_BZIPCMD /usr/bin/bzip2
## R_DOC_DIR /Library/Frameworks/R.framework/Resources/doc
## R_GZIPCMD /usr/bin/gzip
## R_HOME /Library/Frameworks/R.framework/Resources
## R_INCLUDE_DIR /Library/Frameworks/R.framework/Resources/include
## R_LIBS_SITE
## R_LIBS_USER ~/Library/R/3.3/library
## R_PAPERSIZE a4
## R_PDFVIEWER /usr/bin/open
## R_PLATFORM x86_64-apple-darwin13.4.0
## R_PRINTCMD lpr
## R_QPDF /Library/Frameworks/R.framework/Resources/bin/qpdf
## R_RD4PDF times,inconsolata,hyper
## R_SESSION_TMPDIR /var/folders/15/vdvn4fvx0zn0gc93_5krp6h00000gn/T//RtmpLe3D9z
## R_SHARE_DIR /Library/Frameworks/R.framework/Resources/share
## R_SYSTEM_ABI osx,gcc,gxx,gfortran,?
## R_TEXI2DVICMD /usr/local/bin/texi2dvi
## R_UNZIPCMD /usr/bin/unzip
## R_ZIPCMD /usr/bin/zip
## RMARKDOWN_MATHJAX_PATH
## /Applications/RStudio.app/Contents/Resources/resources/mathjax-26
## RS_RPOSTBACK_PATH /Applications/RStudio.app/Contents/MacOS/rpostback
## RS_SHARED_SECRET XXX
## RSTUDIO 1
## RSTUDIO_PANDOC /Applications/RStudio.app/Contents/MacOS/pandoc
## RSTUDIO_SESSION_PORT
## XXX
## RSTUDIO_USER_IDENTITY
## XXX
## RSTUDIO_WINUTILS bin/winutils
## SED /usr/bin/sed
## SHELL /bin/bash
## SSH_AUTH_SOCK XXX
## TAR /usr/bin/tar
## TMPDIR /var/folders/15/vdvn4fvx0zn0gc93_5krp6h00000gn/T/
## USER XXX
## XPC_FLAGS 0x0
## XPC_SERVICE_NAME 0
Update2 关注来自@r2evans 的 cmets
在.Rmd 中包含来自render() 的DYLD_FALLBACK_LIBRARY_PATH 会按预期更改Sys.getenv() 的结果,但是编织按钮的错误行为(与上述相同的错误消息)并且render() 中没有错误仍然存在。新的.Rmd 内容为:
---
title: "test2"
output: html_document
---
```{r}
Sys.setenv(DYLD_FALLBACK_LIBRARY_PATH="/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Users/Jayme/lib:/usr/local/lib:/usr/lib::::::::")
library(rJava)
```
有趣的是,在上面的 test2.Rmd 中使用 render(),包括 Sys.getenv() 现在会输出两个新变量,之前不存在,使用 knit 按钮也不存在:
## DYLD_LIBRARY_PATH /Library/Java/JavaVirtualMachines/jdk1.8.0_101.jdk/Contents/Home/jre/lib/server
## LD_LIBRARY_PATH :@JAVA_LD@
我不知道它是否有意义,但我尝试了一个新的.Rmd(如下),它仍然给出同样的错误
---
title: "test3"
output: html_document
---
```{r}
Sys.setenv(DYLD_FALLBACK_LIBRARY_PATH="/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Library/Frameworks/R.framework/Resources/lib:/Users/Jayme/lib:/usr/local/lib:/usr/lib::::::::")
Sys.setenv(DYLD_LIBRARY_PATH="/Library/Java/JavaVirtualMachines/jdk1.8.0_101.jdk/Contents/Home/jre/lib/server")
Sys.setenv(LD_LIBRARY_PATH= ":@JAVA_LD@")
library(rJava)
```
【问题讨论】:
-
我无法重现您的错误...在我的系统 Ubuntu 16.04 LTS 上一切正常。其余的包和我系统上的一样。
-
在
render和knitting 中运行Sys.getenv()可能会提供信息。寻找差异,特别是在PATH和任何与LIB相关的变量中。 -
@r2evans 更新了问题并提供了所要求的信息。
-
你找到
libjvm.dylib的位置了吗?我可能会开始查看额外的DYLD_FALLBACK_LIBRARY_PATH路径(来自第二个清单)。如果您在那里找到它,请尝试使用附加路径更新变量(不幸的是,可能在.Rmd文件中)。 -
感谢@r2evans 的帮助。在来自 Knit 按钮 (
/Library/Frameworks/R.framework/Resources/lib) 的DYLD_FALLBACK_LIBRARY_PATH中没有libjvm.dylib文件,但在来自render()(/usr/local/lib) 的路径之一中。我应该将此文件(它是别名)复制到/Library/Frameworks/R.framework/Resources/lib吗?或者在.Rmd文件中写一些东西?这些软件包是否会出现此问题,或者只是我机器中的错误配置?我尝试在加载rJava之前添加Sys.setenv(DYLD_FALLBACK_LIBRARY_PATH="/usr/local/lib"),但是编织时的错误仍然存在
标签: r rstudio knitr r-markdown rjava