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的方式則不會出現