一.来源:能够自己编写出一个自定义的Redis是因为Redis的应用程协议是公开的
(像是一个QQ的自定义客户端/王者荣耀的客户端/XXXX 不能自定义客户端,因为他们没有公开自己使用的自定义协议(如果非要定义的话也可以通过抓包/逆向手段,猜测QQ的应用层协议是什么样子的(全凭运气)))
二.引入:
网络通信过程中会用到很多的协议:
1.应用层:虽然有很多像是http等的很多成熟的应用层协议,但是更多的时候,会“自定义”应用层协议,Redis此处应用层协议,就是自定义的协议
2.传输层:TCP/UDP协议(基于TCP:客户端按照这里的的应用层协议,发送请求;服务器按照这个协议进行解析;服务器再按照这个协议构造响应;客户端再解析这个响应)
3.网络层:IP协议
4.数据链路层:以太网
物理层
作为第三方,要想开一个Redis客户端,也就需要知道应用层协议
Redis自定义应用层协议的名字=》resp
三.
RESP协议:
优点:1.简单好实现 2.快速进行解析 3.肉眼可读
传输层这里基于TCP,但和TCP没有耦合
客户端给服务器发送的是Redis命令(bluck string数组的形式发送的)
服务器发送信息给客户端的形式:
①simple string:“+ok\r\n”
②errors:“-error message\r\n”
③integers:“:1000\r\n”
④bluck string:“$\r\nhello\r\n”
⑤arrays:“*2\r\n$5\r\nnhello\r\n”
服务器就是把这些字符串写到TCP Socket中即可
Simple String只能用来文本传输
Bluck String 可以传输二进制数据
四.Java客户端
Java这边比较依赖Windows(IDEA),需要通过云服务器的外网IP来访问到Linux的服务器
光服务器的外网IP还不够,因为6379端口是被云服务器的防火墙给保护起来的(不能被外面访问)(别人不能来访问,自己也不能访问)(虽然Tomcat的端口也开放了,但是Tomcat的8080这里的这个门的锁,不好撬,但是6379这个门的锁就特别好撬)
解决方法:
一.直接让Java程序,也在Linux上运行,这就需要我们把代码打包成jar包,然后把jar包拷贝到Linux服务器上执行,如果手工的话比较麻烦,可以使用第三方的插件
二.配置ssh端口转发,把云服务器的redis端口映射到本地主机(此时访问127.0.0.1:8888,就相当于访问6379端口了)