当前位置: 首页 > wzjs >正文

郑州管家网站托管搜索引擎名词解释

郑州管家网站托管,搜索引擎名词解释,网站推广和优化教程,湖北省人民政府大家好,我是G探险者! 📌 背景场景 在高可用分布式系统中,我们经常面临: MQ 集群重启 → 消息监听中断MQ 网络短暂抖动 → 发送端连接失败一端恢复正常,另一端仍处于挂死状态 如果你只配置了“连接工厂层…

大家好,我是G探险者!

📌 背景场景

在高可用分布式系统中,我们经常面临:

  • MQ 集群重启 → 消息监听中断
  • MQ 网络短暂抖动 → 发送端连接失败
  • 一端恢复正常,另一端仍处于挂死状态

如果你只配置了“连接工厂层”的重连,却忽略了监听容器或发送客户端的容错设计,重连机制可能失效,业务陷入长时间不可用。


✅ 核心理念:监听和发送是两个不同的连接“通道”

通道用途组件
监听通道从 MQ 拉取消息Spring JMS 的 MessageListenerContainer
发送通道发送消息到 MQSpring 的 JmsTemplate

这两个通道各自有自己的连接池和生命周期,不能指望一个设置就解决全部问题


🔁 一、监听端的自动重连机制

推荐做法:使用 DefaultMessageListenerContainer 并设置重连间隔

DefaultMessageListenerContainer container = new DefaultMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
container.setDestinationName("MY.QUEUE");
container.setMessageListener(new MyListener());// ✅ 开启事务模式可选
container.setSessionTransacted(true);// ✅ 开启自动重连机制(默认是 true)
container.setRecoveryInterval(5000L); // 每 5 秒重试连接一次container.afterPropertiesSet();
container.start();

DefaultMessageListenerContainer 内部会捕获 ConnectionException 等连接中断异常,自动重试连接。


📤 二、发送端的容灾重连策略

监听容器有容器帮你维护连接,而 发送端(JmsTemplate)则需要连接池支撑

推荐:配合使用 CachingConnectionFactory

ConnectionFactory factory = createIBMConnectionFactory(); // 原始 MQ 工厂
CachingConnectionFactory cachingFactory = new CachingConnectionFactory(factory);// 可选设置缓存大小(缓存 session 的数量)
cachingFactory.setSessionCacheSize(10);JmsTemplate jmsTemplate = new JmsTemplate(cachingFactory);
jmsTemplate.convertAndSend("MY.QUEUE", "Hello MQ");

📌 为啥要用 CachingConnectionFactory

原因描述
重用连接避免每次发送都新建连接(开销大)
支持连接断开重建内部封装连接失效后重建逻辑
提供 session 缓存提升发送效率,降低资源消耗

🧰 三、JMS 厂商参数补充(IBM MQ 举例)

若你使用 IBM MQ,可以在底层工厂设置:

MQQueueConnectionFactory factory = new MQQueueConnectionFactory();factory.setHostName("192.168.1.102");
factory.setPort(1414);
factory.setQueueManager("QM1");
factory.setChannel("CHANNEL1");
factory.setTransportType(WMQConstants.WMQ_CM_CLIENT);// ✅ 启用自动重连
factory.setIntProperty(WMQConstants.WMQ_CLIENT_RECONNECT_OPTIONS,WMQConstants.WMQ_CLIENT_RECONNECT);// ✅ 设置最大重连时间(秒)
factory.setIntProperty(WMQConstants.WMQ_CLIENT_RECONNECT_TIMEOUT, 30);// ✅ 设置连接列表(用于集群 HA)
factory.setStringProperty(WMQConstants.WMQ_CONNECTION_NAME_LIST,"192.168.1.102(1414),192.168.1.103(1414)");

🔗 四、总结策略建议表

场景推荐设置
MQ监听端DefaultMessageListenerContainer + setRecoveryInterval
MQ发送端JmsTemplate + CachingConnectionFactory
多 broker/集群设置 CONNECTION_NAME_LIST
事务性保障setSessionTransacted(true) + onMessage() 异常触发 rollback
监听不生效检查是否调用了 afterPropertiesSet()

📘 下一篇预告:

《JMS事务性会话彻底解析:消息监听中的 commit、rollback 和幂等设计》

我们将深入剖析如何使用事务控制 MQ 消息的消费与回滚,Spring 容器如何自动帮你 commit/rollback,以及如何设计幂等保证系统不重复处理失败消息。


http://www.dtcms.com/wzjs/296804.html

相关文章:

  • 方案设计基本步骤北仑seo排名优化技术
  • wordpress多域一网seo长尾关键词优化
  • 网页升级紧急通知怎么取消seo资料网
  • 成都百度seo搜索引擎优化培训宁波seo外包公司
  • 什么网站可以做pie chart网站平台有哪些
  • 做网页和做网站百度搜索关键词规则
  • 舟山公司网站建设网络营销企业有哪些公司
  • 怎么做淘宝客网站和APP品牌推广方式都有哪些
  • wordpress创建三级分类抚顺优化seo
  • sharepoint网站制作下载一个百度时事新闻
  • 阜阳网站建设阜阳广告公司取名字参考大全
  • 建手机网站要多少钱广东省疫情最新
  • 包装设计网站官网搜索关键词网站
  • 网站建设功免费b站推广网站短视频
  • 社区网站的建设镇江关键字优化公司
  • szfob外贸论坛首页搜索引擎优化管理实验报告
  • flash美食网站论文分类信息网站平台有哪些
  • 做网站基本语言摘抄一小段新闻
  • 做网站公奇闻司郑州汉狮网络营销未来有哪些发展趋势
  • 网站开发运营新人要注意什么网络推广seo教程
  • 网站开发3687474企鹅个人推广app的妙招
  • 做结构设计有没有自学的网站bing搜索引擎
  • 一起来做网站什么是软文文案
  • 织梦网站建设流程全网营销整合营销
  • 中低端网站建设客户网免费推广网
  • 怎么制作微信购物网站网站排名优化价格
  • 飘雪影视在线观看免费观看西瓜上海网站快速排名优化
  • 怎样做百度网站推广网站搜索关键词优化
  • 群艺馆网站建设方案关键词热度分析工具
  • 海外打开网站慢推广引流网站