赞
踩
最近在开发Spring项目,其中用到了多个RabbitMQ,现在总结如下。
如果要配置多个RabbitMQ,就将rabbitMq相关的xml中的配置再复制一份,然后创建对应的生产者消费者类即可。
1.pom.xml中进行配置,导入jar包:
- <dependency>
- <groupId>org.springframework.amqp</groupId>
- <artifactId>spring-rabbit</artifactId>
- <version>1.3.5.RELEASE</version>
- </dependency>
- <dependency>
- <groupId>com.rabbitmq</groupId>
- <artifactId>amqp-client</artifactId>
- <version>3.3.4</version>
- </dependency>
2.创建rabbitmq的xml配置文件,路径例如:resources/context/context-rabbitMq.xml;这个路径与xml文件名可以自定义,只要spring配置文件中把这个xml包含了就行;内容如下:
- <!-- 配置rabbitMq链接 -->
- <bean id="connectionFactory" class="org.springframework.amqp.rabbit.connection.CachingConnectionFactory">
- <property name="username" value="${username}"/>
- <property name="password" value="${password}"/>
- <property name="port" value="${port}"/>
- <property name="virtualHost" value="${vhost}"/>
- <property name="channelCacheSize" value="50"/>
- <property name="connectionTimeout" value="5000"/>
- <property name="addresses" value="${addresses}"/>
- </bean>
-
- <!-- 配置admin信息后,当前producer中的exchange和queue会在rabbitmq服务器上自动生成 -->
- <rabbit:admin connection-factory="connectionFactory" />
-
- <!-- 消息队列消费者 -->
- <bean id="myConsumer" class="com.test.MyConsumer" />
-
- <rabbit:listener-container connection-factory="connectionFactory">
- <rabbit:listener ref="myConsumer" queue-names="${queue}" />
- </rabbit:listener-container>
-
- <!-- rabbitMQ实例,生产者用 -->
- <bean id="rabbitTemplate" class="org.springframework.amqp.rabbit.core.RabbitTemplate">
- <property name="connectionFactory" ref="connectionFactory" />
- <property name="channelTransacted" value="true" />
- </bean>
-
-
-
- <!-- 如果有多个mq,再复制一次上面的配置即可,bean的id设置成不同的,可以使用不同的链接信息 -->
3.编写properties配置文件,路径如:resources/properties/config.properties;路径与文件名可自定义,spring配置文件中把这个文件包含了就行,如:
- <bean name="propertyConfiger" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" >
- <property name="ignoreResourceNotFound" value="true" />
- <property name="locations">
- <list>
- <value>classpath:properties/config.properties</value>
- </list>
- </property>
- </bean>
“classpath:”指的就是resources文件夹。
config.properties内容如下,与rabbitmq中的${}对应:
- host=10.111.11.111,10.111.11.112,10.111.11.113
- port=5672
- username=admin
- password=admin
- #交换机名,mq生产者用
- exchange=e1.exchange
- queue=q1.queue
- vhost=v1.vhost
4.编写消费者类MyConsumer.java,这个类用来监听mq队列消息,如果队列中有数据,则拿出一个来处理。如下:
- public class MyConsumer implements MessageListener {
-
- private static final Logger log = LoggerFactory.getLogger(MyConsumer.class);
-
- @Override
- public void onMessage(Message message){
- String msg = "";
- MyMsgBean bean = null;
-
- try{
- //这里有个小坑,下面会提到
- //msg = new String(message.getBody(), message.getMessageProperties().getContentEncoding());
-
- //获取mq中的消息,从byte[]转为string
- msg = new String(message.getBody());
- //项目中,这个msg是json格式的String,再把String转为bean,容易处理些
- bean = JSONObject.parseObject(msg, MyMsgBean.class);
- //TODO 以下省略处理步骤
- }
- catch(Exception e){
- log.error("mq消费者异常",e);
- }
- }
- }
这个类在上方的context-rabbitMq.xml中配置过了(myConsumer),所以能实现自动监听mq队列并处理的功能。
5.编写生产者类MyProducer.java,这个类通过使用rabbitTemplate对象,把信息放入mq队列。如下:
- public class MyProducer{
-
- private static final Logger log = LoggerFactory.geetLogger(MyProducer.class);
-
- //交换机名称
- @Value("${e1.exchange}")
- private String exchange;
-
- //@Autowired
- private RabbitTemplate rabbitTemplate;
-
- public void setRabbitTemplate(RabbitTemplate rabbitTemplate){
- this.rabbitTemplate = rabbitTemplate;
- }
-
- public RabbitTemplate getRabbitTemplate(){
- return this.rabbitTemplate;
- }
-
-
- public void sendMsg(String msg){
- Message info = MessageBuilder.withBody(msg.getBytes())
- .setContentType(MessageProperties.CONTENT_TYPE_JSON)
- .setContentEncoding("utf-8")
- .build();
-
- try{
-
- rabbitTemplate.send(exchange,"",info);
-
- }catch(Exception e){
- log.error("生产者将信息放入mq失败!",e);
- }
- }
- }
这个类中的rabbitTemplate是第一步在xml中配置好的,所以能注入,用set方法注入的(也可以用注解注入,还可以用构造方法注入);
这个类本身也是在xml中配置的,然后其它类就可以注入这个类,调用这个类的sendMsg()方法把消息存入mq队列了(例如Controller.java类中注入这个类,然后给mq新增消息)
配置如:
- <bean id="myProducer" class="com.test.MyProducer">
- <property name="rabbitTemplate" ref="rabbitTemplate"></property>
- </bean>
6.其它:
直接输入mq的ip,然后输入mq的账号密码,可以登录mq管理中心;
在这个界面,点击queues,找到自己在使用的队列,可以手动给队列添加信息;
具体如下:
(1)找到Publish message下拉框;
(2)Headers中可以写key与value,对应Message对象中的Headers字段。
(3)Properties中可以写key与value,对应Message对象中的某些字段,点击旁边的"?"查看有效果的key,区分大小写;例如:
content_encoding=utf-8
(4)Properties中可以写具体信息,对应Message对象的getBody()方法获得的内容,例如:
{"json":"123"}
7.rabbitmq相关文章
rabbitmq三种模式:https://blog.csdn.net/fxq8866/article/details/62049393
rabbitmq结构:https://blog.csdn.net/vipshop_fin_dev/article/details/81612935
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。