Redis Info 命令


Redis Info 命令

Redis Info 命令以一種易於理解和閱讀的格式,返回關於 Redis 服務器的各種信息和統計數值。

通過給定可選的參數 section ,可以讓命令只返回某一部分的信息:

  • server : 一般 Redis 服務器信息,包含以下域:

    • redis_version : Redis 服務器版本
    • redis_git_sha1 : Git SHA1
    • redis_git_dirty : Git dirty flag
    • os : Redis 服務器的宿主操作系統
    • arch_bits : 架構(32 或 64 位)
    • multiplexing_api : Redis 所使用的事件處理機制
    • gcc_version : 編譯 Redis 時所使用的 GCC 版本
    • process_id : 服務器進程的 PID
    • run_id : Redis 服務器的隨機標識符(用於 Sentinel 和集群)
    • tcp_port : TCP/IP 監聽端口
    • uptime_in_seconds : 自 Redis 服務器啟動以來,經過的秒數
    • uptime_in_days : 自 Redis 服務器啟動以來,經過的天數
    • lru_clock : 以分鍾為單位進行自增的時鍾,用於 LRU 管理
  • clients : 已連接客戶端信息,包含以下域:

    • connected_clients : 已連接客戶端的數量(不包括通過從屬服務器連接的客戶端)
    • client_longest_output_list : 當前連接的客戶端當中,最長的輸出列表
    • client_longest_input_buf : 當前連接的客戶端當中,最大輸入緩存
    • blocked_clients : 正在等待阻塞命令(BLPOP、BRPOP、BRPOPLPUSH)的客戶端的數量
  • memory : 內存信息,包含以下域:

    • used_memory : 由 Redis 分配器分配的內存總量,以字節(byte)為單位
    • used_memory_human : 以人類可讀的格式返回 Redis 分配的內存總量
    • used_memory_rss : 從操作系統的角度,返回 Redis 已分配的內存總量(俗稱常駐集大小)。這個值和 top 、 ps 等命令的輸出一致。
    • used_memory_peak : Redis 的內存消耗峰值(以字節為單位)
    • used_memory_peak_human : 以人類可讀的格式返回 Redis 的內存消耗峰值
    • used_memory_lua : Lua 引擎所使用的內存大小(以字節為單位)
    • mem_fragmentation_ratio : used_memory_rss 和 used_memory 之間的比率
    • mem_allocator : 在編譯時指定的, Redis 所使用的內存分配器。可以是 libc 、 jemalloc 或者 tcmalloc 。

    在理想情況下, used_memory_rss 的值應該只比 used_memory 稍微高一點兒。

    當 rss > used ,且兩者的值相差較大時,表示存在(內部或外部的)內存碎片。

    內存碎片的比率可以通過 mem_fragmentation_ratio 的值看出。

    當 used > rss 時,表示 Redis 的部分內存被操作系統換出到交換空間了,在這種情況下,操作可能會產生明顯的延遲。

    當 Redis 釋放內存時,分配器可能會,也可能不會,將內存返還給操作系統。

    如果 Redis 釋放了內存,卻沒有將內存返還給操作系統,那么 used_memory 的值可能和操作系統顯示的 Redis 內存占用並不一致。

    查看 used_memory_peak 的值可以驗證這種情況是否發生。

  • persistence : RDB 和 AOF 的相關信息

  • stats : 一般統計信息

  • replication : 主/從復制信息

  • cpu : CPU 計算量統計信息

  • commandstats : Redis 命令統計信息

  • cluster : Redis 集群信息

  • keyspace : 數據庫相關的統計信息

# Server
redis_version:5.0.8
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:f5de7c59791f2d0a
redis_mode:standalone
os:Linux 3.10.0-1062.18.1.el7.x86_64 x86_64
arch_bits:64
multiplexing_api:epoll
atomicvar_api:atomic-builtin
gcc_version:8.3.0
process_id:1
run_id:0af71da428854489e825ed709a3abe82af43c60d
tcp_port:6379
uptime_in_seconds:558729
uptime_in_days:6
hz:10
configured_hz:10
lru_clock:10464552
executable:/data/redis-server
config_file:

