欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Redis底层函数详解

程序员文章站 2022-04-14 16:03:41
Redis底层函数详解 1. serverCron 函数 它负责管理服务器的资源,并维持服务器的正常运行。在执行 serverCron 函数的过程中会调用相关的子函数,如 trackOperationsPerSecond、SigtermHandler、clientsCron、databasesCro ......

redis底层函数详解

  1. servercron 函数

    它负责管理服务器的资源,并维持服务器的正常运行。在执行 servercron 函数的过程中会调用相关的子函数,如 trackoperationspersecond、sigtermhandler、clientscron、databasescron 等函数。默认情况下,每隔 100 毫秒执行一次 servercron 函数

  2. trackoperationspersecond 函数

    是 servercron 函数的一个子函数。采用抽样计算的方式,计算并记录服务器在最近 1 秒内处理的命令请求数量。可以通过 info stats 命令来查看(instantaneous_ops_per_sec 属性)

    127.0.0.1:6379> info stats
    # stats
    total_connections_received:1
    total_commands_processed:4
    instantaneous_ops_per_sec:0
    total_net_input_bytes:133
    total_net_output_bytes:5948156
    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:0
    evicted_keys:0
    keyspace_hits:0
    keyspace_misses:0
    pubsub_channels:0
    pubsub_patterns:0
    latest_fork_usec:0
    migrate_cached_sockets:0
    
  3. sigtermhandler 函数

    sigtermhandler 函数是一个 redis 服务器进程的 sigterm 信号关联处理器。在 redis 服务器启动的时候会调用执行 sigtermhandler 函数,它负责在服务器接收到 sigterm 信号时,打开服务器状态的 shutdown_asap 标识。

    在每次执行服务器资源管理函数 servercron 的时候,都会先对服务器状态的 shutdown_asap 属性的值进行判断,再决定是否关闭服务器。当 shutdown_asap 属性的值为 1 时,关闭服务器;当 shutdown_asap 属性的值为 0 时,什么也不做。

  4. clientscron 函数

    它会对一定数量的客户端进行如下检查。

    ● 检查这个客户端与服务器的连接是否已经超时。如果连接已经超时(在很长一段时间内,客户端与服务器之间没有进行交互),则释放这个客户端的连接。

    ● 检查这个客户端的输入缓存区的大小,以便对服务器的内存进行管理。如果客户端在上一次执行命令请求后,输入缓冲区的大小超过了一定的限制,那么程序会释放这个客户端的输入缓存区,然后重新为这个客户端创建一个默认大小的输入缓冲区,以此来防止客户端的输入缓冲区消耗更多内存。

  5. databasescron 函数

    它的作用是对服务器中的部分数据库进行检查,查找出过期的键,然后删除它们,并对 redis 数据字典进行相关的收缩操作等。