22 Jun 2024 |
- 抽取公关逻辑到接口command
data:image/s3,"s3://crabby-images/60e71/60e714bf8770304affaa80809ebd77a4dea14315" alt="图片"
它的实现类就是各个命令。
data:image/s3,"s3://crabby-images/642ee/642ee5058bc3589e55ef3d9b032783d12655a6ab" alt="图片"
- 通过commands注册所有命令
data:image/s3,"s3://crabby-images/a607a/a607a41fc5d5d164bc134833c8f97731408aa9a2" alt="图片"
- 通过Reply封装redis返回数据类型
data:image/s3,"s3://crabby-images/c8ce9/c8ce9711bdfb28781bf34c61246f23d4be6dded6" alt="图片"
包括整形、错误、简单字符串、复杂字符串和数组。
data:image/s3,"s3://crabby-images/9ce1e/9ce1eec9491fb96297622f0cc82052a4e0c547fb" alt="图片"
- LPUSH命令的实现
- 实现command接口
- 重写name方法
- 实现执行逻辑exec:获取参数和值,在缓存中实现具体逻辑,返回int类型结果。
data:image/s3,"s3://crabby-images/6faca/6facaa94503d422c79a494eaf9fcd043ab0d41d1" alt="图片"
在cache中lpush逻辑如下,借用LinkedList的addFirst实现。
data:image/s3,"s3://crabby-images/fb0bf/fb0bf1eaee35bd614c93e4c030df9de52398f1f4" alt="图片"
底层使用Map作为缓存数据结构, CacheEntry封装值的类型
data:image/s3,"s3://crabby-images/3e324/3e3246f3cf3ae1a1da8f7ac9bb24c927d342908f" alt="图片"
data:image/s3,"s3://crabby-images/4d4e1/4d4e1e289dd4380c6274bc93de9ba54b5f9591bf" alt="图片"
- LPOP命名的实现
- 实现command接口
- 重写name方法
- 实现执行逻辑exec:获取参数和值,在缓存中实现具体逻辑,返回bulkString类型结果。
data:image/s3,"s3://crabby-images/206ed/206ed89651e4fc0a6cb097fc26645534a780c4cc" alt="图片"
在cache中缓存的具体逻辑实现如下,借用LinkedList的removeFirst实现。
data:image/s3,"s3://crabby-images/67cad/67cadf4b35c2b72b0a6ec38c30d302f67590d4f0" alt="图片"
- 测试
通过redis客户端都可以实现命令lpush/lpop/rpush/rpop/lindex/lrange/llen。
data:image/s3,"s3://crabby-images/dc1fa/dc1fa572b2011ff215b39f2f3dbd83f938850915" alt="图片"
- REDIS 协议规范 https://redis.com.cn/topics/protocol.html在 RESP 中,数据的类型依赖于首字节:单行字符串(Simple Strings): 响应的首字节是 “+”错误(Errors): 响应的首字节是 “-“整型(Integers): 响应的首字节是 “:”多行字符串(Bulk Strings): 响应的首字节是”$“数组(Arrays): 响应的首字节是 “*“RESP协议的不同部分总是以 “\r\n” (CRLF**) 结束。
源码:https://github.com/midnight2104/midnight-cache
19 Jun 2024 |
- 自定义缓存MidnightCache
data:image/s3,"s3://crabby-images/44308/44308e02630fc31dacb62e024f4843949bcb4115" alt="图片"
- 实现redis协议
data:image/s3,"s3://crabby-images/792d2/792d2321cd45d5ebacfff606289817a594ce70e6" alt="图片"
integr编码处理
data:image/s3,"s3://crabby-images/3589d/3589d1f81eb55de23ab661f75f494356d44aa7aa" alt="图片"
错误编码处理
data:image/s3,"s3://crabby-images/70569/7056995c04258fed4a187c40ece274d88b4aac02" alt="图片"
数组编码处理
data:image/s3,"s3://crabby-images/7fdf2/7fdf2ec496194870d08d159e81d815da9fefa8ec" alt="图片"
负责字符串处理
data:image/s3,"s3://crabby-images/86374/863748c74986f08f0cb50900b75f88ddafdc3e82" alt="图片"
- 测试
data:image/s3,"s3://crabby-images/386db/386db4c1a6381931cbfdca78c97a55185c08b398" alt="图片"
- REDIS 协议规范 https://redis.com.cn/topics/protocol.html在 RESP 中,数据的类型依赖于首字节:单行字符串(Simple Strings): 响应的首字节是 “+”错误(Errors): 响应的首字节是 “-“整型(Integers): 响应的首字节是 “:”多行字符串(Bulk Strings): 响应的首字节是”$“数组(Arrays): 响应的首字节是 “*“RESP协议的不同部分总是以 “\r\n” (CRLF**) 结束。
源码:https://github.com/midnight2104/midnight-cache
18 Jun 2024 |
实现原理如下:
data:image/s3,"s3://crabby-images/1f71c/1f71c9b9a93766dc112986202e26ff32a0bbd80d" alt="图片"
- 定义插件接口
- init初始化方法;
- startup启动方法;
- shutdown停止方法;
data:image/s3,"s3://crabby-images/c812b/c812bdd26f9d88938f74801ca95878b9e15995c4" alt="图片"
- 实现CacheServer
- 声明为bean
- 定义端口6379;
- 定义boss和worker
data:image/s3,"s3://crabby-images/815f2/815f2a9885959fe00d208e176bb857d6cd3cf78f" alt="图片"
在startup方法中定义netty server,添加CacheHandle和CacheDecoder
data:image/s3,"s3://crabby-images/355d4/355d4bdbdc22961bcc651fc9e1b2d8e3b4735fb8" alt="图片"
在shutdown方法中,关闭channel,boss和worker
data:image/s3,"s3://crabby-images/daf1e/daf1ecbe40180ce7e600829cd0213aa04f08d44a" alt="图片"
- 实现CacheDecoder
继承ByteToMessageDecoder,从ByteBuf中读取输入,转成String输出
data:image/s3,"s3://crabby-images/13bb4/13bb4e8be2aa798fa0e506dad680f82ec505c7b7" alt="图片"
- 实现CacheHandle
继承SimpleChannelInboundHandler,重写channelRead0方法。
data:image/s3,"s3://crabby-images/577ac/577aca8a6069ec194de7505c06fdcc300242818b" alt="图片"
在channelRead0方法,读取参数,解析命令,支持命令COMMAND,PING,INFO。*和$都是redis协议规范。
data:image/s3,"s3://crabby-images/4c6e4/4c6e44ecbc210e760a464cca4c959b46b8b4117a" alt="图片"
解析命令后,构造输出。
data:image/s3,"s3://crabby-images/153b9/153b9f41ea2be508588546a4c45448a8be297c28" alt="图片"
- 实现MidnightApplicationListener
事件ApplicationReadyEvent启动插件,完成初始化。ContextClosedEvent事件关闭插件。
data:image/s3,"s3://crabby-images/c71bd/c71bd18a1438cfb2c190309ce4bed05edd71ce2d" alt="图片"
- 测试
启动redis client,命令都可以正常解析。
data:image/s3,"s3://crabby-images/4932f/4932f0ed9ce71b17e7b0ef0e51f2413a8bc758cf" alt="图片"
源码:https://github.com/midnight2104/midnight-cache