# Clients
connected_clients:3
client_recent_max_input_buffer:2
client_recent_max_output_buffer:0
blocked_clients:0

# Memory
used_memory:898560
used_memory_human:877.50K
used_memory_rss:12513280
used_memory_rss_human:11.93M
used_memory_peak:4998384
used_memory_peak_human:4.77M
used_memory_peak_perc:17.98%
used_memory_overhead:877034
used_memory_startup:791264
used_memory_dataset:21526
used_memory_dataset_perc:20.06%
allocator_allocated:1158176
allocator_active:1409024
allocator_resident:8511488
total_system_memory:3973369856
total_system_memory_human:3.70G
used_memory_lua:66560
used_memory_lua_human:65.00K
used_memory_scripts:2160
used_memory_scripts_human:2.11K
number_of_cached_scripts:6
maxmemory:0
maxmemory_human:0B
maxmemory_policy:noeviction
allocator_frag_ratio:1.22
allocator_frag_bytes:250848
allocator_rss_ratio:6.04
allocator_rss_bytes:7102464
rss_overhead_ratio:1.47
rss_overhead_bytes:4001792
mem_fragmentation_ratio:14.61
mem_fragmentation_bytes:11656720
mem_not_counted_for_evict:0
mem_replication_backlog:0
mem_clients_slaves:0
mem_clients_normal:83538
mem_aof_buffer:0
mem_allocator:jemalloc-5.1.0
active_defrag_running:0
lazyfree_pending_objects:0

# Persistence
loading:0
rdb_changes_since_last_save:0
rdb_bgsave_in_progress:0
rdb_last_save_time:1587046539
rdb_last_bgsave_status:ok
rdb_last_bgsave_time_sec:0
rdb_current_bgsave_time_sec:-1
rdb_last_cow_size:6402048
aof_enabled:0
aof_rewrite_in_progress:0
aof_rewrite_scheduled:0
aof_last_rewrite_time_sec:-1
aof_current_rewrite_time_sec:-1
aof_last_bgrewrite_status:ok
aof_last_write_status:ok
aof_last_cow_size:0

# Stats
total_connections_received:88
total_commands_processed:238
instantaneous_ops_per_sec:0
total_net_input_bytes:67596
total_net_output_bytes:148055
instantaneous_input_kbps:0.00
instantaneous_output_kbps:0.00
rejected_connections:0
sync_full:0
sync_partial_ok:0
sync_partial_err:0
expired_keys:3
expired_stale_perc:0.00
expired_time_cap_reached_count:0
evicted_keys:0
keyspace_hits:21
keyspace_misses:39
pubsub_channels:0
pubsub_patterns:0
latest_fork_usec:1220
migrate_cached_sockets:0
slave_expires_tracked_keys:0
active_defrag_hits:0
active_defrag_misses:0
active_defrag_key_hits:0
active_defrag_key_misses:0

# Replication
role:master
connected_slaves:0
master_replid:f3f5c1ebf085e9a74a401b88efdb18bd89848233
master_replid2:91f3e9b0b11bc5f4083e846a1399174e86933f92
master_repl_offset:0
second_repl_offset:1
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0

# CPU
used_cpu_sys:869.539401
used_cpu_user:895.500259
used_cpu_sys_children:0.053327
used_cpu_user_children:0.365536

# Cluster
cluster_enabled:0

# Keyspace
db0:keys=1,expires=0,avg_ttl=0
127.0.0.1:6379>

 

當然也可以獲取單個的信息

127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:0
master_replid:f3f5c1ebf085e9a74a401b88efdb18bd89848233
master_replid2:91f3e9b0b11bc5f4083e846a1399174e86933f92
master_repl_offset:0
second_repl_offset:1
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
127.0.0.1:6379>

Redis 每秒執行多少次指令

root@d4cad7fb69c2:/data# redis-cli info stats |grep ops
instantaneous_ops_per_sec:789
root@d4cad7fb69c2:/data#

