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

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

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

redis源码之:客户端命令执行Command_第5张图片

你可能感兴趣的:(redis源码学习分析,redis)