设为首页 收藏本站
查看: 832|回复: 0

[经验分享] RabbitMQ学习以及与Spring的集成(三)

[复制链接]

尚未签到

发表于 2017-7-2 15:28:02 | 显示全部楼层 |阅读模式
  本文介绍RabbitMQ与Spring的简单集成以及消息的发送和接收。
  在RabbitMQ的Spring配置文件中,首先需要增加命名空间。



xmlns:rabbit="http://www.springframework.org/schema/rabbit"
  其次是模式文档,这里按1.0的来。



xsi:schemaLocation="
http://www.springframework.org/schema/rabbit
http://www.springframework.org/schema/rabbit/spring-rabbit-1.0.xsd"
  配置connection-factory元素。



<rabbit:connection-factory id="connectionFactory"
username="mmq" password="mmq" host="192.168.1.138" port="5672" virtual-host="/vhost1" />
  配置connection-factory元素实际是注册一个org.springframework.amqp.rabbit.connection.CachingConnectionFactory实例。
  参数介绍:
  id:bean的id值。
  host:RabbitMQ服务器地址。默认值"localhost"。
  port:RabbitMQ服务端口,默认值"5672"。
  virtual-host:虚拟主机,默认是"/"。
  usernamepassword就是访问RabbitMQ服务的账户和密码了。
  channel-cache-size:channel的缓存数量。新版本默认是25。
  消息队列queue的配置。



<!--定义queue queueTest -->
<rabbit:queue name="queueTest" durable="true" auto-delete="false" exclusive="false"  />
  参数介绍:
  name:queue的名字。
  durable:是否为持久的。默认是true,RabbitMQ重启后queue依然存在。
  auto-delete:表示消息队列没有在使用时将被自动删除。默认是false。
  exclusive:表示该消息队列是否只在当前connection生效。默认false。
  交换器exchange的配置。



<rabbit:direct-exchange name="exchangeTest" durable="true" auto-delete="false">
<rabbit:bindings>
<rabbit:binding queue="queueTest" key="queueTestKey"></rabbit:binding>
</rabbit:bindings>
</rabbit:direct-exchange>
  参数介绍:
  name:exchange的名字。
  durable:是否为持久的,默认为true,RabbitMQ重启后exhange依然存在。
  auto-delete:表示exchange在未被使用时是否自动删除,默认是false。
  key:queue在该direct-exchange中的key值。当消息发送给该direct-exchange中指定key为设置值时,消息将会转发给queue参数指定的消息队列。
  Spring为方便使用RabbitMQ服务,提供一个操作模板类:org.springframework.amqp.rabbit.core.RabbitTemplate。



<rabbit:template id="amqpTemplate"  connection-factory="connectionFactory" exchange="exchangeTest" />
  配置也很简单。template还有其他的配置项,可以自己查看xsd文件中的说明。
  最后一个配置项是消息consumer。其实也可以叫做listener。简单的配置如下。



<rabbit:listener-container connection-factory="connectionFactory">
<rabbit:listener  queues="queueTest" ref="messageConsumer"/>
</rabbit:listener-container>
  messageConsumer是一个简单bean类,可以用注解标识。



@Component("messageConsumer")
public class MessageConsumer implements MessageListener {
public void onMessage(Message message) {}  
}
  类作为消息监听器,必须实现接口MessageListener或者是接口ChannelAwareMessageListener。
  另一种配置方式是使用method参数,指定消息处理的方法,以org.springframework.amqp.core.Message类作为方法参数。
  配置完成并写好消息监听处理类后就可以尝试发送消息了。



public class MessageProducer{
@Resource
private AmqpTemplate amqpTemplate;
public void sendMessage(){
Message message = MessageBuilder.withBody("hello rabbit".getBytes("utf-8"))
.setMessageId(System.currentTimeMillis()+"")
.build();
this.amqpTemplate.send("queueTestKey", message);
}  
}
  消息监听方法。



public void onMessage(Message message){
String content = new String(message.getBody(),"utf-8");
system.out.println(content);
}
  消息内容发送时会被转换为字节数组,默认以UTF-8进行编码。如果想要发送对象信息,按照类实例的序列化和反序列化进行操作即可。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-390429-1-1.html 上篇帖子: RabbitMQ基础知识篇 下篇帖子: Leetcode27--->Remove Element(移除数组中给定元素)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表