JavaWeb项目架构之Redis分布式日志队列

3 篇文章 0 订阅
2 篇文章 0 订阅

架构、分布式、日志队列,就是一个日志收集的功能,只不过中间加了一个Redis做消息队列。 




为什么需要消息队列?


当系统中出现“生产“和“消费“的速度或稳定性等因素不一致的时候,就需要消息队列,作为抽象层,弥合双方的差异。


比如我们系统中常见的邮件、短信发送,把这些不需要及时响应的功能写入队列,异步处理请求,减少响应时间。


如何实现?


成熟的JMS消息队列中间件产品市面上有很多,但是基于目前项目的架构以及部署情况,我们采用Redis做消息队列。


为什么用Redis?


Redis中list数据结构,具有“双端队列”的特性,同时redis具有持久数据的能力,因此redis实现分布式队列是非常安全可靠的。


它类似于JMS中的“Queue”,只不过功能和可靠性(事务性)并没有JMS严格。Redis本身的高性能和"便捷的"分布式设计(replicas,sharding),可以为实现"分布式队列"提供了良好的基础。


提供者端


项目采用第三方redis插件spring-data-redis,不清楚如何使用的请自行谷歌或者百度。


redis.properties:



redis配置:



切面日志配置(伪代码):





Redis配置:


监听接口:


监听实现:


Q&A


【问题一】为什么使用Redis?


上面其实已经有做说明,尽管市面上有许多很稳定的产品,比如可能大家会想到的Kafka、RabbitMQ以及RocketMQ。但是由于项目本身使用了Redis做分布式缓存,基于省事可行的原则就选定了Redis。


【问题二】日志数据如何存储?


原则上是不建议存储到关系数据库的,比如MySql,毕竟产生的日志数量是巨大的,建议存储到Elasticsearch等非关系型数据库。


【问题三】切面日志收集是如何实现的?


切面日志需要引入spring-aspects相关Jar包,并且配置使Spring采用CGLIB代理 。


更多精彩可询462403503或点击下方蓝色字体了解。

蓝色字体


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值