一、Redis客户端
redisServer结构中保存了所有客户端的状态信息。
struct redisServer{
//...
//一个链表,保存了所有客户端状态
list *clients;
};
命令 client list
可以列出目前所有连接到服务器的客户端。
命令 client setname < name >
可以给客户端设置一个名字。
伪客户端
由于服务器必须接收来自客户端的命令以执行操作,因此在没有用户客户端连接的情况下,服务器要想执行一些指令(Lua脚本或者AOF文件中的指令),就需要给自己创建一个客户端。
(1) lua脚本的伪客户端
当执行Lua脚本中的Redis命令的时候,服务器会创建一个伪客户端,这个伪客户端再服务器启动的时候就自动创建了,当服务器关闭时,才会关闭。
(2) AOF文件的伪客户端
服务器载入AOF文件时,会创建一个伪客户端用于执行AOF文件中的Redis命令,载入完成后就关闭这个伪客户端
二、Redis服务器
Redis服务器与多个Redis客户端建立网络连接,处理客户端发送的命令请求。
1、客户端发送请求给服务器
下图是一个客户端发送请求给服务器的情况:
当用户发送下指令时:
SET KEY VALUE
客户端在发送之前会将其转换成下面的协议格式:
*3\r\n$3\r\nSET\r\n$3\rnKEY\r\n$5\r\nVALUE\r\n
然后通过网络发送给服务器。
2、服务器初始化过程
1、初始化服务器状态
2、载入服务器配置
3、初始化服务器数据结构
4、还原数据库状态
5、执行事件循环