zoukankan      html  css  js  c++  java
  • 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 变量的次数来决定是否需要扩大积压缓冲区,它表示主从半同步复制失败的次数。

  • 相关阅读:
    XTREE随笔
    多重共线性
    常用特征选取算法
    最短路径算法的实现(dijskstra):Python
    数据科学的完整学习路径—Python版(转载)
    windows下64位python的安装及机器学习相关包的安装(实用)
    拓扑排序 详解 + 并查集 详解 + 最小生成树(MST)详解 【普利姆算法 + 优先队列优化 & 克鲁斯卡尔算法】
    最短路算法 :Bellman-ford算法 & Dijkstra算法 & floyd算法 & SPFA算法 详解
    在linux下部署项目所用到的基本linux命令
    素数筛 模板
  • 原文地址:https://www.cnblogs.com/dalianpai/p/12750702.html
Copyright © 2011-2022 走看看