安庆大理运城常德铜陵江西
投稿投诉
江西南阳
嘉兴昆明
铜陵滨州
广东西昌
常德梅州
兰州阳江
运城金华
广西萍乡
大理重庆
诸暨泉州
安庆南充
武汉辽宁

Rocketmqkfaka太重,小团队可以选什么MQ?

5月9日 龙凤殿投稿
  前言
  提起消息队列,大部分java程序员并不陌生,在盛行的微服务体系下,rocketMQ,kfaka是很多java程序员的必修课。然而对于单体应用,rocketMQ亦或kfaka未免显得太重,这时又该怎么选择消息队列呢?
  答案就是熟悉的redis需求背景
  笔者的需求背景是这样的,公司有两个java服务,一个负责前台业务,也就是用户端的业务;一个负责后台业务,也就是管理端的业务。两个服务都只用到了mysql和redis,算是比较简单的业务服务。前台业务部署在两台服务器上,并且需要支持弹性扩张;后台业务部署在一台服务器上。此时有一个刷新本地缓存的功能,需要在管理后台服务发起,两个用户前台服务执行。
  第一版,采用了直接请求的方案。管理后台服务会直接调用前台服务的内网IP,通过http请求直接刷机器的本地缓存。彼时在功能实现后,出现了些许稳定性问题。因为两个服务都有做权限控制,在http请求时可能是漏了一些关键数据。重点是直接调用维护麻烦,管理后台需要循环调用两个前台服务的接口,如果加了服务器还要改配置改代码。
  改版时,想到这是一个典型的消息队列问题。生产者是管理后台,消费者是用户前台。集成rocketMQ或者kfaka肯定可以满足需求,但是维护工作量也是增加了很多,而已用组件里面的redis可以做消息队列,说实话还没用过redis做消息队列,正好体验一下。详细选型
  调查了下,Redis实现消息队列可以说有三种方式:List点对点,pubsub,stream。List点对点。简单直接,Lpush,lpop,先进先出。考虑阻塞式,blpush,blpop,满足点对点场景。pubsub。经典应用型,没得说。只是不支持消息持久化,对于数据质量要求比较高的场景,需要慎用。stream。感觉比较新颖,基本能和成熟型消息队列产品对飚,集成难度感觉大一些。
  综合考虑,先排除List,再考虑时间因素,先上一个pubsub。具体实现
  这部分就是看代码了,笔者使用的是redis5。0,springboot2。3。通用的redis配置就不负伤了,讲讲消息队列需要的配置及代码
  第一步是增加bean配置。初始化监听器、监听者与监听方法:初始化监听器paramconnectionFactoryfparamlistenerAdapterlreturncBeanRedisMessageListenerContainercontainer(RedisConnectionFactoryconnectionFactory,MessageListenerAdapterlistenerAdapter){RedisMessageListenerContainercontainernewRedisMessageListenerContainer();container。setConnectionFactory(connectionFactory);container。addMessageListener(listenerAdapter,newPatternTopic(RedisConst。REDISCHANNEL));newPatternTopic(这里是监听的通道的名字)通道要和发布者发布消息的通道一致}绑定消息监听者和接收监听的方法paramredisReceiverrreturnlBeanMessageListenerAdapterlistenerAdapter(RedisMQReceiverredisReceiver){returnnewMessageListenerAdapter(redisReceiver,receiveMessage);}
  第二步,实现receiver。这里笔者在收到消息后,将其转为内部事件再次分发,这样这部分代码可以通用。再有项目需要用到直接复制过去即可。Slf4jComponentpublicclassRedisMQReceiver{AutowiredprivateApplicationEventP收到通道的消息之后执行的方法parammessagestring消息publicvoidreceiveMessage(Stringmessage){try{这里是收到通道的消息之后执行的方法RedisMessageDTOmsgJsonUtil。parse(message,RedisMessageDTO。class);log。debug(收到消息{},msg);publisher。publishEvent(msg);}catch(Exceptione){log。error(处理消息异常。msg{},message,e);}}}
  第三步,实现publisherSlf4jComponentpublicclassRedisMQPublisher{AutowiredprivateStringRedisTemplatestringRedisT向通道发送消息的方法paramchannel通道parammessage消息publicvoidsendChannelMess(Stringchannel,Objectmessage){try{StringjsonJsonUtil。toJSON(message);stringRedisTemplate。convertAndSend(channel,json);}catch(Exceptione){log。error(Exception,e);}}publicvoidsendChannelMess(Objectmessage){this。sendChannelMess(RedisConst。REDISCHANNEL,message);}}
  使用的时候,消息发送后,各个接收端就能实现消息的监听与消费。最后
  对于刷本地缓存这种操作,这个消息队列是能够符合要求的。但是其他的业务就不好说了,比如商品、订单、用户信息等等,这种不能持久化的消息队列明显是会出大问题的。给个赞,后面笔者再试下stream做消息队列的集成。
投诉 评论

