1.项目核心目的就是一个:替使用者存储需要延迟处理的消息或任务,并在设定时间进行准时投递。比如某些场景下,客户需要根据自己设定的时间进行周期性的任务触发,时间范围又是不确定的,则可以使用该项目,开发者只需要关心自己需要实现的业务逻辑,延迟触发功能则全权交给该服务。
2.该项目由本人独自维护,使用了rabbitMQ、redis、LUA以及时间轮算法,摆脱了阿里云上版RocketMQ,单机TPS达到了400+每秒。
3.市面上拥有延迟功能的组建很多,比如各类MQ都集成了延迟队列,但都是固定时间的。如何满足“任意”时间的延迟消息则是需要解决的。因此想到了使用redis的zset有序集合,那如何解决redis数据不可靠的问题,则需要结合LUA脚本保证操作的原子性,以及通过Mysql进行数据持久化。
点击空白处退出提示












评论