Apache CouchDB 集成会收集与流量相关的指标,例如对节点发出的请求数以及来自节点的响应数。它还会收集数据库指标,例如操作数以及已打开的操作的数量。 该集成会收集常规 CouchDB 日志以及访问日志,并将其解析为 JSON 载荷。结果将包含用户、主机、级别和消息字段。
如需详细了解 CouchDB,请参阅 Apache CouchDB 文档。
前提条件
如需收集 CouchDB 遥测数据,您必须安装 Ops Agent:
- 对于指标,请安装 2.10.0 版或更高版本。
- 对于日志,请安装 2.11.0 版或更高版本。
此集成支持 CouchDB 2.3.x 和 3.1 及更高版本。
配置 CouchDB 实例
此集成不需要对 CouchDB 3.4.0 之前的版本或基于 Debian 的发行版进行任何其他配置。
从 3.4.0 版开始,CouchDB 在基于 RPM 的发行版(如 RHEL 或 Rocky Linux)上的行为有所不同。如需让 CouchDB 在此类系统上使用此日志记录接收器的默认配置,您必须将 Apache CouchDB 配置为写入 /var/log/couchdb/couchdb.log,而不是 journald。
如需将日志写入 /var/log/couchdb/couchdb.log,请完成以下步骤:
- 创建 - /opt/couchdb/etc/local.d/ops-agent-filelog.ini文件。
- 将以下代码行添加到文件中: - [log] writer = file file = /var/log/couchdb/couchdb.log level = info
- 重启 Apache CouchDB: - sudo systemctl restart couchdb
为 CouchDB 配置 Ops Agent
按照配置 Ops Agent 指南,添加从 CouchDB 实例收集遥测数据所需的元素并重启代理。
配置示例
以下命令会创建相关配置来收集和注入 CouchDB 的遥测数据:
为使这些更改生效,您必须重启 Ops Agent:
Linux
- 要重启代理,请在您的实例上运行以下命令:
sudo systemctl restart google-cloud-ops-agent 
- 如需确认代理已重启,请运行以下命令并验证“Metrics Agent”和“Logging Agent”组件是否已启动:
sudo systemctl status "google-cloud-ops-agent*" 
Windows
- 使用 RDP 或类似工具连接到您的实例,然后登录到 Windows。
- 右键点击 PowerShell 图标并选择 Run as Administrator,以管理员权限打开 PowerShell 终端
- 如需重启代理,请运行以下 PowerShell 命令:
Restart-Service google-cloud-ops-agent -Force 
- 如需确认代理已重启,请运行以下命令并验证“Metrics Agent”和“Logging Agent”组件是否已启动:
Get-Service google-cloud-ops-agent* 
配置日志收集
如需从 CouchDB 注入日志,您必须为 CouchDB 生成的日志创建接收器,然后为新的接收器创建流水线。
如需为 couchdb 日志配置接收器,请指定以下字段:
| 字段 | 默认值 | 说明 | 
|---|---|---|
| exclude_paths | 要从 include_paths匹配的集合中排除的文件系统路径模式列表。 | |
| include_paths | [/var/log/couchdb/couchdb.log] | 要通过对每个文件执行 tail 来读取的文件系统路径列表。路径中可以使用通配符 ( *);例如/var/log/couchdb*/*.log。 | 
| record_log_file_path | false | 如果设置为 true,则从中获取日志记录的特定文件的路径将作为agent.googleapis.com/log_file_path标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 | 
| type | 该值必须为 couchdb。 | |
| wildcard_refresh_interval | 60s | include_paths中通配符文件路径的刷新间隔。指定为时长,例如30s或2m。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 | 
记录的内容
logName 派生自配置中指定的接收器 ID。LogEntry 中的详细字段如下所示。
couchdb 日志包含 LogEntry 中的以下字段:
| 字段 | 类型 | 说明 | 
|---|---|---|
| httpRequest | 对象 | 参见 HttpRequest | 
| jsonPayload.host | 字符串 | 主机实例名称 | 
| jsonPayload.level | 字符串 | 日志条目级别 | 
| jsonPayload.message | 字符串 | 日志消息 | 
| jsonPayload.node | 字符串 | 节点实例名称 | 
| jsonPayload.path | 字符串 | 请求路径 | 
| jsonPayload.pid | 字符串 | 进程 ID | 
| jsonPayload.remote_user | 字符串 | 请求经过身份验证的用户名 | 
| jsonPayload.status_message | 字符串 | 状态代码消息 | 
| severity | 字符串 ( LogSeverity) | 日志条目级别(已转换)。 | 
配置指标收集
如需从 CouchDB 注入指标,您必须为 CouchDB 生成的指标创建接收器,然后为新的接收器创建流水线。
此接收器不支持在配置中使用多个实例,例如,监控多个端点。所有这些实例都会写入相同的时序,并且 Cloud Monitoring 无法区分它们。
如需为 couchdb 指标配置接收器,请指定以下字段:
| 字段 | 默认值 | 说明 | 
|---|---|---|
| collection_interval | 60s | 时长值,例如 30s或5m。 | 
| password | 用于连接到服务器的密码。 | |
| server_status_url | http://localhost:5984 | CouchDB 公开的网址。 | 
| type | 该值必须为 couchdb。 | |
| username | 用于连接到服务器的用户名。 | 
监控的内容
下表提供了 Ops Agent 从 CouchDB 实例收集的指标列表。
| 指标类型 | |
|---|---|
| 种类、类型 受监控的资源 | 标签 | 
| workload.googleapis.com/couchdb.average_request_time | |
| GAUGE、DOUBLEgce_instance | |
| workload.googleapis.com/couchdb.database.open | |
| GAUGE、INT64gce_instance | |
| workload.googleapis.com/couchdb.database.operations | |
| CUMULATIVE、INT64gce_instance | operation | 
| workload.googleapis.com/couchdb.file_descriptor.open | |
| GAUGE、INT64gce_instance | |
| workload.googleapis.com/couchdb.httpd.bulk_requests | |
| CUMULATIVE、INT64gce_instance | |
| workload.googleapis.com/couchdb.httpd.requests | |
| CUMULATIVE、INT64gce_instance | http_method | 
| workload.googleapis.com/couchdb.httpd.responses | |
| CUMULATIVE、INT64gce_instance | http_status_code | 
| workload.googleapis.com/couchdb.httpd.views | |
| CUMULATIVE、INT64gce_instance | view | 
验证配置
本部分介绍如何验证您是否正确配置了 CouchDB 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。
如需验证 CouchDB 日志是否已发送到 Cloud Logging,请执行以下操作:
- 
在 Google Cloud 控制台中,转到 Logs Explorer 页面: 如果您使用搜索栏查找此页面,请选择子标题为 Logging 的结果。 
- 在编辑器中输入以下查询,然后点击运行查询:
      
 resource.type="gce_instance" log_id("couchdb")
如需验证 CouchDB 指标是否已发送到 Cloud Monitoring,请执行以下操作:
- 
在 Google Cloud 控制台中,前往 leaderboard Metrics Explorer 页面: 如果您使用搜索栏查找此页面,请选择子标题为监控的结果。 
- 在查询构建器窗格的工具栏中,选择名为 code MQL 或 code PromQL 的按钮。
- 验证已在PromQL 切换开关中选择 PromQL。语言切换开关位于同一工具栏中,用于设置查询的格式。
- 在编辑器中输入以下查询,然后点击运行查询:
      
 {"workload.googleapis.com/couchdb.database.open", monitored_resource="gce_instance"}
查看信息中心
如需查看 CouchDB 指标,您必须配置一个图表或信息中心。 CouchDB 集成服务可为您提供一个或多个信息中心。在您配置集成并且 Ops Agent 开始收集指标数据后,所有信息中心都会自动安装。
您还可以在不安装集成的情况下查看信息中心的静态预览。
如需查看已安装的信息中心,请执行以下操作:
- 
在 Google Cloud 控制台中,前往  信息中心页面: 信息中心页面:如果您使用搜索栏查找此页面,请选择子标题为监控的结果。 
- 选择信息中心列表标签页,然后选择集成类别。
- 点击您要查看的信息中心的名称。
如果您已配置集成,但尚未安装信息中心,请检查 Ops Agent 是否正在运行。如果信息中心内没有图表的指标数据,则信息中心的安装将失败。Ops Agent 开始收集指标后,系统会为您安装信息中心。
如需查看信息中心的静态预览,请执行以下操作:
- 
在 Google Cloud 控制台中,前往  集成页面: 集成页面:如果您使用搜索栏查找此页面,请选择子标题为监控的结果。 
- 点击 Compute Engine 部署平台过滤条件。
- 找到 CouchDB 的条目,然后点击查看详细信息。
- 选择信息中心标签页以查看静态预览。如果信息中心已安装,您可以通过点击查看信息中心来转到信息中心。
如需详细了解 Cloud Monitoring 中的信息中心,请参阅信息中心和图表。
如需详细了解如何使用集成页面,请参阅管理集成。
安装提醒政策
提醒政策会指示 Cloud Monitoring 在满足指定条件时通知您。 CouchDB 集成包含一项或多项提醒政策供您使用。您可以从 Monitoring 中的集成页面查看和安装这些提醒政策。
如需查看可用提醒政策的说明并安装它们,请执行以下操作:
- 
在 Google Cloud 控制台中,前往  集成页面: 集成页面:如果您使用搜索栏查找此页面,请选择子标题为监控的结果。 
- 找到 CouchDB 的条目,然后点击查看详细信息。
- 选择提醒标签页。此标签页提供可用提醒政策的说明,并提供一个安装政策的界面。
- 安装提醒政策。提醒政策需要知道将提醒触发的通知发送到何处,因此它们需要您提供信息才能进行安装。如需安装提醒政策,请执行以下操作:
        - 从可用提醒政策列表中,选择您要安装的提醒政策。
- 在配置通知部分中,选择一个或多个通知渠道。您可以选择禁止使用通知渠道,但如果您这样做,则您的提醒政策将以静默方式触发。您可以在 Monitoring 中查看其状态,但不会收到通知。 - 如需详细了解通知渠道,请参阅管理通知渠道。 
- 点击创建政策。
 
如需详细了解 Cloud Monitoring 中的提醒政策,请参阅提醒简介。
如需详细了解如何使用集成页面,请参阅管理集成。
后续步骤
如需查看有关如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请观看安装 Ops Agent 以排查第三方应用的问题视频。