logstash启动时找不到自定义的JAVA_HOME环境变量

懵懂的女人 提交于 2019-11-28 17:26:52

logstash java 版本问题

配置logstash收集应用日志时出现报错,说是找不到JAVA_HOME环境变量,但是明明已经设置了

logstash要求java 1.8以上,查看生产环境:

[root@localhost ~]# echo ${JAVA_HOME}
/usr/local/jdk-12

[root@localhost ~]# java -version
openjdk version "12" 2019-03-19
OpenJDK Runtime Environment (build 12+33)
OpenJDK 64-Bit Server VM (build 12+33, mixed mode, sharing)

查看logstash启动脚本,没有关于java_home之类的相关配置,但是有一项:

"$(cd `dirname $SOURCEPATH`/..; pwd)/bin/logstash.lib.sh"

logstash启动过程会引入lib文件bin/logstash.lib.sh

查看logstash.lib.sh

setup_java() {
  if [ -z "$JAVACMD" ] ; then
    if [ -n "$JAVA_HOME" ] ; then
      JAVACMD="$JAVA_HOME/bin/java"
    else
      JAVACMD="java"
    fi
  fi

定义了一个setup_java的函数,setup_java被setup函数调用,最终被bin/logstash启动脚本调用,因此,

我们只需要在logstash或logstash.lib.sh的行首位置添加两个环境变量

export JAVA_HOME=/usr/local/jdk-12
export PATH=$PATH:$JAVA_HOME/bin

再次启动正常

注意:这种情况一般发生在自定义的java环境上,使用yum在线安装java的方式则不会出现

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!