Elasticsearch 在 Centos 6.6 上未找到 Java,所有路径变量均已设置并正常工作
Posted
技术标签:
【中文标题】Elasticsearch 在 Centos 6.6 上未找到 Java,所有路径变量均已设置并正常工作【英文标题】:Java not found by Elasticsearch on Centos 6.6, all path variables are set and working 【发布时间】:2014-12-28 21:08:57 【问题描述】:我最近启动了一个 vagrant 服务器,并希望让 Elasticsearch 继续运行。因此,我在“chef/Centos-6.6”流浪云虚拟机上安装了 Oracle Java 和 ES。我使用“etc/profile.d”中的 shell 脚本设置我的 Java 路径。
这是我的配置脚本:
#!/usr/bin/env bash
yum -y update
wget -O /opt/jdk-7u67-linux-x64.tar.gz --no-cookies --no-check-certificate --header "Cookie: gpw_e24=http%3A%2F%2Fwww.oracle.com%2F; oraclelicense=accept-securebackup-cookie" "http://download.oracle.com/otn-pub/java/jdk/7u67-b01/jdk-7u67-linux-x64.tar.gz"
tar xzf /opt/jdk-7u67-linux-x64.tar.gz -C /opt/
touch /etc/profile.d/java.sh
echo "export JAVA_HOME=/opt/jdk1.7.0_67" >> /etc/profile.d/java.sh
echo "export JRE_HOME=/opt/jdk1.7.0_67/jre" >> /etc/profile.d/java.sh
echo "export PATH=$PATH:/opt/jdk1.7.0_67/bin:/opt/jdk1.7.0_67/jre/bin" >> /etc/profile.d/java.sh
rpm --import http://packages.elasticsearch.org/GPG-KEY-elasticsearch
REPO="[elasticsearch-1.3]
name=Elasticsearch repository for 1.3.x packages
baseurl=http://packages.elasticsearch.org/elasticsearch/1.3/centos
gpgcheck=1
gpgkey=http://packages.elasticsearch.org/GPG-KEY-elasticsearch
enabled=1"
echo "$REPO" > /etc/yum.repos.d/elasticsearch.repo
yum install -y elasticsearch
安装一切顺利。但是,当我运行“sudo service elasticsearch start”时,我得到:
which: no java in (/sbin:/usr/sbin:/bin:/usr/bin)
但如果我为家庭用户“回显 $PATH”,我会得到:
/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/opt/jdk1.7.0_67/bin:/opt/jdk1.7.0_67/jre/bin:/home/vagrant/bin
对于根用户 $PATH 我得到:
/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/opt/jdk1.7.0_67/bin:/opt/jdk1.7.0_67/jre/bin
我得到“回声 $JAVA_HOME”:
/opt/jdk1.7.0_67
如果我运行“我得到哪个 java”:
/opt/jdk1.7.0_67/bin/java
如果我运行“java”,它会显示在手册页中。
elasticsearch 怎么没有在我的 java 路径中寻找?为什么它只在默认的 Centos 路径中查找?我在这里错过了什么?
【问题讨论】:
不知道你错过了什么,但我想没有什么是ln -s /opt/jdk1.7.0_67/bin/java /bin/java
无法修复的。
谢谢,这确实有效,我没想过要建立一个符号链接。它仍然无法正常工作
我知道这不是您正在寻找的学术解决方案,但在您找到它之前,这将解锁您。
【参考方案1】:
问题的根源可能是初始化脚本(在这种情况下为弹性初始化脚本)看不到大多数环境变量(例如JAVA_HOME
、JRE_HOME
等)。
如果您查看ElasticSearch init script,您会发现PATH
变量是在该初始化脚本中显式设置的,而JAVA_HOME
是通过循环遍历一组预定义的可能位置来确定的:
JDK_DIRS="/usr/lib/jvm/jdk-7-oracle-x64 /usr/lib/jvm/java-7-oracle /usr/lib/jvm/java-7-openjdk /usr/lib/jvm/java-7-openjdk-amd64/ /usr/lib/jvm/java-7-openjdk-armhf /usr/lib/jvm/java-7-openjdk-i386/ /usr/lib/jvm/default-java"
所以你可以将你的 Java 安装放到 /usr/lib/jvm/jdk-7-oracle-x64
目录中,然后 init 脚本应该会选择它。
更新
查看初始化脚本,我注意到您可以在 /etc/default/elasticsearch
中设置 JAVA_HOME
以跳过循环遍历上述预定义的 JDK 位置 (Source)。
【讨论】:
太棒了,这让我发疯了。从我读到的似乎“/etc/profile.d”会全局设置这些变量,我想这是个例外。感谢您清除此问题 @patrickbarker/etc/profile.d/
确实在全局范围内设置了变量。但是,如果您查看man service
,它会提到它剥离了几乎所有环境变量,以便服务可以在最可预测的环境中运行。我相信如果服务在系统启动期间启动,这些变量可能还没有设置,所以脚本最好不要依赖它们。但我不能 100% 确定最后一部分 :) 也许一些 Linux 专家可以证实这一点。无论如何,我很高兴它对你有用:)
@BohuslavBurghardt,到 Github 的两个链接都断开了。以上是关于Elasticsearch 在 Centos 6.6 上未找到 Java,所有路径变量均已设置并正常工作的主要内容,如果未能解决你的问题,请参考以下文章
sh 在CentOS 6.4上安装ElasticSearch的命令
sh 在CentOS 6.4上安装ElasticSearch的命令