Redis底层函数详解
redis底层函数详解
-
servercron 函数
它负责管理服务器的资源,并维持服务器的正常运行。在执行 servercron 函数的过程中会调用相关的子函数,如 trackoperationspersecond、sigtermhandler、clientscron、databasescron 等函数。默认情况下,每隔 100 毫秒执行一次 servercron 函数
-
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
-
sigtermhandler 函数
sigtermhandler 函数是一个 redis 服务器进程的 sigterm 信号关联处理器。在 redis 服务器启动的时候会调用执行 sigtermhandler 函数,它负责在服务器接收到 sigterm 信号时,打开服务器状态的 shutdown_asap 标识。
在每次执行服务器资源管理函数 servercron 的时候,都会先对服务器状态的 shutdown_asap 属性的值进行判断,再决定是否关闭服务器。当 shutdown_asap 属性的值为 1 时,关闭服务器;当 shutdown_asap 属性的值为 0 时,什么也不做。
-
clientscron 函数
它会对一定数量的客户端进行如下检查。
● 检查这个客户端与服务器的连接是否已经超时。如果连接已经超时(在很长一段时间内,客户端与服务器之间没有进行交互),则释放这个客户端的连接。
● 检查这个客户端的输入缓存区的大小,以便对服务器的内存进行管理。如果客户端在上一次执行命令请求后,输入缓冲区的大小超过了一定的限制,那么程序会释放这个客户端的输入缓存区,然后重新为这个客户端创建一个默认大小的输入缓冲区,以此来防止客户端的输入缓冲区消耗更多内存。
-
databasescron 函数
它的作用是对服务器中的部分数据库进行检查,查找出过期的键,然后删除它们,并对 redis 数据字典进行相关的收缩操作等。