Apache Tomcat 集成会收集流量相关的指标,例如活跃会话数量或网络吞吐量。集成还会收集访问日志和 Catalina 日志。访问日志会解析为侧重于请求详细信息的 JSON 载荷,而 Catalina 日志针对一般详细信息进行解析。tomcat
接收器通过 JMX 从 Tomcat 服务器的 Java 虚拟机 (JVM) 收集遥测数据。
如需详细了解 Tomcat,请参阅 Apache Tomcat 文档。
前提条件
如需收集 Tomcat 遥测数据,您必须安装 Ops Agent:
- 对于指标,请安装 2.9.0 版或更高版本。
- 对于日志,请安装 2.9.0 版或更高版本。
此集成支持 Tomcat 10.x 和 9.0.x 版。
配置 Tomcat 实例
如需公开 JMX 端点,您必须在启动 JVM 时设置 com.sun.management.jmxremote.port
系统属性。我们还建议您将 com.sun.management.jmxremote.rmi.port
系统属性设置为同一端口。 如需远程公开 JMX 端点,您还必须设置 java.rmi.server.hostname
系统属性。
默认情况下,这些属性在 Tomcat 部署的 tomcat-env.sh
文件中设置。
如需使用命令行参数设置系统属性,请在启动 JVM 时在属性名称前加上 -D
。 例如,如需将 com.sun.management.jmxremote.port
设置为端口 8050
,请在启动 JVM 时指定以下内容:
-Dcom.sun.management.jmxremote.port=8050
为 Tomcat 配置 Ops Agent
按照配置 Ops Agent 指南,添加从 Tomcat 实例收集遥测数据所需的元素并重启代理。
配置示例
以下命令会创建相关配置来收集和注入 Tomcat 的遥测数据,并重启 Ops Agent。
配置日志收集
如需从 Tomcat 注入日志,您必须为 Tomcat 生成的日志创建接收器,然后为新的接收器创建流水线。
如需为 tomcat_system
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
exclude_paths |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
|
include_paths |
[/opt/tomcat/logs/catalina.out] |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* )。 |
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
type |
该值必须为 tomcat_system 。 |
|
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
如需为 tomcat_access
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
exclude_paths |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
|
include_paths |
[/opt/tomcat/logs/localhost_access_log.*.txt] |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* )。 |
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
type |
该值必须为 tomcat_access 。 |
|
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
记录的内容
logName
派生自配置中指定的接收器 ID。LogEntry
中的详细字段如下所示。
tomcat_system
日志包含 LogEntry
中的以下字段:
字段 | 类型 | 说明 |
---|---|---|
jsonPayload.level |
字符串 | 日志条目级别 |
jsonPayload.message |
字符串 | 日志消息,包括详细的堆栈轨迹(如果提供) |
jsonPayload.module |
字符串 | 日志源自的 Tomcat 模块 |
jsonPayload.source |
字符串 | 日志的来源 |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换)。 |
tomcat_access
日志包含 LogEntry
中的以下字段:
字段 | 类型 | 说明 |
---|---|---|
httpRequest |
对象 | 参见HttpRequest |
jsonPayload.host |
字符串 | Host 标头的内容 |
jsonPayload.user |
字符串 | 请求经过身份验证的用户名 |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换)。 |
配置指标收集
如需从 Tomcat 注入指标,您必须为 Tomcat 生成的指标创建接收器,然后为新的接收器创建流水线。
如需为 tomcat
指标配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
collect_jvm_metrics |
true |
配置接收器以同时收集支持的 JVM 指标。 |
collection_interval |
60s |
时长,例如 30s 或 5m 。 |
endpoint |
localhost:8050 |
JMX 服务网址或用于构造服务网址的主机和端口。此值必须采用 service:jmx:<protocol>:<sap> 或 host:port 格式。host:port 格式的值用于创建 service:jmx:rmi:///jndi/rmi://<host>:<port>/jmxrmi 的服务网址。 |
password |
将 JMX 配置为需要身份验证时配置的密码。 | |
type |
该值必须为 tomcat 。 |
|
username |
将 JMX 配置为需要身份验证时配置的用户名。 |
监控的内容
下表提供了 Ops Agent 从 Tomcat 实例收集的指标列表。
指标类型 | |
---|---|
种类、类型 受监控的资源 |
标签 |
workload.googleapis.com/tomcat.errors
|
|
CUMULATIVE 、INT64 gce_instance |
proto_handler
|
workload.googleapis.com/tomcat.max_time
|
|
GAUGE 、INT64 gce_instance |
proto_handler
|
workload.googleapis.com/tomcat.processing_time
|
|
CUMULATIVE 、INT64 gce_instance |
proto_handler
|
workload.googleapis.com/tomcat.request_count
|
|
CUMULATIVE 、INT64 gce_instance |
proto_handler
|
workload.googleapis.com/tomcat.sessions
|
|
GAUGE 、DOUBLE gce_instance |
|
workload.googleapis.com/tomcat.threads
|
|
GAUGE 、INT64 gce_instance |
proto_handler state
|
workload.googleapis.com/tomcat.traffic
|
|
CUMULATIVE 、INT64 gce_instance |
direction proto_handler
|
示例信息中心
如需查看 Tomcat 指标,您必须配置一个图表或信息中心。Cloud Monitoring 提供了一个用于集成的示例信息中心库,其中包含一些预配置的图表。如需了解如何安装这些信息中心,请参阅安装示例信息中心。
验证配置
本部分介绍如何验证您是否正确配置了 Tomcat 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。
如需验证是否已注入日志,请前往日志浏览器并运行以下查询来查看 Tomcat 日志:
resource.type="gce_instance"
(log_id("tomcat_system") OR log_id("tomcat_access"))
如需验证指标已注入,请前往 Metrics Explorer 并在 MQL 标签页中运行以下查询:
fetch gce_instance
| metric 'workload.googleapis.com/tomcat.threads'
| every 1m
后续步骤
如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。