本地连接云端消息队列rocketmq注意事项

博客作者在遇到RocketMQ发送消息时的错误‘closeChannel:closetheconnectiontoremoteaddress’后,通过调整nameserver和broker的内存配置,设置brokerIP1,以及正确重启服务等步骤解决了问题。关键点包括更改配置文件、使用公网地址以及确保正确重启所有相关进程。

需求:本地数据库库存信息推到redis之后,通过RocketMQ进行Redis和数据库的异步交互。在发送消息的时候一直报错:
closeChannel: close the connection to remote address
参考了以下链接:
https://blog.csdn.net/lwycc2333/article/details/106629237/?spm=1001.2101.3001.4242)
但是仍没有解决。
又经过仔细排查才解决,梳理了一下要点:
1.更改nameserver和broker内存配置,一共四个文件两个.xml和两个.sh,由于我买的云主机比较小,就改成64或者32M的

2.broker.conf加上brokerIP1=xxx.xxx.xxx.xxx(服务器公网地址)

3.向其他很多博客说的,启动server 和broker的时候使用公网地址:
nohup ./bin/mqnamesrv -n 公网ip:9876 &
nohup sh bin/mqbroker -n 公网ip:9876 -c conf/broker.conf autoCreateTopicEnable=true &

4.我之前一直没有更改成功是因为我重启的时候只根据线程id只重启了server,忘了重启broker,导致之前更改的未生效。可以直接根据ps -ef|grep broker 或者ps -ef|grep name
来搜索并杀掉对应的线程,也可使用自带的停止命令:
关闭namesrv服务:sh bin/mqshutdown namesrv
关闭broker服务 :sh bin/mqshutdown broker

在网易云信中,云端消息与本地消息是两种不同类型的消息处理机制,分别适用于不同的使用场景需求。 ### 云端消息 云端消息是指消息在传输过程中经过云服务器进行中转存储。这种方式具有较高的可靠性可扩展性,适合用于需要确保消息送达、支持多端同步以及历史消息查询的场景。例如,在企业微信的应用消息、API 消息等类型中,云端消息能够保证消息的持久化存储,并通过频率控制机制避免对用户造成干扰[^2]。此外,在大规模实时通信场景如直播弹幕分发中,云端消息可以通过 CDN 连接混合推送的方式,实现高效的消息广播[^3]。 ### 本地消息 本地消息则是在客户端之间直接传输,不经过云端存储或中转。这类消息通常用于低延迟、高实时性的交互场景,例如即时通讯中的控制消息(如群信息变更通知)。由于本地消息不需要经过服务器中转,因此在网络条件良好的情况下可以显著降低传输延迟,但其缺点是不具备消息持久化能力,若接收方离线则可能丢失消息。 ### 对比分析 | 特性 | 云端消息 | 本地消息 | |--------------------|------------------------------------------|--------------------------------------| | **消息存储** | 支持消息存储,可实现多端同步 | 不存储消息,仅实时传输 | | **可靠性** | 高,支持重传历史消息检索 | 较低,依赖网络状态客户端在线情况 | | **延迟性** | 相对较高,因需经过云端中转 | 低,直接客户端间传输 | | **适用场景** | 应用消息、公告、跨设备通信等需要持久化的场景 | 控制类消息、即时通讯中的高频小数据交互 | | **网络依赖** | 强,依赖稳定的网络连接 | 弱,适合短时高速通信 | ### 示例代码:云端消息发送逻辑(伪代码) ```python def send_cloud_message(message, recipient): # 连接云端服务器 server_connection = connect_to_server() # 发送消息至云端 cloud_response = server_connection.send(message) # 确认消息是否成功送达 if cloud_response.status == "success": update_local_cache(message, recipient) return True else: retry_queue.add(message) return False ``` ### 示例代码:本地消息发送逻辑(伪代码) ```python def send_local_message(message, recipient): # 直接通过本地网络栈发送 try: recipient_socket = establish_connection(recipient) recipient_socket.send(message) return True except ConnectionError: return False ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值