logstash启动时找不到自定义的JAVA_HOME环境变量
logstash java 版本问题
配置logstash收集应用日志时出现报错,说是找不到JAVA_HOME环境变量,但是明明已经设置了
[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
注:logstash的启动文件没有关于java_home的相关配置
若使用yum安装方式安装的话 最好jdk也用yum安装方式
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!