- 필수 기능
- 시작하기
- Glossary
- 표준 속성
- Guides
- Agent
- 통합
- 개방형텔레메트리
- 개발자
- Administrator's Guide
- API
- Datadog Mobile App
- CoScreen
- Cloudcraft
- 앱 내
- 서비스 관리
- 인프라스트럭처
- 애플리케이션 성능
- APM
- Continuous Profiler
- 스팬 시각화
- 데이터 스트림 모니터링
- 데이터 작업 모니터링
- 디지털 경험
- 소프트웨어 제공
- 보안
- AI Observability
- 로그 관리
- 관리
Supported OS
Redis를 데이터베이스, 캐시 또는 메시지 큐로 사용하든 관계없이, 본 통합은 Redis 서버, 클라우드 서비스, 제공하는 인프라스트럭처 일부의 문제를 추적합니다. Datadog 에이전트의 Redis 점검을 사용하여 다음과 관련된 메트릭 정보를 수집합니다.
Redis 점검은 Datadog 에이전트 패키지에 포함되어 있으므로 Redis 서버에 추가 설치할 필요가 없습니다.
호스트에서 실행 중인 에이전트에 대해 이 점검을 구성하려면:
에이전트 설정 디렉토리의 루트에 있는 conf.d/
폴더에서 redisdb.d/conf.yaml
파일을 편집합니다. 다음 파라미터를 업데이트해야 할 수도 있습니다. 사용 가능한 모든 설정 옵션은 redisdb.d/conf.yaml 샘플을 참조하세요.
init_config:
instances:
## @param host - string - required
## Enter the host to connect to.
- host: localhost
## @param port - integer - required
## Enter the port of the host to connect to.
port: 6379
## @param username - string - optional
## The username to use for the connection. Redis 6+ only.
#
# username: <USERNAME>
## @param password - string - optional
## The password to use for the connection.
#
# password: <PASSWORD>
Redis 6+ 및 ACL을 사용한다면 사용자에게 최소 데이터베이스 수준 DB Viewer
권한, 클러스터 환경에서 작동하는 경우 Cluster Viewer
권한, +config|get +info +slowlog|get
ACL 규칙이 있는지 확인하세요. 자세한 내용은 데이터베이스 액세스 제어를 참조하세요.
Agent 버전 6.0 이상에서 사용 가능
Datadog 에이전트에서 로그 수집은 기본적으로 사용하지 않도록 설정되어 있습니다. datadog.yaml
파일에서 로그 수집을 사용하도록 설정합니다.
logs_enabled: true
redisdb.d/conf.yaml
의 하단에서 이 설정 블록의 주석 처리를 제거하고 편집합니다.
logs:
- type: file
path: /var/log/redis_6379.log
source: redis
service: myapplication
path
와 service
파라미터 값을 내 환경에 맞게 변경 및 설정하세요. 사용할 수 있는 설정 옵션 전체를 보려면 redisdb.yaml 샘플을 참고하세요.
Datadog APM은 Redis와 통합되어 분산 시스템 전체의 트레이스를 확인합니다. Datadog 에이전트 v6+에서는 트레이스 수집이 기본적으로 활성화되어 있습니다. 트레이스 수집을 시작하려면 다음 지침을 따르세요.
컨테이너에서 실행 중인 에이전트에 이 점검을 구성하는 방법:
애플리케이션 컨테이너에 자동탐지 통합 템플릿을 Docker 레이블로 설정하세요.
LABEL "com.datadoghq.ad.check_names"='["redisdb"]'
LABEL "com.datadoghq.ad.init_configs"='[{}]'
LABEL "com.datadoghq.ad.instances"='[{"host":"%%host%%","port":"6379","password":"%%env_REDIS_PASSWORD%%"}]'
참고: "%%env_<ENV_VAR>%%"
템플릿 변수 로직은 암호를 일반 텍스트로 저장하지 않기 위해 사용하므로, REDIS_PASSWORD
환경 변수가 에이전트 컨테이너에 설정되어야 합니다. 자세한 내용은 자동 탐지 템플릿 변수 설명서를 참조하세요. 또는 에이전트는 secrets
패키지를 활용하여 모든 시크릿 관리 백엔드(예: HashiCorp Vault 또는 AWS Secrets Manager)를 사용할 수 있습니다.
Agent 버전 6.0 이상에서 사용 가능
기본적으로 로그 수집은 Datadog 에이전트에서 비활성화되어 있습니다. 활성화하려면 도커(Docker) 로그 수집을 참고하세요.
그런 다음 도커(Docker) 레이블로 로그 통합을 설정하세요.
LABEL "com.datadoghq.ad.logs"='[{"source":"redis","service":"<YOUR_APP_NAME>"}]'
컨테이너화된 앱용 APM은 Agent v6+에서 지원되지만 트레이스 수집을 시작하려면 추가 구성이 필요합니다.
Agent 컨테이너의 필수 환경 변수:
파라미터 | 값 |
---|---|
<DD_API_KEY> | api_key |
<DD_APM_ENABLED> | true |
<DD_APM_NON_LOCAL_TRAFFIC> | true |
사용 가능한 환경 변수 및 설정의 전체 목록은 도커(Docker) 애플리케이션 추적을 참조하세요.
그런 다음 Redis에 요청하는 애플리케이션 컨테이너를 계측하고 DD_AGENT_HOST
를 에이전트 컨테이너의 이름으로 설정합니다.
쿠버네티스에서 실행 중인 에이전트에 이 점검을 구성하는 방법:
메트릭을 수집하려면 다음 파라미터와 값을 자동탐지 템플릿에 설정합니다. Redis 포드의 쿠버네티스 어노테이션(아래 표시) 또는 로컬 파일, ConfigMap, 키-값 저장소, Datadog Operator 매니페스트 또는 헬름(Helm) 차트를 통해 이를 수행할 수 있습니다.
파라미터 | 값 |
---|---|
<INTEGRATION_NAME> | ["redisdb"] |
<INIT_CONFIG> | [{}] |
<INSTANCE_CONFIG> | [{"host": "%%host%%","port":"6379","password":"%%env_REDIS_PASSWORD%%"}] |
주석 v1(Datadog 에이전트 v7.36 이하용)
apiVersion: v1
kind: Pod
metadata:
name: redis
annotations:
ad.datadoghq.com/redis.check_names: '["redisdb"]'
ad.datadoghq.com/redis.init_configs: '[{}]'
ad.datadoghq.com/redis.instances: |
[
{
"host": "%%host%%",
"port":"6379",
"password":"%%env_REDIS_PASSWORD%%"
}
]
labels:
name: redis
spec:
containers:
- name: redis
image: redis:latest
ports:
- containerPort: 6379
주석 v2(Datadog 에이전트 v7.36 이상용)
apiVersion: v1
kind: Pod
metadata:
name: redis
annotations:
ad.datadoghq.com/redis.checks: |
{
"redisdb": {
"init_config": {},
"instances": [
{
"host": "%%host%%",
"port":"6379",
"password":"%%env_REDIS_PASSWORD%%"
}
]
}
}
labels:
name: redis
spec:
containers:
- name: redis
image: redis:latest
ports:
- containerPort: 6379
참고: "%%env_<ENV_VAR>%%"
템플릿 변수 로직은 암호를 일반 텍스트로 저장하지 않기 위해 사용하므로, REDIS_PASSWORD
환경 변수가 에이전트 컨테이너에 설정되어야 합니다. 자동 탐지 템플릿 변수 설명서를 참조하세요. 또는 에이전트는 secrets
패키지를 활용하여 모든 시크릿 관리 백엔드(예: HashiCorp Vault 또는 AWS Secrets Manager)를 사용할 수 있습니다.
에이전트 버전 6.0 이상에서 사용 가능
Datadog 에이전트에서 로그 수집은 기본값으로 비활성화되어 있습니다. 이를 활성화하려면 쿠버네티스(Kubernetes) 로그 수집을 참조하세요.
그런 다음 자동탐지 템플릿에서 다음을 파라미터를 설정합니다. Redis 포드에서 쿠버네티스(Kubernetes) 어노테이션(아래 표시)을 사용하거나 로컬 파일, ConfigMap, 키-값 저장소, Datadog Operator 매니페스트 또는 헬름(Helm) 차트를 사용하여 이 작업을 수행할 수 있습니다.
파라미터 | 값 |
---|---|
<LOG_CONFIG> | [{"source":"redis","service":"<YOUR_APP_NAME>"}] |
주석 v1/v2
apiVersion: v1
kind: Pod
metadata:
name: redis
annotations:
ad.datadoghq.com/redis.logs: '[{"source":"redis","service":"<YOUR_APP_NAME>"}]'
labels:
name: redis
spec:
containers:
- name: redis
image: redis:latest
ports:
- containerPort: 6379
컨테이너화된 앱용 APM은 Agent v6+를 실행하는 호스트에서 지원되지만 트레이스 수집을 시작하려면 추가 구성이 필요합니다.
Agent 컨테이너의 필수 환경 변수:
파라미터 | 값 |
---|---|
<DD_API_KEY> | api_key |
<DD_APM_ENABLED> | true |
<DD_APM_NON_LOCAL_TRAFFIC> | true |
사용 가능한 환경 변수 및 구성의 전체 목록은 Kubernetes 애플리케이션 추적 및 Kubernetes 데몬 설정을 참조하세요.
그런 다음 Redis에 요청하는 애플리케이션 컨테이너를 계측합니다.
ECS에서 실행 중인 에이전트에 이 점검을 구성하는 방법:
애플리케이션 컨테이너에 자동탐지 통합 템플릿을 Docker 레이블로 설정하세요.
{
"containerDefinitions": [{
"name": "redis",
"image": "redis:latest",
"dockerLabels": {
"com.datadoghq.ad.check_names": "[\"redisdb\"]",
"com.datadoghq.ad.init_configs": "[{}]",
"com.datadoghq.ad.instances": "[{\"host\":\"%%host%%\",\"port\":\"6379\",\"password\":\"%%env_REDIS_PASSWORD%%\"}]"
}
}]
}
참고: "%%env_<ENV_VAR>%%"
템플릿 변수 로직은 암호를 일반 텍스트로 저장하지 않기 위해 사용하므로, REDIS_PASSWORD
환경 변수가 에이전트 컨테이너에 설정되어야 합니다. 자동 탐지 템플릿 변수 설명서를 참조하세요. 또는 에이전트는 secrets
패키지를 활용하여 모든 시크릿 관리 백엔드(예: HashiCorp Vault 또는 AWS Secrets Manager)를 사용할 수 있습니다.
에이전트 버전 6.0 이상에서 사용 가능
기본적으로 로그 수집은 Datadog 에이전트에서 비활성화되어 있습니다. 활성화하려면 ECS 로그 수집을 참조하세요.
그런 다음 도커(Docker) 레이블로 로그 통합을 설정하세요.
{
"containerDefinitions": [{
"name": "redis",
"image": "redis:latest",
"dockerLabels": {
"com.datadoghq.ad.logs": "[{\"source\":\"redis\",\"service\":\"<YOUR_APP_NAME>\"}]"
}
}]
}
컨테이너화된 앱용 APM은 Agent v6+에서 지원되지만 트레이스 수집을 시작하려면 추가 구성이 필요합니다.
Agent 컨테이너의 필수 환경 변수:
파라미터 | 값 |
---|---|
<DD_API_KEY> | api_key |
<DD_APM_ENABLED> | true |
<DD_APM_NON_LOCAL_TRAFFIC> | true |
사용 가능한 환경 변수 및 설정의 전체 목록은 도커(Docker) 애플리케이션 추적을 참조하세요.
그런 다음 Redis에 요청하는 애플리케이션 컨테이너를 계측하고 DD_AGENT_HOST
를 EC2 비공개 IP 주소로 설정합니다.
에이전트 상태 하위 명령을 실행하고 점검 섹션에서 redisdb
를 찾습니다.
redis.active_defrag.hits (gauge) | Number of value reallocations performed by the active defragmentation process. Shown as operation |
redis.active_defrag.key_hits (gauge) | Number of keys that were actively defragmented. Shown as key |
redis.active_defrag.key_misses (gauge) | Number of keys that were skipped by. Shown as key |
redis.active_defrag.misses (gauge) | Number of aborted value reallocations started by the active defragmentation process. Shown as operation |
redis.active_defrag.running (gauge) | Whether active defragmentation is running or not. |
redis.aof.buffer_length (gauge) | Size of the AOF buffer. Shown as byte |
redis.aof.last_rewrite_time (gauge) | Duration of the last AOF rewrite. Shown as second |
redis.aof.loading_eta_seconds (gauge) | The estimated amount of time left to load. Shown as second |
redis.aof.loading_loaded_bytes (gauge) | The amount of bytes to load. Shown as byte |
redis.aof.loading_loaded_perc (gauge) | The percent loaded. Shown as percent |
redis.aof.loading_total_bytes (gauge) | The total amount of bytes already loaded. Shown as byte |
redis.aof.rewrite (gauge) | Flag indicating a AOF rewrite operation is on-going. |
redis.aof.size (gauge) | AOF current file size (aofcurrentsize). Shown as byte |
redis.clients.biggest_input_buf (gauge) | The biggest input buffer among current client connections [v3 & v4]. |
redis.clients.blocked (gauge) | The number of connections waiting on a blocking call. Shown as connection |
redis.clients.longest_output_list (gauge) | The longest output list among current client connections [v3 & v4]. |
redis.clients.recent_max_input_buffer (gauge) | The biggest input buffer among recent client connections [v5+]. |
redis.clients.recent_max_output_buffer (gauge) | The longest output buffer among recent client connections [v5+]. |
redis.command.calls (gauge) | The number of times a redis command has been called, tagged by 'command', e.g. 'command:append'. Enable in Agent's redisdb.yaml with the command_stats option. |
redis.command.usec_per_call (gauge) | The CPU time consumed per redis command call, tagged by 'command', e.g. 'command:append'. Enable in Agent's redisdb.yaml with the command_stats option. |
redis.cpu.sys (gauge) | System CPU consumed by the Redis server. |
redis.cpu.sys_children (gauge) | System CPU consumed by the background processes. |
redis.cpu.sys_main_thread (gauge) | System CPU consumed by the Redis server main thread. [v7+]. |
redis.cpu.user (gauge) | User CPU consumed by the Redis server. |
redis.cpu.user_children (gauge) | User CPU consumed by the background processes. |
redis.cpu.user_main_thread (gauge) | User CPU consumed by the Redis server main thread. [v7+]. |
redis.expires (gauge) | The number of keys with an expiration. Shown as key |
redis.expires.percent (gauge) | Percentage of total keys with an expiration. Shown as percent |
redis.info.latency_ms (gauge) | The latency of the redis INFO command. Shown as millisecond |
redis.key.length (gauge) | The number of elements in a given key, tagged by key, e.g. 'key:mykeyname'. Enable in Agent's redisdb.yaml with the keys option. |
redis.keys (gauge) | The total number of keys. Shown as key |
redis.keys.evicted (gauge) | The total number of keys evicted due to the maxmemory limit. Shown as key |
redis.keys.expired (gauge) | The total number of keys expired from the db. Shown as key |
redis.mem.clients_normal (gauge) | The total size in bytes of all clients overheads. Shown as byte |
redis.mem.clients_slaves (gauge) | The total size in bytes of all replicas overheads. Shown as byte |
redis.mem.dataset (gauge) | The size in bytes of the dataset. Shown as byte |
redis.mem.fragmentation (gauge) | Delta between usedmemoryrss and used_memory. Shown as byte |
redis.mem.fragmentation_ratio (gauge) | Ratio between usedmemoryrss and used_memory. Shown as fraction |
redis.mem.functions (gauge) | Number of bytes overhead by Function scripts (part of used_memory). [v7+]. Shown as byte |
redis.mem.lua (gauge) | Amount of memory used by the Lua engine. Shown as byte |
redis.mem.maxmemory (gauge) | Maximum amount of memory allocated to the Redisdb system. Shown as byte |
redis.mem.overhead (gauge) | Sum of all overheads allocated by Redis for managing its internal datastructures [v4+]. Shown as byte |
redis.mem.peak (gauge) | The peak amount of memory used by Redis. Shown as byte |
redis.mem.rss (gauge) | Amount of memory that Redis allocated as seen by the os. Shown as byte |
redis.mem.scripts (gauge) | redis.mem.scriptseval + redis.mem.functions (part of usedmemory). [v7+]. Shown as byte |
redis.mem.scripts_eval (gauge) | Number of bytes overhead by the EVAL scripts (part of used_memory). [v7+]. Shown as byte |
redis.mem.startup (gauge) | Amount of memory consumed by Redis at startup. Shown as byte |
redis.mem.total_replication_buffers (gauge) | Total memory consumed for replication buffers. [v7+]. Shown as byte |
redis.mem.used (gauge) | Amount of memory allocated by Redis. Shown as byte |
redis.mem.vm_eval (gauge) | Number of bytes used by the script VM engines for EVAL framework (not part of used_memory). [v7+]. Shown as byte |
redis.mem.vm_functions (gauge) | Number of bytes used by the script VM engines for Functions framework (not part of used_memory). [v7+]. Shown as byte |
redis.mem.vm_total (gauge) | redis.mem.vmeval + redis.mem.vmfunctions (not part of used_memory). [v7+]. Shown as byte |
redis.net.clients (gauge) | The number of connected clients (excluding slaves). Shown as connection |
redis.net.commands (gauge) | The number of commands processed by the server. Shown as command |
redis.net.commands.instantaneous_ops_per_sec (gauge) | The number of commands processed by the server per second. Shown as command |
redis.net.connections (gauge) | The number of connections tagged by client name. Shown as connection |
redis.net.instantaneous_input (gauge) | The network's read rate per second in KB/sec. Shown as kibibyte |
redis.net.instantaneous_ops_per_sec (gauge) | Number of commands processed per second. Shown as operation |
redis.net.instantaneous_output (gauge) | The network's write rate per second in KB/sec. Shown as kibibyte |
redis.net.maxclients (gauge) | The maximum number of connected clients. Shown as connection |
redis.net.rejected (gauge) | The number of rejected connections. Shown as connection |
redis.net.slaves (gauge) | The number of connected slaves. Shown as connection |
redis.net.total_connections_received (gauge) | Total number of connections accepted by the server. Shown as connection |
redis.perf.latest_fork_usec (gauge) | The duration of the latest fork. Shown as microsecond |
redis.persist (gauge) | The number of keys persisted (redis.keys - redis.expires). Shown as key |
redis.persist.percent (gauge) | Percentage of total keys that are persisted. Shown as percent |
redis.ping.latency_ms (gauge) | The latency of the redis PING command. Shown as millisecond |
redis.pubsub.channels (gauge) | The number of active pubsub channels. |
redis.pubsub.patterns (gauge) | The number of active pubsub patterns. |
redis.rdb.bgsave (gauge) | One if a bgsave is in progress and zero otherwise. |
redis.rdb.changes_since_last (gauge) | The number of changes since the last background save. |
redis.rdb.last_bgsave_time (gauge) | Duration of the last bg_save operation. Shown as second |
redis.replication.backlog_histlen (gauge) | The amount of data in the backlog sync buffer. Shown as byte |
redis.replication.delay (gauge) | The replication delay in offsets. Shown as offset |
redis.replication.last_io_seconds_ago (gauge) | Amount of time since the last interaction with master. Shown as second |
redis.replication.master_link_down_since_seconds (gauge) | Amount of time that the master link has been down. Shown as second |
redis.replication.master_repl_offset (gauge) | The replication offset reported by the master. Shown as offset |
redis.replication.slave_repl_offset (gauge) | The replication offset reported by the slave. Shown as offset |
redis.replication.sync (gauge) | One if a sync is in progress and zero otherwise. |
redis.replication.sync_left_bytes (gauge) | Amount of data left before syncing is complete. Shown as byte |
redis.server.io_threads_active (gauge) | Flag indicating if I/O threads are active. This metric is only provided by redis >=6.x. |
redis.slowlog.micros.95percentile (gauge) | The 95th percentile of the duration of queries reported in the slow log. Shown as microsecond |
redis.slowlog.micros.avg (gauge) | The average duration of queries reported in the slow log. Shown as microsecond |
redis.slowlog.micros.count (rate) | The rate of queries reported in the slow log. Shown as query |
redis.slowlog.micros.max (gauge) | The maximum duration of queries reported in the slow log. Shown as microsecond |
redis.slowlog.micros.median (gauge) | The median duration of queries reported in the slow log. Shown as microsecond |
redis.stats.io_threaded_reads_processed (gauge) | Number of read events processed by the main and I/O threads. This metric is only provided by redis >=6.x. |
redis.stats.io_threaded_writes_processed (gauge) | Number of write events processed by the main and I/O threads. This metric is only provided by redis >=6.x. |
redis.stats.keyspace_hits (gauge) | The rate of successful lookups in the main db. Shown as key |
redis.stats.keyspace_misses (gauge) | The rate of missed lookups in the main db. Shown as key |
Redis 점검은 이벤트를 포함하지 않습니다.
redis.can_connect
Returns CRITICAL
if the Agent check is unable to connect to the monitored redis instance. Returns OK
otherwise.
Statuses: ok, critical
redis.replication.master_link_status
Returns CRITICAL
if this Redis instance is unable to connect to its master instance. Returns OK
otherwise.
Statuses: ok, critical
redisdb
-------
- instance #0 [ERROR]: 'Error 111 connecting to localhost:6379. Connection refused.'
- Collected 0 metrics, 0 events & 1 service check
redisdb.yaml
의 연결 정보가 올바른지 확인합니다.
redisdb
-------
- instance #0 [ERROR]: 'NOAUTH Authentication required.'
- Collected 0 metrics, 0 events & 1 service check
redisdb.yaml
에서 password
를 설정합니다.
기타 유용한 문서, 링크 및 기사: