【redis】客户端

这里的客户端并不是说redis-cli的是实现,而是在服务端检测到一个连接事件以后,创建的一个描述客户端的数据结构,本质上还是服务端的实现,服务端对客户端的封装。

用的是一个叫做redisClient的结构体。

里面的重要属性有:

1.套接字;

2.名字;

3.冲入缓冲区,客户端发来的命令会被存在这里

4.输出缓冲区,服务端给客户端返回的数据存在这里

5.命令,服务端解析客户端缓冲区的内容,分析出命令和参数,存在这里

6.命令实现函数,这是一个指针,存放命令的实现函数的dict

在服务器的数据结构中redisServer中,除了之前介绍的和数据库有关的db指针外,还有一个redisClient的数组指针,保存了所有的连接的客户端。


执行过程,客户端先连接,服务端监听到连接事件,就会创建一个redisClient,并且加上读写的监听事件。之后客户端调用了write写入了命令,这时服务端就可以监听到一个read事件,读取命令,存在redisClient结构体的输入缓冲区中,解析,把解析以后的命令存入arg中,在命令表里面查找相应的命令函数,执行,最后把结果放在输出缓冲区上。当客户端调用read准备读取结果时,服务器会把结果写入套接字中。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值