设为首页 收藏本站
查看: 926|回复: 0

[经验分享] redis笔记-指令原理篇

[复制链接]

尚未签到

发表于 2018-11-3 07:48:41 | 显示全部楼层 |阅读模式
2018-1-2 by Atlas

  一个命令请求从发送到获得回复的过程中,客户端和服务器需要完成一系列操作。
  举例:
   SET key value
  ok


1. 简单概述

  1)客户端向服务器发送命令请求 SET key value。
  2)服务器接收并处理客户端发来的命令请求 SET key value,在数据库中进行设置操作,并产生命令回复 ok。
  3)服务器将命令回复 ok 发送给客户端。
  4)客户端接收服务器返回的命令回复 ok,并将这个回复打印显示给用户。


2. 执行细节
  2.1.发送命令请求


  • 客户端接收并发送命令请求的过程
DSC0000.jpg

  1)用户在客户端键入命令。
  

SET key value  

  2)客户端将命令转换成协议。
  

*3\r\n$3\r\nSET\r\n$3\r\nkey\r\n$5\r\nvalue\r\n  

  *开头,紧跟的3表示接下来有3个字符串,\r\n表示分隔符,$后跟字符串,紧跟的3表示该字符串含有3个字符,分隔符后跟该字符串字符内容,以此类推,分隔符结尾。
  这串协议字符串即是后续会了解到的 AOF,AOF文件中就是这些显式字符串。

  3)将协议内容发送给服务器。
  2.2.读取命令请求


  • 当客户端套接字因为客户端的写入变得可读时,服务器调用命令请求处理器执行以下操作
  1)读取套接字中协议格式的命令请求,并将其保存到客户端状态的输入缓冲区。
DSC0001.jpg

  2)对输入缓冲区的命令请求进行分析,提前出命令请求中包含的命令参数及参数个数,然后分别将参数和参数个数保存到客户端状态的argv属性和argc属性里面。
DSC0002.jpg

  3)调用命令执行器,执行客户端指定的命令。
  2.3.命令执行:查找命令实现

  命令表是一个字典,字典的键是一个个命令名字,字典的值则是一个个redisCommand结构,记录着redis命令的实现信息。
  命令表命令名字大小不影响命令表查找结果,因为命令表大小写无关。

  1)命令表
DSC0003.jpg

  2)设置客户端状态的cmd指针
DSC0004.jpg

  2.4.命令执行:执行预备操作


  •   客户端状态的cmd指针是否指向NULL,如果是说明没有查找到相应的命令,服务器不在执行后续步骤。

  •   根据客户端cmd属性指向的redisCommand结构的arity属性,检查命令请求的参数个数是否正确,如果不正确,不再执行后续步骤。

  •   检查客户端是否已经通过了身份验证。

  • 等等繁琐的检查,不多赘述。
  2.5.命令执行:调用命令实现函数


  • 调用命令实现函数前客户端状态
DSC0005.jpg

  1)执行命令语句。
  

client -> cmd -> proc(client);  

  
setCommand(client);
  

  2)执行操作后,相应的命令回复保存客户端状态的输出缓冲区。
DSC0006.jpg

  2.6.命令执行:执行后续操作


  •   如果服务器开启慢查询日志功能,那么慢查询日志模块会检查是否需要为刚刚执行的命令请求添加一条新的慢查询日志。

  •   根据刚刚执行命令所耗费的时长,更新被执行命令的redisCommand结构的milliseconds属性,并将calls计数器的值增一。

  •   如果服务器开启了AOF持久化功能,那么AOF持久化模块会将刚刚执行的命令请求写入AOF缓冲区。

  • 如果有其他从服务器正在复制当前服务器,那么服务器会将刚刚执行的命令请求传播给所有从服务器。
  2.7.将命令回复发送给客户端


  • 当客户端套接字变为可写时,服务器执行命令回复处理器将保存在客户端输出缓冲区的命令回复发送给客户端。
  2.8.客户端接收并打印命令回复


  • 客户端接收并打印命令回复的过程
DSC0007.jpg

  1)客户端接收到服务器发来的协议回复。
  

+ok\r\n  

  2)转换成人类可读格式并打印显示。
  

ok\n  

  以上就是redis客户端和服务器执行命令请求的过程。
  参考文献:《Redis 设计与实现》



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-630018-1-1.html 上篇帖子: redis常用操作,redis操作键值,redis安全设置 下篇帖子: redis慢查询日志,php安装redis扩展,redis存储session,redis主从配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表