JVM 集成会收集通过 Java Management Extensions (JMX) 公开的 JVM 指标。该集成主要收集有关内存和垃圾回收的指标。您还可以使用其他运行时指标(如线程数和已加载的类)。
如需详细了解 JVM,请参阅 JVM 文档。
前提条件
如需收集 JVM 遥测数据,您必须安装 Ops Agent:
- 对于指标,请安装 2.2.0 版或更高版本。
此集成支持 JVM 版本 Java 16 和 Java 11。
配置您的 JVM 实例
如需公开 JMX 端点,您必须在启动 JVM 时设置 com.sun.management.jmxremote.port
系统属性。我们还建议您将 com.sun.management.jmxremote.rmi.port
系统属性设置为同一端口。
如需远程公开 JMX 端点,您还必须设置 java.rmi.server.hostname
系统属性。
如需使用命令行参数设置系统属性,请在启动 JVM 时在属性名称前加上 -D
。
例如,如需将 com.sun.management.jmxremote.port
设置为端口 9999
,请在启动 JVM 时指定以下内容:
-Dcom.sun.management.jmxremote.port=9999
为 JVM 配置 Ops Agent
按照配置 Ops Agent 指南,添加从 JVM 实例收集遥测数据所需的元素并重启代理。
配置示例
以下命令会创建相关配置来收集和注入 JVM 的遥测数据,并重启 Ops Agent。
配置指标收集
如需从 JVM 注入指标,您必须为 JVM 生成的指标创建接收器,然后为新的接收器创建流水线。
此接收器不支持在配置中使用多个实例,例如,监控多个端点。所有这些实例都会写入相同的时序,并且 Cloud Monitoring 无法区分它们。
如需为 jvm
指标配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
collection_interval |
60s |
时长值,例如 30s 或 5m 。 |
endpoint |
localhost:9999 |
JMX 服务网址或用于构造服务网址的主机和端口。此值必须采用 service:jmx:<protocol>:<sap> 或 host:port 格式。host:port 格式的值用于创建 service:jmx:rmi:///jndi/rmi://<host>:<port>/jmxrmi 的服务网址。 |
password |
将 JMX 配置为需要身份验证时配置的密码。 | |
type |
该值必须为 jvm 。 |
|
username |
将 JMX 配置为需要身份验证时配置的用户名。 |
监控的内容
下表提供了 Ops Agent 从 JVM 实例收集的指标列表。
指标类型 | |
---|---|
种类、类型 受监控的资源 |
标签 |
workload.googleapis.com/jvm.classes.loaded
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.gc.collections.count
|
|
CUMULATIVE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.gc.collections.elapsed
|
|
CUMULATIVE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.memory.heap.committed
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.heap.init
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.heap.max
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.heap.used
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.nonheap.committed
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.nonheap.init
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.nonheap.max
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.nonheap.used
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/jvm.memory.pool.committed
|
|
GAUGE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.memory.pool.init
|
|
GAUGE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.memory.pool.max
|
|
GAUGE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.memory.pool.used
|
|
GAUGE 、INT64 gce_instance |
name
|
workload.googleapis.com/jvm.threads.count
|
|
GAUGE 、INT64 gce_instance |
验证配置
本部分介绍如何验证您是否正确配置了 JVM 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。
如需验证 JVM 指标是否已发送到 Cloud Monitoring,请执行以下操作:
-
在 Google Cloud 控制台中,转到 leaderboard Metrics Explorer 页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 在查询构建器窗格的工具栏中,选择名为 code MQL 或 code PromQL 的按钮。
- 验证已在MQL切换开关中选择 MQL。语言切换开关位于同一工具栏中,用于设置查询的格式。
- 在编辑器中输入以下查询,然后点击运行查询:
fetch gce_instance | metric 'workload.googleapis.com/jvm.memory.heap.used' | every 1m
查看信息中心
如需查看 JVM 指标,您必须配置一个图表或信息中心。 JVM 集成服务可为您提供一个或多个信息中心。在您配置集成并且 Ops Agent 开始收集指标数据后,所有信息中心都会自动安装。
您还可以在不安装集成的情况下查看信息中心的静态预览。
如需查看已安装的信息中心,请执行以下操作:
-
在 Google Cloud 控制台中,转到 信息中心页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 选择信息中心列表标签页,然后选择集成类别。
- 点击您要查看的信息中心的名称。
如果您已配置集成,但尚未安装信息中心,请检查 Ops Agent 是否正在运行。如果信息中心内没有图表的指标数据,则信息中心的安装将失败。Ops Agent 开始收集指标后,系统会为您安装信息中心。
如需查看信息中心的静态预览,请执行以下操作:
-
在 Google Cloud 控制台中,转到 集成页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 点击 Compute Engine 部署平台过滤条件。
- 找到 JVM 的条目,然后点击查看详细信息。
- 选择信息中心标签页以查看静态预览。如果信息中心已安装,您可以通过点击查看信息中心来转到信息中心。
如需详细了解 Cloud Monitoring 中的信息中心,请参阅信息中心和图表。
如需详细了解如何使用集成页面,请参阅管理集成。
安装提醒政策
提醒政策会指示 Cloud Monitoring 在满足指定条件时通知您。 JVM 集成包含一项或多项提醒政策供您使用。您可以从 Monitoring 中的集成页面查看和安装这些提醒政策。
如需查看可用提醒政策的说明并安装它们,请执行以下操作:
-
在 Google Cloud 控制台中,转到 集成页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 找到 JVM 的条目,然后点击查看详细信息。
- 选择提醒标签页。此标签页提供可用提醒政策的说明,并提供一个安装政策的界面。
- 安装提醒政策。提醒政策需要知道将提醒触发的通知发送到何处,因此它们需要您提供信息才能进行安装。如需安装提醒政策,请执行以下操作:
- 从可用提醒政策列表中,选择您要安装的提醒政策。
在配置通知部分中,选择一个或多个通知渠道。您可以选择禁止使用通知渠道,但如果您这样做,则您的提醒政策将以静默方式触发。您可以在 Monitoring 中查看其状态,但不会收到通知。
如需详细了解通知渠道,请参阅管理通知渠道。
- 点击创建政策。
如需详细了解 Cloud Monitoring 中的提醒政策,请参阅提醒简介。
如需详细了解如何使用集成页面,请参阅管理集成。
后续步骤
如需查看有关如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请观看安装 Ops Agent 以排查第三方应用的问题视频。