redis源码之:客户端命令执行Command

发布时间:2024年01月15日

在上一篇中讲到在客户端提交命令后,在服务端触发可读事件,最终可读事件由readQueryFromClient处理:
在这里插入图片描述
在进入分析readQueryFromClient处理之前,先来看看redis的命令初始化:
在main()->initServerConfig()中完成server.commands的初始化,将redisCommandTable中的命令都放入server.commands这个字典中:
在这里插入图片描述
接下来,继续看下从客户端发送info指令后readQueryFromClient的执行流程:
读取数据:在创建conn的时候,就将连接的type设置为Socket
在这里插入图片描述
读取到数据后进行数据处理processInputBuffer,方法中processInlineBuffer()或processMultibulkBuffer()对命令输入的命令名和命令参数进行解析,
如‘set hello eshin’这条指令,则会解析成
在这里插入图片描述

这里不对命令行解析做分析,主要看看如何在解析后调用到具体的命令执行方法processCommandAndResetClient()->processCommand():
方法中有一些命令执行前的条件限制,比如是否需要认证等,涉及情况较多,这里不过多分析,等遇到具体情况再看这些限制情况,这里直接看执行命令的语句:
在这里插入图片描述在这里插入图片描述
在call方法里,调用具体的command对应处理方法。所有的command都抽象出公共的入参client c ,command执行时直接从c中获取参数,如set指令:

在这里插入图片描述

文章来源:https://blog.csdn.net/qq_22351805/article/details/135558063
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。