以上,表示 ops 是 789,也就是所有客戶端每秒會發送 789 條指令到服務器執行。極限情況下,Redis 可以每秒執行 10w 次指令,CPU 幾乎完全榨干。如果 qps 過高,可以考
慮通過 monitor 指令快速觀察一下究竟是哪些 key 訪問比較頻繁,從而在相應的業務上進行優化,以減少 IO 次數。monitor 指令會瞬間吐出來巨量的指令文本,所以一般在執行
monitor 后立即 ctrl+c 中斷輸出。

root@d4cad7fb69c2:/data#  redis-cli monitor
OK
^Z
[1]+  Stopped                 redis-cli monitor
root@d4cad7fb69c2:/data#

Redis 連接了多少客戶端 ?
這個信息在 Clients 塊里,可以通過 info clients 看到。

root@d4cad7fb69c2:/data# redis-cli info clients
# Clients
connected_clients:4
client_recent_max_input_buffer:2
client_recent_max_output_buffer:0
blocked_clients:0
root@d4cad7fb69c2:/data#

 

這個信息也是比較有用的,通過觀察這個數量可以確定是否存在意料之外的連接。如果
發現這個數量不對勁,接着就可以使用 client list 指令列出所有的客戶端鏈接地址來確定源頭。

關於客戶端的數量還有個重要的參數需要觀察,那就是 rejected_connections,它表示因
為超出最大連接數限制而被拒絕的客戶端連接次數,如果這個數字很大,意味着服務器的最
大連接數設置的過低需要調整 maxclients 參數。

root@d4cad7fb69c2:/data# redis-cli info stats |grep reject
rejected_connections:0
root@d4cad7fb69c2:/data#

Redis 內存占用多大 ?

這個信息在 Memory 塊里,可以通過 info memory 看到。

root@d4cad7fb69c2:/data# redis-cli info memory | grep used | grep human
used_memory_human:897.02K  # 內存分配器 (jemalloc) 從操作系統分配的內存總量
used_memory_rss_human:11.93M  # 操作系統看到的內存占用 ,top 命令看到的內存
used_memory_peak_human:4.77M  # Redis 內存消耗的峰值
used_memory_lua_human:65.00K  # lua 腳本引擎占用的內存大小
used_memory_scripts_human:2.11K
root@d4cad7fb69c2:/data#

如果單個 Redis 內存占用過大,並且在業務上沒有太多壓縮的空間的話,可以考慮集群化了。

復制積壓緩沖區多大?

這個信息在 Replication 塊里,可以通過 info replication 看到。

root@d4cad7fb69c2:/data# redis-cli info replication |grep backlog
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
root@d4cad7fb69c2:/data#

復制積壓緩沖區大小非常重要,它嚴重影響到主從復制的效率。當從庫因為網絡原因臨時斷開了主庫的復制,然后網絡恢復了,又重新連上的時候,這段斷開的時間內發生在
master 上的修改操作指令都會放在積壓緩沖區中,這樣從庫可以通過積壓緩沖區恢復中斷的主從同步過程。

積壓緩沖區是環形的,后來的指令會覆蓋掉前面的內容。如果從庫斷開的時間過長,或者緩沖區的大小設置的太小,都會導致從庫無法快速恢復中斷的主從同步過程,因為中間的
修改指令被覆蓋掉了。這時候從庫就會進行全量同步模式,非常耗費 CPU 和網絡資源。如果有多個從庫復制,積壓緩沖區是共享的,它不會因為從庫過多而線性增長。如果實
例的修改指令請求很頻繁,那就把積壓緩沖區調大一些,幾十個 M 大小差不多了,如果很閑,那就設置為幾個 M。

root@d4cad7fb69c2:/data# redis-cli info stats | grep sync
sync_full:0
sync_partial_ok:0
sync_partial_err:0  # 半同步失敗次數

通過查看 sync_partial_err 變量的次數來決定是否需要擴大積壓緩沖區,它表示主從半同步復制失敗的次數。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM