MQ 发送普通消息有三种实现方式:[color=red][b]可靠同步发送、可靠异步发送、单向(Oneway)发送。[/b][/color]本文介绍了每种实现的原理、使用场景以及三种实现的异同,同时提供了代码示例以供参考。
[size=medium][b]可靠同步发送[/b][/size]
原理:同步发送是指消息发送方发出数据后,会在收到接收方发回响应之后才发下一个数据包的通讯方式。
应用场景:此种方式应用场景非常广泛,例如重要通知邮件、报名短信通知、营销短信系统等。
[size=medium][color=red][b]可靠异步发送[/b][/color][/size]
[b]原理:异步发送是指发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式。[/b]MQ 的异步发送,需要用户实现异步发送回调接口(SendCallback),在执行消息的异步发送时,应用不需要等待服务器响应即可直接返回,通过回调接口接收服务器响应,并对服务器的响应结果进行处理。
[size=medium][color=red][b]1.在连接的URI中配置[/b][/color][/size]
你可以使用连接的URI支持的参数来配置异步发送的模式,如下所示:
cf = new ActiveMQConnectionFactory("tcp://locahost:61616?jms.useAsyncSend=true");
[size=medium][color=red][b]2.在ConnectionFactory层配置[/b][/color][/size]
你可以使用ActiveMQConnectionFactory对象实例,并通过下面的设置来使用异步模式:
((ActiveMQConnectionFactory)connectionFactory).setUseAsyncSend(true);
[size=medium][color=red][b]3.在Connection层配置[/b][/color][/size]
在Connection层的配置,将覆盖在ConnectionFactory层的配置。
你可以使用ActiveMQConnection对象实例,并通过下面的设置来使用异步模式:
((ActiveMQConnection)connection).setUseAsyncSend(true);
应用场景:异步发送一般用于链路耗时较长,对 RT 响应时间较为敏感的业务场景,例如用户视频上传后通知启动转码服务,转码完成后通知推送转码结果等。
[size=medium][color=red]