如何实现tm同时监控多个状态的改变_Prometheus 监控多个 Tomcat 实例状态

本文详细介绍了如何使用jmx_exporter监控多个Tomcat实例的状态,包括下载所需软件、配置Tomcat、jmx_exporter、Prometheus和Grafana,确保每个Tomcat实例使用不同的JMX端口,并提供了配置示例。

1、使用 jmx_exporter 监控多个 tomcat 实例(shutdown 端口、Connector 端口、AJP 端口都不能相同)的状态,前提条件是同一台主机的每个 tomcat 实例要分配不同的 jmx 端口

2、下载 tomcat 安装包、 jmx_exporter 安装包和 jmx_exporter tomcat 配置文件

// 下载地址:https://tomcat.apache.org/download-70.cgi

# ls /usr/local/src/apache-tomcat-7.0.91.tar.gz

/usr/local/src/apache-tomcat-7.0.91.tar.gz

// 下载地址:https://repo1.maven.org/maven2/io/prometheus/jmx/jmx_prometheus_javaagent/0.3.1/jmx_prometheus_javaagent-0.3.1.jar

# ls /usr/local/src/jmx_prometheus_javaagent-0.3.1.jar

/usr/local/src/jmx_prometheus_javaagent-0.3.1.jar

// jmx_exporter tomcat 配置文件下载地址:https://github.com/prometheus/jmx_exporter/tree/master/example_configs

# ls /usr/local/src/tomcat.yaml

/usr/local/src/tomcat.yaml

3、安装 tomcat

# cd /usr/local/src

# tar xf apache-tomcat-7.0.91.tar.gz -C /usr/local

# mv /usr/local/apache-tomcat-7.0.91 /usr/local/tomcat-1

4、tomcat server.xml 配置

type="org.apache.catalina.UserDatabase"

description="User database that can be updated and saved"

factory="org.apache.catalina.users.MemoryUserDatabaseFactory"

pathname="conf/tomcat-users.xml" />

connectionTimeout="20000"

redirectPort="8443" />

resourceName="UserDatabase"/>

unpackWARs="true" autoDeploy="true">

prefix="localhost_access_log." suffix=".txt"

pattern="%h %l %u %t "%r" %s %b" />

5、配置 jmx exporter

# mkdir -p /usr/local/jmx/

# cp /usr/local/src/jmx_prometheus_javaagent-0.3.1.jar /usr/local/jmx/

// 下载地址:https://github.com/prometheus/jmx_exporter/blob/master/example_configs/tomcat.yml

# cp /usr/local/src/tomcat.yaml /usr/local/jmx/config.yaml

# cat /usr/local/jmx/config.yaml

---

lowercaseOutputLabelNames: true

lowercaseOutputName: true

rules:

- pattern: 'Catalina<>(\w+):'

name: tomcat_$3_total

labels:

port: "$2"

protocol: "$1"

help: Tomcat global $3

type: COUNTER

- pattern: 'Catalina<>(requestCount|maxTime|processingTime|errorCount):'

name: tomcat_servlet_$3_total

labels:

module: "$1"

servlet: "$2"

help: Tomcat servlet $3 total

type: COUNTER

- pattern: 'Catalina<>(currentThreadCount|currentThreadsBusy|keepAliveCount|pollerThreadCount|connectionCount):'

name: tomcat_threadpool_$3

labels:

port: "$2"

protocol: "$1"

help: Tomcat threadpool $3

type: GAUGE

- pattern: 'Catalina<>(processingTime|sessionCounter|rejectedSessions|expiredSessions):'

name: tomcat_session_$3_total

labels:

context: "$2"

host: "$1"

help: Tomcat session $3 total

type: COUNTER

6、配置 tomcat setenv.sh,让 jmx_exporter 跟 tomcat 一起启动

// 指定 jmx_exporter 的运行端口为 30013,不同的实例要分配不同的端口

# cat /usr/local/tomcat-1/bin/setenv.sh

JAVA_OPTS="-javaagent:/usr/local/jmx/jmx_prometheus_javaagent-0.3.1.jar=30013:/usr/local/jmx/config.yaml"

7、prometheus 配置

// prometheus.yml 配置文件内容

- job_name: 'tomcat'

static_configs:

- targets: ['10.1.18.249:30013']

labels:

appname: 'tx-web-oss'

可以看到已经成功监控到 tomcat 实例

其他 tomcat 实例监控的配置都类似,如果多个 tomcat 实例在同一台机器上,注意要指定不同的 jmx 端口

8、grafana 配置

从 https://grafana.com/dashboards/8563 这里下载一个模板,导入 grafana 中,略作修改即可

添加应用名变量,方便查看

最后完成的 tomcat 实例监控图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值