前几天在Ubuntu上安装R中的xlsx包时一直卡在了rJava包的安装上,最终各种google都没能解决问题.直到最后,我回到了安装rJava时的错误记录....我用血的教训证明,错误日志是很重要很重要的!!!!!

(由于已经成功地排除了错误,且不打算折腾我的电脑,我就从网上copy一个类似的来说明下发生了什么问题)

运行 install.packages("rJava")并下载解压缩后,日志显示电脑上JDK环境配置有问题.(一大堆的yes后在"checking Java support in R"那里卡住了)

如下:

checking Java support in R... present:
interpreter : '/usr/bin/java'
archiver : '' #空白
compiler : '/usr/bin/javac'
header prep.: '' #空白
cpp flags : '-I/usr/share/jdk1.8.0_51/jre/../include -I/usr/share/jdk1.8.0_51/jre/../include/linux'
java libs : '-L/usr/share/jdk1.8.0_51/jre/lib/amd64/server -ljvm'
configure: error: One or more Java configuration variables are not set.
Make sure R is configured with full Java support (including JDK). Run #注意此句:JDK环境有误
R CMD javareconf
as root to add Java support to R. # 这句告诉我们,在确保JDK的安装路径没有问题的情况下应该如何就行修复 If you don't have root privileges, run
R CMD javareconf -e
to set all Java-related variables and then install rJava. ERROR: configuration failed for package ‘rJava’ #由于安装出错,移除安装包
* removing ‘/home/cc886/R/x86_64-pc-linux-gnu-library/3.1/rJava’
Warning in install.packages :
installation of package ‘rJava’ had non-zero exit status The downloaded source packages are in
‘/tmp/RtmpaX9v6v/downloaded_packages’

事实上我在翻看错误记录看到那两段空白的时候,终于意识到了问题的关键. 一开始在Ubuntu上配置的是用apt-get获取的openjdk环境,无论我如何运行R CMD javareconf 都没能修复这个问题.

最后,在尝试着上官网下载sunjdk并进行配置的过程中,我发现openjdk和sunjdk相比少了一些文件,即bin文件夹里的javac,javah等等.而Javac立刻让我联想到了错误日志里的"compliler"的空白.于是我用sudo update-alternatives --install ***** 对jar,javah等进行了手动的指定.并发现那两段空白被填补上了.也就是说,这个安装错误信息出现的根本原因就是缺少了jar,javah等的指定(前提是有这些文件)

如果不对jar,javah进行手动指定,运行sudo R CMD javareconf过程中Java headers gen和Java archive tool项会缺失,如下

cc886@cc886:~$ sudo R CMD javareconf -e
[sudo] password for cc886:
Java interpreter : /usr/bin/java
Java version : 1.8.0_51
Java home path : /usr/share/jdk1.8.0_51/jre
Java compiler : /usr/bin/javac
Java headers gen.: #缺失
Java archive tool: #缺失 trying to compile and link a JNI progam
detected JNI cpp flags : -I$(JAVA_HOME)/../include -I$(JAVA_HOME)/../include/linux
detected JNI linker flags : -L$(JAVA_HOME)/lib/amd64/server -ljvm
gcc -std=gnu99 -I/usr/share/R/include -DNDEBUG -I/usr/share/jdk1.8.0_51/jre/../include -I/usr/share/jdk1.8.0_51/jre/../include/linux -fpic -g -O2 -fstack-protector-strong -Wformat -Werror=format-security -D_FORTIFY_SOURCE=2 -g -c conftest.c -o conftest.o
gcc -std=gnu99 -shared -L/usr/lib/R/lib -Wl,-Bsymbolic-functions -Wl,-z,relro -o conftest.so conftest.o -L/usr/share/jdk1.8.0_51/jre/lib/amd64/server -ljvm -L/usr/lib/R/lib -lR The following Java variables have been exported:
JAVA_HOME JAVA JAVAC JAVAH JAR JAVA_LIBS JAVA_CPPFLAGS JAVA_LD_LIBRARY_PATH
Running: /bin/bash

因此,我们需要在手动指定了jar,javah后再运行

sudo R CMD javareconf

在JDK路径无误的状态下,此命令会自动地进行DEBUG.并export一个环境变量 JAVA_TOOL_OPTIONS. 当所有空白被正确填补,并成功运行上述命令后,rJava包即可成功安装.


另,此时运行 java -version会是如下状况,其中的 JAVA_TOOL_OPTIONS一行是rJava的安装所致.

user@loca:~$ java -version
Picked up JAVA_TOOL_OPTIONS: -javaagent:/usr/share/java/jayatanaag.jar
java version "1.8.0_51"
Java(TM) SE Runtime Environment (build 1.8.0_51-b16)
Java HotSpot(TM) 64-Bit Server VM (build 25.51-b03, mixed mode)

具体DEBUG步骤

配置JDK环境

详见另一篇博文:Ubuntu 中 java 环境 (sunjdk) 的配置 (附详细说明)

手动指定archiver, header prep.

# 以下两条应该已经在配置JDK的时候已经运行过了
$ sudo update-alternatives --install /usr/bin/java java /usr/share/jdk1.8.0_51/bin/java 300
$ sudo update-alternatives --install /usr/bin/javac javac /usr/share/jdk1.8.0_51/bin/javac 300 #下面这些是DEBUG所需的
$ sudo update-alternatives --install /usr/bin/jar jar /usr/share/jdk1.8.0_51/bin/jar 300
$ sudo update-alternatives --install /usr/bin/javah javah /usr/share/jdk1.8.0_51/bin/javah 300