Rocketmqkfaka太重,小团队可以选什么MQ?前言提起消息队列,大部分java程序员并不陌生,在盛行的微服务体系下,rocketMQ,kfaka是很多java程序员的必修课。然而对于单体应用,rocketMQ亦或kf……动力电池价格上涨叠加补贴额度下降,新能源汽车价格体系迎大考最近一周,新能源汽车涨声迭起:特斯拉5天内两度涨价;比亚迪、小鹏、威马等今年内二次调价,最高涨幅超3万元;零跑、哪吒、几何等也纷纷加入涨价大军据不完全统计,今年以来,已有……京东自营越来越低的服务购物回顾:第一段:21日通过京东自营超市购买酒1瓶,预计24日送达(宁波沈阳)〔呲牙〕,经跟踪物流信息,23日12:50到达目的地派送站点〔赞〕〔赞〕,后即无任何进展〔w……微信后台反复读取相册,企业何时能够学会尊重隐私据媒体报道,10月8日有网友发帖表示,新版iOS15的隐私功能有记录APP活动,可以存储7天内APP访问位置或麦克风等数据,而微信在用户未主动激活应用的情况下在后台数次读取相册……华为P30才排第四目前市面上前置摄像头拍照最好手机居然是这几近年,随着国产手机的崛起,小米、华为等手机厂商的春风正盛,而一些老牌手机厂商例如三星、苹果却被人一直因为创新点少长衰。但是唱衰的老牌厂商的沉淀未必就一定不如最近的新手机界的网红……月球为什么总是一面朝着地球呢?月球会自转吗?2019年1月3日,中国的嫦娥四号卫星成功的在月球背面登陆,它携带的月球探测车玉兔二号也开始了正常的工作,这是人类历史上第一次在月球背面实现软着陆,揭开了人类探索月球的新的篇章……中国出手了!基础科学再获重视,未来芯片发展能否实现弯道超车此前,就有外媒曾放话中国大陆的芯片产业落后于国际水平,且无法实现弯道超车,看到这可能就有人会说了,这完全是因上世纪八十年代的造不如买观念所带来的必然结果。其实不然,中国并……苹果或在AppleCar中引入机器学习以快速做出驾驶决定品玩2月9日讯,据新浪科技引市场消息,苹果公司正计划在其AppleCar电动汽车中使用机器学习(ML)技术,因为当前的处理器速度还不够快,无法自动做出一些关键的驾驶决定。……在线职业教育蓬勃发展构筑创新发展人才飞轮5月21日,腾讯课堂在长沙举办2022年度全国职业教育行业大会,主题为聚焦高品质,共创新可能。腾讯公司集团副总裁、腾讯教育总裁殷宇表示,目前,腾讯课堂聚合了超过13万家教培机构……OPPOReno6配置完全曝光全系65瓦快充,最高配骁龙87OPPOReno6看起来基本配置完全曝光,所以这次看看设计吧,看起来这次的配置基本上主要的cpu都有,当然设计看起来不错!简单看这个消息吧!三种配色是出现了,当然名称就那……没有华为,中国智能手机市场的均价都降了?众所周知,自从华为MateP系列手机大火之后,很多人就吐槽华为手机太贵了,因为与苹果相比,华为MateP系列的价格也不遑多让。那么问题就来了,2021年开始,华为手机销量……预训练周刊第34期BigScience寻求建立强大的开放语言转载智源社区本期贡献者申德周翟珂吴新刚关于周刊本期周刊,我们选择了11篇预训练相关的论文,涉及图像处理、图像理解、语言模型调优、常识问答、大模型隐私泄漏、文本分类、……
人工智能预测蛋白质结构为何连续两年入选科学的年度十大科学突破这就是中兴的格局,新支点国产操作系统向所有人免费使用小米杂货铺又上新品,1199元的多看电纸书ProII值不值得华为,承包了一条超前赛道为什么亚马逊从来不强调用户时长?怎样查几年前工程中标的网上公示?姨夫谢幕索尼需要的救心丸到底是什么?中秋适合送给父母的几款手机,每一款都充满了性价比小鹏汽车门店开业请道士现场作法地球位于可观测宇宙正中心,这是巧合吗?小米为什么一定要做电动汽车?朗盛开发具有集成热管理功能的汽车雷达传感器概念金字旁加古金字旁加古怎么读数码知识360n7pro怎么打开后台高耗电提醒设置方法介绍掌握10要点养育出色宝宝糖尿病遗传性强吗摩尔多瓦红酒怎么样多少钱,有最大酒窖的古老红酒王国无论绿豆或黑豆,别直接下锅煮,多加这1步,豆子3分钟就软烂开什么是冠心病呢冠心病有什么危害呢描写家的味道的记叙文800字游泳不带泳镜可以吗?在水下可以睁开眼睛吗?春分节气关于天气的谚语iPhone14Pro渲染图曝光确定有金色颜色更深桃源忆故人

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找七猫云易事利