Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How does one configure rJava on OSX to select the right JVM -- .jinit() failing

Tags:

java

r

rjava

I installed rJava by calling install.packages("rJava") -- no problems seen

However when I call:

library(rJava)
.jinit() 

I get:

JavaVM: requested Java version ((null)) not available. Using Java at "" instead.
JavaVM: Failed to load JVM: /bundle/Libraries/libserver.dylib
JavaVM FATAL: Failed to load the jvm library.
Error in .jinit() : JNI_GetCreatedJavaVMs returned -1

I'm running OSX:

Darwin MBP-2 14.5.0 Darwin Kernel Version 14.5.0: Tue Sep  1 21:23:09 PDT 2015; root:xnu-2782.50.1~1/RELEASE_X86_64 x86_64

I have the following Sun JDK's installed:

$ ls /Library/Java/JavaVirtualMachines/
jdk1.7.0_79.jdk jdk1.8.0_65.jdk

Which Java is on my PATH:

$ which java
/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home//bin/Java

I also have JavaHome defined as:

$ echo $JAVA_HOME
/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home/
like image 998
user1172468 Avatar asked Jan 24 '16 03:01

user1172468


3 Answers

The answer at https://stackoverflow.com/a/36045290/4351357 helped resolve this issue for me on MacOS Sierra Version 10.12. In particular, it provided the code in command 1, below.

The three Terminal commands I used are:

  1. sudo ln -s $(/usr/libexec/java_home)/jre/lib/server/libjvm.dylib /usr/local/lib
  2. sudo R CMD javareconf
  3. install.packages("rJava",type='source')
like image 75
Jonathan Avatar answered Oct 17 '22 18:10

Jonathan


This solution Cannot load R xlsx package on Mac OS 10.11

sudo R CMD javareconf

install.packages("rJava",type='source')

Worked for me

like image 6
Tim Child Avatar answered Oct 17 '22 18:10

Tim Child


While attempting to run this test on OSX 10.11.5 (El Capitan) http://www.r-bloggers.com/connecting-r-to-an-oracle-database-with-rjdbc/

I kept getting that same error. I attempted to just do the install as suggested by Tim Child. The thing I noticed was that my version of R Studio (Version 0.99.896 ) kept complaining about installing the 1.6 Legacy Java for OSX.

I installed the legacy Java from the website https://support.apple.com/kb/DL1572?locale=en_US

Then ran a simpler test in R Studio.

library(rJava)

.jinit()
print(.jcall("java/lang/System", "S", "getProperty", "java.version"))

My results:

 > library(rJava)
 > .jinit()
 > print(.jcall("java/lang/System", "S", "getProperty", "java.version"))
[1] "1.6.0_65"

Happy to see that I ran my other test (then that one that started me down this path). I still could not get it to set the most current Java version.

I did one more re-install of the package rJava

install.packages("rJava",type='source')

and things are working ok, using version of Java 1.6 for now, but at least I can get some work done. Hope some comes across a better fix :)

like image 1
mtbiker-s Avatar answered Oct 17 '22 17:10

mtbiker-s