zoukankan      html  css  js  c++  java
  • logstash启动时找不到自定义的JAVA_HOME环境变量

    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的方式则不会出现

  • 相关阅读:
    Codeforces 912 D. Fishes (贪心、bfs)
    Codeforces 908 D.New Year and Arbitrary Arrangement (概率&期望DP)
    HDU
    HDU
    POJ-2299 Ultra-QuickSort (树状数组)
    deque!
    HDU
    乘法逆元
    Codeforces 911D. Inversion Counting (数学、思维)
    Codeforces 909E. Coprocessor (拓扑、模拟)
  • 原文地址:https://www.cnblogs.com/sanduzxcvbnm/p/11416138.html
Copyright © 2011-2022 走看看