MongoDB

使用集合让一切井井有条 根据您的偏好保存内容并对其进行分类。

MongoDB 集成主要收集数据库指标,例如操作数和对象数以及资源用量。该集成还会收集日志并将其解析为 JSON 载荷。结果将包含上下文、组件、级别和消息字段。

如需详细了解 MongoDB,请参阅 MongoDB 文档

前提条件

如需收集 MongoDB 遥测数据,您必须安装 Ops Agent

  • 对于指标,请安装 2.19.0 版或更高版本。
  • 对于日志,请安装 2.10.0 版或更高版本。

该集成支持 MongoDB 2.6、3.x、4.x 和 5.0 版。

为 MongoDB 配置 Ops Agent

按照配置 Ops Agent 指南,添加从 MongoDB 实例收集遥测数据所需的元素并重启代理

配置示例

以下命令会创建相关配置来收集和注入 MongoDB 的遥测数据,并重启 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:
    mongodb:
      type: mongodb
      insecure: true
  service:
    pipelines:
      mongo:
        receivers: [mongodb]
logging:
  receivers:
    mongodb:
      type: mongodb
  service:
    pipelines:
      mongo:
        receivers: [mongodb]
EOF

sudo service google-cloud-ops-agent restart
sleep 60

配置日志收集

如需从 MongoDB 注入日志,您必须为 MongoDB 生成的日志创建接收器,然后为新的接收器创建流水线。

如需为 mongodb 日志配置接收器,请指定以下字段:

字段 默认 说明
exclude_paths 要从 include_paths 匹配的集合中排除的文件系统路径模式列表。
include_paths [/var/log/mongodb/mongod.log*] 要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (*);例如 /var/log/mongodb/*.log
record_log_file_path false 如果设置为 true,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。
type 该值必须为 mongodb
wildcard_refresh_interval 60s include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration,例如 30s2m;必须是 1s 的倍数。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。

记录的内容

logName 派生自配置中指定的接收器 ID。LogEntry 中的详细字段如下所示。

mongodb 日志包含 LogEntry 中的以下字段:

字段 类型 说明
jsonPayload.component 字符串 日志消息的分类。如需查看完整列表,请参阅 MongoDB 文档
jsonPayload.ctx 字符串 发出日志语句的线程的名称。
jsonPayload.id 数字 日志 ID。
jsonPayload.message 字符串 日志消息。
jsonPayload.attributes 对象(可选) 包含提供的其他任何特性的一个或多个键值对的对象。
jsonPayload.context 字符串
jsonPayload.severity 字符串 日志条目级别。
severity 字符串 (LogSeverity) 日志条目级别(已转换)。

配置指标收集

如需从 MongoDB 注入指标,您必须为 MongoDB 生成的指标创建接收器,然后为新的接收器创建流水线。

如需为 mongodb 指标配置接收器,请指定以下字段:

字段 默认 说明
ca_file CA 证书的路径。作为客户端,此字段会验证服务器证书。如果为空,则接收器使用系统根 CA。
cert_file 用于要求 mTLS 的连接的 TLS 证书的路径。
collection_interval 60s time.Duration 值,例如 30s5m
endpoint http://localhost:27017 主机名、IP 地址或 UNIX 网域套接字。端口可以采用:格式进行指定。如果未指定端口,则系统会使用默认端口 27017。
insecure true 设置是否使用安全 TLS 连接。如果设置为 false,则启用 TLS。
insecure_skip_verify false 设置是否跳过证书验证。如果 insecure 设置为 true,则不使用 insecure_skip_verify 值。
key_file 用于要求 mTLS 的连接的 TLS 密钥的路径。
password 用于对 MongoDB 实例进行身份验证的密码。如果设置了用户名,则必须指定该字段。
type 该值必须为 mongodb
username 用于对 MongoDB 实例进行身份验证的用户名。如果设置了密码,则必须指定该字段。

监控的内容

下表提供了 Ops Agent 从 MongoDB 实例收集的指标列表。

指标类型
种类、类型
受监控的资源
标签
workload.googleapis.com/mongodb.cache.operations
CUMULATIVEINT64
gce_instance
type
workload.googleapis.com/mongodb.collection.count
GAUGEINT64
gce_instance
database
workload.googleapis.com/mongodb.connection.count
GAUGEINT64
gce_instance
database
type
workload.googleapis.com/mongodb.cursor.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.cursor.timeout.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.data.size
GAUGEINT64
gce_instance
database
workload.googleapis.com/mongodb.database.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.document.operation.count
GAUGEINT64
gce_instance
database
operation
workload.googleapis.com/mongodb.global_lock.time
CUMULATIVEINT64
gce_instance
 
workload.googleapis.com/mongodb.index.access.count
GAUGEINT64
gce_instance
collection
database
workload.googleapis.com/mongodb.index.count
GAUGEINT64
gce_instance
database
workload.googleapis.com/mongodb.index.size
GAUGEINT64
gce_instance
database
workload.googleapis.com/mongodb.memory.usage
GAUGEINT64
gce_instance
database
type
workload.googleapis.com/mongodb.network.io.receive
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.network.io.transmit
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.network.request.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.object.count
GAUGEINT64
gce_instance
database
workload.googleapis.com/mongodb.operation.count
CUMULATIVEINT64
gce_instance
operation
workload.googleapis.com/mongodb.operation.time
CUMULATIVEINT64
gce_instance
operation
workload.googleapis.com/mongodb.session.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/mongodb.storage.size
CUMULATIVEINT64
gce_instance
database

示例信息中心

如需查看 MongoDB 指标,您必须配置一个图表或信息中心。Cloud Monitoring 提供了一个用于集成的示例信息中心库,其中包含一些预配置的图表。如需了解如何安装这些信息中心,请参阅安装示例信息中心

验证配置

本部分介绍如何验证您是否正确配置了 MongoDB 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。

如需验证是否已注入日志,请转到日志浏览器并运行以下查询来查看 MongoDB 日志:

resource.type="gce_instance"
log_id("mongodb")

如需验证指标已注入,请前往 Metrics Explorer 并在 MQL 标签页中运行以下查询:

fetch gce_instance
| metric 'workload.googleapis.com/mongodb.memory.usage'
| every 1m

后续步骤

如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。