指定archiver (jar), header prep (javah)

# config选项指定
$ sudo update-alternatives --config jar
$ sudo update-alternatives --config javah

运行sudo R CMD javareconfsudo R CMD javareconf -e

按照R中提示运行命令(不知道具体是那个起的作用)

$ sudo R CMD javareconf
$ sudo R CMD javareconf -e

安装rJava包

在R中运行

install.packages("rJava")

一路直踩到底,大功告成!

R 之 rJava 包安装错误的解决方案的更多相关文章

  1. R语言rJava包安装载入及JAVA环境配置

    rJava 包的安装与载入 一般文本分词的教程都会贴出: install.packages("rJava") library(rJava) 来引导我们装载rJava包,运行inst ...

  2. 20150514Linux下rpm包安装错误及解决方案

    (1)用rpm -ivh ***.rpm解压RedHat自带boost出现错误如下: warning: /media/RHEL_6.3 i386 Disc 1/Packages/boost-1.41. ...

  3. R中rJava包载入时报错的问题

    今天安装XLConnect包,安装后无法library(XLConnect)载入,看报错问题应该出在rJava上,找到了下面的解决办法: if (Sys.getenv("JAVA_HOME& ...

  4. 【转】Win7+Ubuntu12.04.1硬盘安装错误及解决方案----不错

    原文网址:http://blog.csdn.net/ys_073/article/details/8310115 前言: 说起来了,为了在Win7上进行硬盘安装Ubuntu浪费了整整一个晚上的时间.装 ...

  5. weblogic安装错误BEA-090870解决方案

    00.问题描述 <Sep 3, 2017 3:29:09 PM CST> <Error> <Security> <BEA-090870> <The ...

  6. linux-ubuntu 下R无法安装HH包的原因及解决方案

    错误信息: configure: error: GNU MP not found, or not 4.1.4 or up, see http://gmplib.org ERROR: configura ...

  7. R 安装包遇到问题(一) loadNamespace()里算'rJava'时.onLoad失败了 rJava 包的安装与载入

    > library(xlsx) Error: package or namespace load failed for ‘xlsx’: loadNamespace()里算'rJava'时.onL ...

  8. R语言:关于rJava包的安装

    R语言:关于rJava包的安装  盐池里的萝卜 2014-09-14 00:53:33 在做文本挖掘的时候,会发现分词时候rJava是必须要迈过去的坎儿,所以进行了总结: 第一步:安装rJava和jd ...

  9. 安装python包时出现VC++ 错误的解决方案

    方式一 就是按照提示在微软的官网上下载宇宙第一编辑器VS,安装完之后卸载掉就好了. 方式二 下载whl包安装 因为python有很多native的包,不是纯python代码,用了诸如c/c++的代码, ...

随机推荐

  1. js验证真实姓名

    var regName = /^[\u4e00-\u9fa5]{2,4}$/; if (!regName.test(examinee.name)) { wx.showToast({ title: &q ...

  2. HDU - 6437 Problem L.Videos 2018 Multi-University Training Contest 10 (最小费用最大流)

    题意:M个影片,其属性有开始时间S,结束时间T,类型op和权值val.有K个人,每个人可以看若干个时间不相交的影片,其获得的收益是这个影片的权值val,但如果观看的影片相邻为相同的属性,那么收益要减少 ...

  3. Mybatis之基础应用小结以及IntelliJ IDEA目录结构的一些小问题

    IntelliJ IDEA 目录结构的一些小问题 [Mybatis 之基础应用小结] 1.不管怎么样,先建立一个简单的MySQL数据表,如下所示 2.接下来要做的事情就是通过Mybatis对数据表进行 ...

  4. 20145201 《Java程序设计》第一周学习总结(修改)

    # 20145201 <Java程序设计>第一周学习总结 ## 教材学习内容总结 万事开头难,终于开始学习了Java.寒假的时候看到老师的要求确实有点慌,但是这周翻开书,从书本知识第一行学 ...

  5. MapReduce:输入是两个文件,file1代表工厂表,包含工厂名列和地址编号列;file2代表地址表,包含地址名列和地址编号列。要求从输入数据中找出工厂名和地址名的对应关系,输出"工厂名----地址名"表

    文件如下: file1: Beijing Red Star Shenzhen Thunder Guangzhou Honda Beijing Rising Guangzhou Development ...

  6. React Native 常用学习链接地址

    Android Studio下载http://www.android-studio.org/ 第二章:Android Studio概述(一)http://ask.android-studio.org/ ...

  7. NO.2 You must restart adb and Eclipse多种情形分析与解决方案

    一.问题描述:     运行android程序控制台输出     The connection to adb is down, and a severe error has occured.      ...

  8. Oracle递归查询与常用分析函数

    最近学习oracle的一些知识,发现自己sql还是很薄弱,需要继续学习,现在总结一下哈. (1)oracle递归查询  start with ... connect by prior ,至于是否向上查 ...

  9. HDFS集群启动的常见问题

    hdfs集群启动的常见问题 1.用浏览器访问namenode的50070端口,不正常,需要诊断问题出在哪里: a.在服务器的终端命令行使用jps查看相关进程 观察节点是否存活 b.如果已经知道了启动失 ...

  10. Ajax编程(HTTP请求与响应及API)详解

    AJAX编程 即 Asynchronous [e'sɪŋkrənəs] Javascript And XML, AJAX 不是一门的新的语言,而是对现有技术的综合利用. 本质是在HTTP协议的基础上以 ...