这里的客户端并不是说redis-cli的是实现,而是在服务端检测到一个连接事件以后,创建的一个描述客户端的数据结构,本质上还是服务端的实现,服务端对客户端的封装。
用的是一个叫做redisClient的结构体。
里面的重要属性有:
1.套接字;
2.名字;
3.冲入缓冲区,客户端发来的命令会被存在这里
4.输出缓冲区,服务端给客户端返回的数据存在这里
5.命令,服务端解析客户端缓冲区的内容,分析出命令和参数,存在这里
6.命令实现函数,这是一个指针,存放命令的实现函数的dict
在服务器的数据结构中redisServer中,除了之前介绍的和数据库有关的db指针外,还有一个redisClient的数组指针,保存了所有的连接的客户端。
执行过程,客户端先连接,服务端监听到连接事件,就会创建一个redisClient,并且加上读写的监听事件。之后客户端调用了write写入了命令,这时服务端就可以监听到一个read事件,读取命令,存在redisClient结构体的输入缓冲区中,解析,把解析以后的命令存入arg中,在命令表里面查找相应的命令函数,执行,最后把结果放在输出缓冲区上。当客户端调用read准备读取结果时,服务器会把结果写入套接字中。