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_HOMEJRE_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的命令

centos7安装elasticsearch-6.6.0

centos7安装elasticsearch-6.6.0

Elasticsearch 在 Centos 6.6 上未找到 Java,所有路径变量均已设置并正常工作

CentOS 6 ElasticSearch 5.5.x 安装指南