天天看點

logstash java home_logstash啟動時找不到自定義的JAVA_HOME環境變量

logstash java 版本問題

配置logstash收集應用日志時出現報錯,說是找不到JAVA_HOME環境變量,但是明明已經設定了

logstash要求java 1.8以上,檢視生産環境:

[[email protected] ~]# echo ${JAVA_HOME}

/usr/local/jdk-12

[[email protected] ~]# 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的方式則不會出現