RabbitMQ 集成会收集消息指标,例如已传送、已发布和已丢弃的消息数量。 该集成还会收集 RabbitMQ 日志并将其解析为 JSON 载荷。结果将包含进程 ID、级别和消息。
如需详细了解 RabbitMQ,请参阅 RabbitMQ 文档。
前提条件
如需收集 RabbitMQ 遥测,您必须安装 Ops Agent:
- 对于指标,请安装 2.11.0 版或更高版本。
- 对于日志,请安装 2.12.0 或更高版本。
此集成支持 RabbitMQ 3.8 版和 3.9 版。
您必须按照使用入门说明启用 RabbitMQ 管理插件。
您必须使用 monitoring
标记配置用户。
为 RabbitMQ 配置 Ops Agent
按照配置 Ops 代理的指南,添加从 RabbitMQ 实例收集遥测所需的元素,并重启代理。
配置示例
以下命令会创建配置,以收集并注入 RabbitMQ 遥测数据,并重启 Ops Agent。
# Configures Ops Agent to collect telemetry from the app and restart Ops Agent.
set -e
# Create a back up of the existing file so existing configurations are not lost.
sudo cp /etc/google-cloud-ops-agent/config.yaml /etc/google-cloud-ops-agent/config.yaml.bak
# Configure the Ops Agent.
sudo tee /etc/google-cloud-ops-agent/config.yaml > /dev/null << EOF
metrics:
receivers:
rabbitmq:
type: rabbitmq
username: usr
password: pwd
service:
pipelines:
rabbitmq:
receivers:
- rabbitmq
logging:
receivers:
rabbitmq:
type: rabbitmq
service:
pipelines:
rabbitmq:
receivers:
- rabbitmq
EOF
sudo service google-cloud-ops-agent restart
sleep 30
配置日志收集
如需从 RabbitMQ 注入日志,您必须为 RabbitMQ 生成的日志创建接收器,然后为新接收器创建流水线。
如需为 rabbitmq
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
exclude_paths |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
|
include_paths |
[var/log/rabbitmq/*.log] |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* );例如 /var/log/rabbitmq/*.log 。 |
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
type |
该值必须为 rabbitmq 。 |
|
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
记录的内容
logName
派生自配置中指定的接收器 ID。LogEntry
中的详细字段如下所示。
rabbitmq
日志包含 LogEntry
中的以下字段:
字段 | 类型 | 说明 |
---|---|---|
jsonPayload.message |
字符串 | 日志消息,包括详细的堆栈轨迹(如果提供) |
jsonPayload.process_id |
字符串 | 发出日志的进程 ID |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换)。 |
配置指标收集
如需从 RabbitMQ 注入指标,您必须为 RabbitMQ 生成的指标创建接收器,然后为新接收器创建流水线。
如需为 rabbitmq
指标配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
ca_file |
CA 证书的路径。作为客户端,此字段会验证服务器证书。如果为空,则接收器使用系统根 CA。 | |
cert_file |
用于要求 mTLS 的连接的 TLS 证书的路径。 | |
collection_interval |
60s |
时长值,例如 30s 或 5m 。 |
endpoint |
http://localhost:15672 |
要监控的节点的网址。 |
insecure |
true |
设置是否使用安全 TLS 连接。如果设置为 false ,则启用 TLS。 |
insecure_skip_verify |
false |
设置是否跳过证书验证。如果 insecure 设置为 true ,则不使用 insecure_skip_verify 值。 |
key_file |
用于要求 mTLS 的连接的 TLS 密钥的路径。 | |
password |
用于连接到服务器的密码。 | |
type |
该值必须为 rabbbitmq 。 |
|
username |
用于连接到服务器的用户名。 |
监控的内容
下表列出了 Ops Agent 从 RabbitMQ 实例收集的指标列表。
指标类型 | |
---|---|
种类、类型 受监控的资源 |
标签 |
workload.googleapis.com/rabbitmq.consumer.count
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/rabbitmq.message.current
|
|
GAUGE 、INT64 gce_instance |
state
|
示例信息中心
要查看 RabbitMQ 指标,您必须配置图表或信息中心。Cloud Monitoring 提供了一个用于集成的示例信息中心库,其中包含一些预配置的图表。如需了解如何安装这些信息中心,请参阅安装示例信息中心。
验证配置
本部分介绍如何验证是否已正确配置 RabbitMQ 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。
如需验证日志是否已提取,请转到日志浏览器并运行以下查询以查看 RabbitMQ 日志:
resource.type="gce_instance"
log_id("rabbitmq")
如需验证指标已注入,请前往 Metrics Explorer 并在 MQL 标签页中运行以下查询:
fetch gce_instance
| metric 'workload.googleapis.com/rabbitmq.message.current'
| every 1m
后续步骤
如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。