Redis 集成会收集与性能和使用情况相关的指标。性能指标侧重于 CPU、内存和网络吞吐量,而使用情况指标侧重于密钥、命令和复制。集成还会收集 Redis 日志并将其解析为 JSON 载荷。在此过程中,角色和级层的符号会转换为易于用户理解的格式。
如需详细了解 Redis,请参阅 redis.io。
前提条件
如需收集和注入 Redis 遥测数据,您必须安装 Ops Agent 2.7.0 或更高版本。
此接收器支持 Redis 6.2 版。
为 Redis 配置 Ops Agent
按照配置 Ops Agent 指南,添加从 Redis 实例收集日志所需的元素,并重启代理。
配置示例
以下命令会创建配置文件,以收集和注入 Redis 的日志,并在 Linux 上重启 Ops Agent。
sudo tee /etc/google-cloud-ops-agent/config.yaml > /dev/null << EOF
logging:
receivers:
redis:
type: redis
service:
pipelines:
redis:
receivers:
- redis
metrics:
receivers:
redis:
type: redis
password: Strong_Password123
service:
pipelines:
redis:
receivers:
- redis
EOF
sudo service google-cloud-ops-agent restart
配置日志收集
如需从 Redis 注入日志,您必须为 Redis 生成的日志创建接收器,然后为新的接收器创建流水线。如需为 redis
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
type |
该值必须为 redis 。 |
|
include_paths |
[/var/log/redis/redis-server.log, /var/log/redis_6379.log, /var/log/redis/redis.log, /var/log/redis/default.log, /var/log/redis/redis_6379.log] |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* );例如 /var/log/redis/*.log 。 |
exclude_paths |
[] |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
记录的内容
Redis 日志在 LogEntry
中包含以下字段:
字段 | 类型 | 说明 |
---|---|---|
jsonPayload.roleChar |
字符串 | Redis 角色字符(X、C、S、M) |
jsonPayload.role |
字符串 | 从 Redis 角色字符转换(sentinel、RDB/AOF_writing_child、slave、master) |
jsonPayload.level |
字符串 | 日志条目级别 |
jsonPayload.pid |
数字 | 进程 ID |
jsonPayload.message |
字符串 | 日志消息 |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换) |
timestamp |
字符串 (Timestamp ) |
记录条目的时间 |
配置指标收集
如需从 Redis 收集指标,您必须为 Redis 指标创建接收器,然后为新接收器创建流水线。如需为 Redis 指标配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
type |
该值必须为 redis 。 |
|
address |
localhost:6379 |
由 Redis 公开的网址。 |
collection_interval |
60s |
time.Duration 值,例如 30s 或 5m 。 |
password |
用于连接到服务器的密码。 | |
insecure |
true |
设置是否使用安全 TLS 连接。如果设置为 false ,则启用 TLS。 |
insecure_skip_verify |
false |
设置是否跳过证书验证。如果 insecure 设置为 true ,则不使用 insecure_skip_verify 值。 |
cert_file |
用于要求 TLS 的连接的 TLS 证书的路径。 | |
key_file |
用于要求 TLS 的连接的 TLS 密钥的路径。 | |
ca_file |
CA 证书的路径。作为客户端,此字段会验证服务器证书。如果为空,则接收器使用系统根 CA。 |
监控的内容
下表提供了 Ops Agent 从 Redis 实例收集的指标列表。
指标类型 | |
---|---|
种类、类型 受监控的资源 |
标签 |
workload.googleapis.com/redis.clients.blocked
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.clients.connected
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.clients.max_input_buffer
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.clients.max_output_buffer
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.commands.processed
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.connections.received
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.connections.rejected
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.cpu.time
|
|
CUMULATIVE 、DOUBLE gce_instance |
state
|
workload.googleapis.com/redis.keys.evicted
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.keys.expired
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.keyspace.hits
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.keyspace.misses
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.latest_fork
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.memory.fragmentation_ratio
|
|
GAUGE 、DOUBLE gce_instance |
|
workload.googleapis.com/redis.memory.lua
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.memory.peak
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.memory.rss
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.memory.used
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.net.input
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.net.output
|
|
CUMULATIVE 、INT64 gce_instance |
|
workload.googleapis.com/redis.rdb.changes_since_last_save
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.replication.backlog_first_byte_offset
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.replication.offset
|
|
GAUGE 、INT64 gce_instance |
|
workload.googleapis.com/redis.slaves.connected
|
|
GAUGE 、INT64 gce_instance |
示例信息中心
您可以使用示例 Cloud Monitoring 信息中心查看集成中的指标。完成安装示例信息中心过程,从示例库中导入 Redis GCE 概览信息中心并查看显示您的 Redis 指标的图表。验证配置
您可以使用日志浏览器和 Metrics Explorer 来验证已正确配置 Redis 接收器。Ops Agent 可能需要一两分钟才会开始收集日志和指标。
如需验证是否已注入日志,请转到日志浏览器并运行以下查询来查看 Redis 日志:
resource.type="gce_instance"
logName=("projects/PROJECT_ID/logs/redis")
如需验证指标是否已注入,请转到 Metrics Explorer 并在 MQL 标签页中运行以下查询。
fetch gce_instance
| metric 'workload.googleapis.com/redis.connections.received'
| align rate(1m)
| every 1m
后续步骤
如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。