Zabbix 通过 JMX 监控 java 进程
参考: [ JMX monitoring ] [ Zabbix Java gateway ] [ JMX Monitoring (Java Gateway) not Working ] [ Monitoring and Management Using JMX ]
这里会说明通过 JMX 监控 java 进程的配置过程以及需要注意的问题.
本文在 zabbix 已经安装好的基础之上展开. 如果使用 zabbix_proxy , 配置完全一致, 只需要打开zabbix_proxy 对 java app server 有所有端口的访问权限即可.
环境说明
基本环境
- OS: CentOS 7.x
- Zabbix 系列版本: 3.4.11
- zabbix-server IP: 172.16.1.10
- zabbix-java-gateway IP: 172.16.1.10
- java app server IP: 172.16.1.11
网络配置需求
zabbix 相关进程都监听在默认端口:
- zabbix-server: 10051
- zabbix-agentd: 10050
- zabbix-java-gateway: 10052
- zabbix-server: 访问 zabbix-agentd 10050
- zabbix-agentd: 访问 zabbix-server 10051
- zabbix-java-gateway: 访问 zabbix-agentd 所有随机端口权限. (原因可以查看 这里) 因为zabbix_java_gateway 还会使用一个随机端口来访问远程主机的 RMI 信息.
zabbix 配置
安装 zabbix-java-gateway
在 172.16.1.10 (zabbix-server / zabbix-java-gateway ) 上执行:
rpm -i https://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm
yum -y install zabbix-java-gateway
**配置 /etc/zabbix/zabbix_java_gateway.conf **
LISTEN_IP="0.0.0.0"
LISTEN_PORT=10052
PID_FILE="/var/run/zabbix/zabbix_java.pid"
START_POLLERS=5
TIMEOUT=3
配置 /etc/zabbix/zabbix_server.conf
JavaGateway=localhost
JavaGatewayPort=10052
StartJavaPollers=5
关于 START_POLLERS 和 StartJavaPollers 值的设定需求: StartJavaPollers <= START_POLLERS ( [ 原因 ])
如果 StartJavaPollers > START_POLLERS, 会出现 zabbix-java-gateway 没有线程来接收进来的请求.
启动服务
# start zabbix-server
zabbix_server
# start zabbix-java-gateway
zabbix_java-gateway
Java App 启动参数的配置
具体可以参考 [ 这里 ].
启动参数如下
java \
-Djava.rmi.server.hostname=172.16.1.11 \
-Dcom.sun.management.jmxremote \
-Dcom.sun.management.jmxremote.port=18383 \
-Dcom.sun.management.jmxremote.authenticate=false \
-Dcom.sun.management.jmxremote.ssl=false \
-jar /data/app/demo.jar
这里需要说明:
- Djava.rmi.server.hostname : 这里需要指定 Java App 运行服务器的 IP 地址. 如果不指定这个参数, 则只接收来自 localhost 的请求.
- Dcom.sun.management.jmxremote.port: JMX 监听的端口. 只要不冲突即可.
附上shell 启动脚本
#!/bin/sh
# - start.sh
#
app=$1
basic_path=/data/app
# Ubuntu
host_ip=`ifconfig | egrep -A 2 "eth|ens" | awk -F "[: ]" '/\<inet\>/ && !/127.0.0.1/{sub(/^[ \t]+/,"");print $3}'`
# CentOS
# host_ip=`ifconfig| egrep -A 2 "eth|ens" | awk -F "[ X]+" '/\<inet\>/ && !/127.0.0.1/ {sub(/^[ \t]+/,"");print $2}'`
# first args could be jar name or directory name.
app_name=`echo $app | awk -F. '{print $1}'`
JAVA_OPS=" -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.port=18383 -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=$host_ip"
nohup /usr/bin/java $JAVA_OPS -jar $basic_path/$app_name/$app_name.jar >/dev/null 2>&1 &
[ $? == 0 ] && echo -e "Start Success!\n"
Zabbix GUI 配置
配置请看 [ 这里 ].
配置 JMX Interface:
- IP Address: Java APP 所在的服务器地址
- Port:
Dcom.sun.management.jmxremote.port所配置的端口 - Link 模板
在配置过程中需要注意的地方:
- zabbix-server ( 或者 zabbix-proxy ) 需要有访问 Java App Server 的所有随机端口的权限.
本地随机端口可以用: sysctl net.ipv4.ip_local_port_range 查看, 默认为 32768 - 60999, 所以在 Java App Server 上打开这些端口的对于 zabbix-server ( 或 zabbix-proxy ) 的访问权限.
Zabbix 通过 JMX 监控 java 进程的更多相关文章
- Linux记录-JMX监控JAVA进程
3.修改xxx.sh 加入export JAVA_OPTS="-Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.mana ...
- 利用VisualVm和JMX远程监控Java进程
自Java 6开始,Java程序启动时都会在JVM内部启动一个JMX agent,JMX agent会启动一个MBean server组件,把MBeans(Java平台标准的MBean + 你自己创建 ...
- zabbix使用jmx监控tomcat
zabbix监控Tomcat/JVM实例性能(115) – 运维生存时间http://www.ttlsa.com/zabbix/zabbix-use-jmx-monitor-tomcat/ zabbi ...
- zabbix 部署 jmx 监控tomcat
zabbix提供了一个java gateway的应用去监控jmx(Java Management Extensions,即Java管理扩展)是一个为应用程序.设备.系统等植入管理功能的框架.JMX可以 ...
- zabbix通过jmx监控tomcat
Zabbix版本: Zabbix 3.0.2 一.服务端配置 1.安装jdk(版本1.7.0_79) 安装与配置比较简单,过程省略.执行java -version命令,出现类似界面表示成功. 2. ...
- Zabbix自动发现监控Tomcat进程
1.编辑自动发现脚本 自动发现脚本只支持JSON格式 #!/usr/bin/env python # -*- coding:utf-8 -*- import commands import psuti ...
- 通过JDK常用工具监控Java进程的内存占用情况
目录 1 JDK 工具的使用 2 查看 GC 日志信息 3 添加 JMS 远程监控 Tomcat是一款常用的Web容器, 它是运行在 JVM(Java Virtual Machine) 中的一个Jav ...
- 性能测试之监控--zabbix通过jmx监控tomcat
前提: 已经安装好了zabbix server 实验环境 Centos 7 Zabbix 3.0 Tomcat 7.0 JDK 1.8 安装JDK tar -zxvf jdk-8u181-linux- ...
- shell脚本--监控java进程存活脚本
#!/bin/bash base_dir=/opt war_processor="tomcat" jar_processor="manager-server.jar pl ...
随机推荐
- lintcode-149-买卖股票的最佳时机
149-买卖股票的最佳时机 假设有一个数组,它的第i个元素是一支给定的股票在第i天的价格.如果你最多只允许完成一次交易(例如,一次买卖股票),设计一个算法来找出最大利润. 样例 给出一个数组样例 [3 ...
- 3ds Max学习日记(八)
再来更新一波学习进度. 之前玩了一下3dsmax里的灯光,不过由于和教程里的版本不同,教程里的我的没有,我有的教程又没有,所以只能瞎jb玩一玩. 最近又想建个人物模型玩玩,于是上网搜一下有 ...
- codesandbox
codesandbox https://codesandbox.io https://codesandbox.io/dashboard https://codesandbox.io/dashboard ...
- react-event-pooling
react-event-pooling 事件池 https://codesandbox.io/s/3xp4y9zp7q https://reactjs.org/docs/events.html#eve ...
- RT-thread内核之定时器管理
一.前言 rt-thread采用软件定时器线程模式或硬件定时器中断模式来实现系统定时器管理.而rt-thread操作系统在默认情况下是采用的硬件定时器中断模式的方式,用户可以通过宏定义RT_USING ...
- CentOS yum安装软件包
yum(Yellowdog Update Modifie)命令是在Fedora和RedHat以及SUSE中基于rpm的软件包管理器,它可以使系统管理人员交互和自动化地更细与管理RPM软件包,能够从指定 ...
- Android Service 生命周期
Service概念及用途: Android中的服务,它与Activity不同,它是不能与用户交互的,不能自己启动的,运行在后台的程序,如果我们退出应用时,Service进程并没有结束,它仍然在后台运行 ...
- 项目管理---git----快速使用git笔记(六)------本地开发与远程仓库的交互----常用git命令
无论是我们自己把本地的项目新建了一个远程仓库 还是 从远程仓库获取到了 本地,现在我们都在本地有了一份项目代码,服务器上对应有项目代码的信息. 现在我们就开始进行交互操作了. 也就是说明一些在 正常开 ...
- Dalvik虚拟机中DexClassLookup结构解析
http://blog.csdn.net/roland_sun/article/details/46877563 原文如下: 在Android系统中,所有的类定义以及具体的代码都是包含在DEX文件中的 ...
- Linux下 ps -ef 和 ps aux 的区别及格式详解
原文:https://www.cnblogs.com/5201351/p/4206461.html Linux下ps -ef和ps aux的区别及格式详解 Linux下显示系统进程的命令ps,最常用的 ...