redis-cli源码流程

redis 命令行操作执行redis命令的工具redis-cli. 是在redis/src/redis-cli.c源文件里面实现的.整体流程比较简单主要就是 配置->创建socket->linenoise接收命令行->write socket ->read socket. 循环以上操作.
redis-cli源码流程_第1张图片cli 默认连接TCP的IP为 本机,端口为6379.以上只贴了部分配置代码。这部分配置是默认值,如需要使用使用其它值,就需要在启动redis-cli时候加上启动选项参数。实现源码部分贴图如下
redis-cli源码流程_第2张图片这里根据源码解释启动选项,以及对应的配置信息含义
-h
后面有参数则配置hostip
后面没有参数则打印帮助信息
–help 打印帮助信息
-x 最后一个配置参数从标准输入获取
-p 后面带参数 设置端口
-s 后面带参数 设置hostsocket
-r 后面带参数 发送次数
-i 后面跟参数 sleep时间,单位秒
-n 后面跟参数 设置dbnum SELECT时使用
–no-auth-warning 开启no auth warning警告

  • a 后面跟参数 设置auth
    -u 后面跟参数 设置auth
    –raw 设置output为OUTPUT_RAW
    –no-raw 设置output为OUTPUT_STANDARD
    –csv 设置output为OUTPUT_CSV
    –latency 设置为latency_mode

    后面还有很多,不写了。好多参数的具体含义还没仔细阅读代码,不完全清楚
    正常启动 cli ./redis-cli 不带其它参数。下面就是建立连接和死循环命令行了
    redis-cli源码流程_第3张图片cliconnect(0)创建socket,向服务端发起连接。
    redis-cli源码流程_第4张图片核心实现如上图所示,创建TCp socket ,然后connect服务器
    relp()从stdin 读取命令,然后向服务器write命令,并等待接收返回。然后等待下一次CMD输入
    redis-cli源码流程_第5张图片如图所示从标准输入读取CMD,然后解析CMD成几个字符串数组。然后对CMD作初步分析,如果是一些特殊的命令如exit.quite.restart等等,就自己处理了不会发给服务端。一切没问题会走到如下代码
    redis-cli源码流程_第6张图片在issueCommandRepeat函数里面,会首先把CMD写入obuf.会然会调用通信接口redis-cli源码流程_第7张图片把obuf里面的CMD发送出去, redisBufferWrite实现如下
    redis-cli源码流程_第8张图片CMD发送完成后就等待服务器回应,redisBufferRead贴图如下
    redis-cli源码流程_第9张图片

你可能感兴趣的:(C)