redis 命令行操作执行redis命令的工具redis-cli. 是在redis/src/redis-cli.c源文件里面实现的.整体流程比较简单主要就是 配置->创建socket->linenoise接收命令行->write socket ->read socket. 循环以上操作.
cli 默认连接TCP的IP为 本机,端口为6379.以上只贴了部分配置代码。这部分配置是默认值,如需要使用使用其它值,就需要在启动redis-cli时候加上启动选项参数。实现源码部分贴图如下
这里根据源码解释启动选项,以及对应的配置信息含义
-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 不带其它参数。下面就是建立连接和死循环命令行了
cliconnect(0)创建socket,向服务端发起连接。
核心实现如上图所示,创建TCp socket ,然后connect服务器
relp()从stdin 读取命令,然后向服务器write命令,并等待接收返回。然后等待下一次CMD输入
如图所示从标准输入读取CMD,然后解析CMD成几个字符串数组。然后对CMD作初步分析,如果是一些特殊的命令如exit.quite.restart等等,就自己处理了不会发给服务端。一切没问题会走到如下代码
在issueCommandRepeat函数里面,会首先把CMD写入obuf.会然会调用通信接口
把obuf里面的CMD发送出去, redisBufferWrite实现如下
CMD发送完成后就等待服务器回应,redisBufferRead贴图如下