增加rabbitMQ 用例
This commit is contained in:
		| @@ -0,0 +1,23 @@ | ||||
| package com.heibaiying.bean; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import java.util.Date; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description : | ||||
|  */ | ||||
| @Data | ||||
| @AllArgsConstructor | ||||
| @NoArgsConstructor | ||||
| public class ProductManager { | ||||
|  | ||||
|     private String name; | ||||
|  | ||||
|     private int age; | ||||
|  | ||||
|     private Date birthday; | ||||
| } | ||||
| @@ -0,0 +1,25 @@ | ||||
| package com.heibaiying.bean; | ||||
|  | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import java.util.Date; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description : | ||||
|  */ | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @AllArgsConstructor | ||||
| public class Programmer { | ||||
|  | ||||
|     private String name; | ||||
|  | ||||
|     private int age; | ||||
|  | ||||
|     private float salary; | ||||
|  | ||||
|     private Date birthday; | ||||
| } | ||||
| @@ -0,0 +1,12 @@ | ||||
| package com.heibaiying.constant; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description : | ||||
|  */ | ||||
| public interface Type { | ||||
|  | ||||
|     String MANAGER="manager"; | ||||
|  | ||||
|     String PROGRAMMER="programmer"; | ||||
| } | ||||
| @@ -0,0 +1,20 @@ | ||||
| package com.heibaiying.rabbit; | ||||
|  | ||||
| import com.heibaiying.bean.ProductManager; | ||||
| import com.heibaiying.bean.Programmer; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description :消息委派处理类 | ||||
|  */ | ||||
| public class MessageDelegate { | ||||
|  | ||||
|     public void handleMessage(ProductManager manager) { | ||||
|         System.out.println("收到一个产品经理" + manager); | ||||
|     } | ||||
|  | ||||
|     public void handleMessage(Programmer programmer) { | ||||
|         System.out.println("收到一个程序员" + programmer); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,102 @@ | ||||
| package com.heibaiying.rabbit; | ||||
|  | ||||
| import com.rabbitmq.client.Channel; | ||||
| import org.springframework.amqp.core.*; | ||||
| import org.springframework.amqp.rabbit.connection.ConnectionFactory; | ||||
| import org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer; | ||||
| import org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener; | ||||
| import org.springframework.context.annotation.Bean; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description : 声明队列、交换机、绑定关系、和队列消息监听 | ||||
|  */ | ||||
|  | ||||
| @Configuration | ||||
| public class RabbitBaseAnnotation { | ||||
|  | ||||
|     @Bean | ||||
|     public TopicExchange exchange() { | ||||
|         // 创建一个持久化的交换机 | ||||
|         return new TopicExchange("topic01", true, false); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Queue firstQueue() { | ||||
|         // 创建一个持久化的队列1 | ||||
|         return new Queue("FirstQueue", true); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Queue secondQueue() { | ||||
|         // 创建一个持久化的队列2 | ||||
|         return new Queue("SecondQueue", true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * BindingKey 中可以存在两种特殊的字符串“#”和“*”,其中“*”用于匹配一个单词,“#”用于匹配零个或者多个单词 | ||||
|      * 这里我们声明三个绑定关系用于测试topic这种类型交换器 | ||||
|      */ | ||||
|     @Bean | ||||
|     public Binding orange() { | ||||
|         return BindingBuilder.bind(firstQueue()).to(exchange()).with("*.orange.*"); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Binding rabbit() { | ||||
|         return BindingBuilder.bind(secondQueue()).to(exchange()).with("*.*.rabbit"); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Binding lazy() { | ||||
|         return BindingBuilder.bind(secondQueue()).to(exchange()).with("lazy.#"); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /*创建队列1消费者监听*/ | ||||
|     @Bean | ||||
|     public SimpleMessageListenerContainer firstQueueLister(ConnectionFactory connectionFactory) { | ||||
|  | ||||
|         SimpleMessageListenerContainer container = new SimpleMessageListenerContainer(connectionFactory); | ||||
|         // 设置监听的队列 | ||||
|         container.setQueues(firstQueue()); | ||||
|         // 指定要创建的并发使用者数。 | ||||
|         container.setConcurrentConsumers(1); | ||||
|         // 设置消费者数量的上限 | ||||
|         container.setMaxConcurrentConsumers(5); | ||||
|         // 设置是否自动签收消费 为保证消费被成功消费,建议手工签收 | ||||
|         container.setAcknowledgeMode(AcknowledgeMode.MANUAL); | ||||
|         container.setMessageListener(new ChannelAwareMessageListener() { | ||||
|             @Override | ||||
|             public void onMessage(Message message, Channel channel) throws Exception { | ||||
|                 // 可以在这个地方得到消息额外属性 | ||||
|                 MessageProperties properties = message.getMessageProperties(); | ||||
|                 //得到消息体内容 | ||||
|                 byte[] body = message.getBody(); | ||||
|                 System.out.println(firstQueue().getName() + "收到消息:" + new String(body)); | ||||
|                 //第二个参数 代表是否一次签收多条 | ||||
|                 channel.basicAck(properties.getDeliveryTag(), false); | ||||
|             } | ||||
|         }); | ||||
|         return container; | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /*创建队列2消费者监听*/ | ||||
|     @Bean | ||||
|     public SimpleMessageListenerContainer secondQueueLister(ConnectionFactory connectionFactory) { | ||||
|  | ||||
|         SimpleMessageListenerContainer container = new SimpleMessageListenerContainer(connectionFactory); | ||||
|         container.setQueues(secondQueue()); | ||||
|         container.setMessageListener(new ChannelAwareMessageListener() { | ||||
|             @Override | ||||
|             public void onMessage(Message message, Channel channel) throws Exception { | ||||
|                 byte[] body = message.getBody(); | ||||
|                 System.out.println(secondQueue().getName() + "收到消息:" + new String(body)); | ||||
|             } | ||||
|         }); | ||||
|         return container; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,73 @@ | ||||
| package com.heibaiying.rabbit; | ||||
|  | ||||
| import com.heibaiying.constant.Type; | ||||
| import com.rabbitmq.client.Channel; | ||||
| import org.springframework.amqp.core.*; | ||||
| import org.springframework.amqp.rabbit.connection.ConnectionFactory; | ||||
| import org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer; | ||||
| import org.springframework.amqp.rabbit.listener.adapter.MessageListenerAdapter; | ||||
| import org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener; | ||||
| import org.springframework.amqp.support.converter.DefaultJackson2JavaTypeMapper; | ||||
| import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter; | ||||
| import org.springframework.context.annotation.Bean; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
|  | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * @author : heibaiying | ||||
|  * @description : 声明队列、交换机、绑定关系、用于测试对象的消息传递 | ||||
|  */ | ||||
|  | ||||
| @Configuration | ||||
| public class RabbitObjectAnnotation { | ||||
|  | ||||
|     @Bean | ||||
|     public DirectExchange objectTopic() { | ||||
|         // 创建一个持久化的交换机 | ||||
|         return new DirectExchange("objectTopic", true, false); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Queue objectQueue() { | ||||
|         // 创建一个持久化的队列 | ||||
|         return new Queue("objectQueue", true); | ||||
|     } | ||||
|  | ||||
|     @Bean | ||||
|     public Binding binding() { | ||||
|         return BindingBuilder.bind(objectQueue()).to(objectTopic()).with("object"); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     /*创建队列消费者监听*/ | ||||
|     @Bean | ||||
|     public SimpleMessageListenerContainer objectQueueLister(ConnectionFactory connectionFactory) { | ||||
|  | ||||
|         SimpleMessageListenerContainer container = new SimpleMessageListenerContainer(connectionFactory); | ||||
|         // 设置监听的队列 | ||||
|         container.setQueues(objectQueue()); | ||||
|         // 将监听到的消息委派给实际的处理类 | ||||
|         MessageListenerAdapter adapter = new MessageListenerAdapter(new MessageDelegate()); | ||||
|         // 指定由哪个方法来处理消息 默认就是handleMessage | ||||
|         adapter.setDefaultListenerMethod("handleMessage"); | ||||
|  | ||||
|         // 消息转换 | ||||
|         Jackson2JsonMessageConverter jackson2JsonMessageConverter = new Jackson2JsonMessageConverter(); | ||||
|         DefaultJackson2JavaTypeMapper javaTypeMapper = new DefaultJackson2JavaTypeMapper(); | ||||
|  | ||||
|         Map<String, Class<?>> idClassMapping = new HashMap<>(); | ||||
|         // 针对不同的消息体调用不同的重载方法 | ||||
|         idClassMapping.put(Type.MANAGER, com.heibaiying.bean.ProductManager.class); | ||||
|         idClassMapping.put(Type.PROGRAMMER, com.heibaiying.bean.Programmer.class); | ||||
|  | ||||
|         javaTypeMapper.setIdClassMapping(idClassMapping); | ||||
|  | ||||
|         jackson2JsonMessageConverter.setJavaTypeMapper(javaTypeMapper); | ||||
|         adapter.setMessageConverter(jackson2JsonMessageConverter); | ||||
|         container.setMessageListener(adapter); | ||||
|         return container; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,5 @@ | ||||
| rabbitmq.addresses=localhost:5672 | ||||
| rabbitmq.username=guest | ||||
| rabbitmq.password=guest | ||||
| # <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD><EFBFBD>ռ<EFBFBD> Ĭ<><C4AC>Ϊ/  <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͼ<EFBFBD>ν<EFBFBD><CEBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>߹ܿ<DFB9>̨<EFBFBD><CCA8><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><F2B2BBBB>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB>׳<EFBFBD><D7B3>쳣 | ||||
| rabbitmq.virtualhost=/ | ||||
							
								
								
									
										43
									
								
								spring/spring-rabbitmq/src/main/resources/rabbitmq.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								spring/spring-rabbitmq/src/main/resources/rabbitmq.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <beans xmlns="http://www.springframework.org/schema/beans" | ||||
|        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|        xmlns:context="http://www.springframework.org/schema/context" | ||||
|        xmlns:rabbit="http://www.springframework.org/schema/rabbit" | ||||
|        xsi:schemaLocation= | ||||
|                "http://www.springframework.org/schema/context | ||||
|           http://www.springframework.org/schema/context/spring-context.xsd | ||||
|           http://www.springframework.org/schema/beans | ||||
|           http://www.springframework.org/schema/beans/spring-beans.xsd | ||||
|           http://www.springframework.org/schema/rabbit | ||||
|           http://www.springframework.org/schema/rabbit/spring-rabbit.xsd"> | ||||
|  | ||||
|     <context:property-placeholder location="rabbitmq.properties"/> | ||||
|  | ||||
|     <!--声明连接工厂--> | ||||
|     <rabbit:connection-factory id="connectionFactory" | ||||
|                                addresses="${rabbitmq.addresses}" | ||||
|                                username="${rabbitmq.username}" | ||||
|                                password="${rabbitmq.password}" | ||||
|                                virtual-host="${rabbitmq.virtualhost}"/> | ||||
|  | ||||
|     <!--创建一个管理器(org.springframework.amqp.rabbit.core.RabbitAdmin),用于管理交换,队列和绑定。 | ||||
|     auto-startup 指定是否自动声明上下文中的队列,交换和绑定, 默认值为true。--> | ||||
|     <rabbit:admin connection-factory="connectionFactory" auto-startup="true"/> | ||||
|  | ||||
|     <!--声明 template 的时候需要声明id 不然会抛出异常--> | ||||
|     <rabbit:template id="rabbitTemplate" connection-factory="connectionFactory"/> | ||||
|  | ||||
|  | ||||
|     <!--可以在xml采用如下方式声明交换机、队列、绑定管理 但是建议使用代码方式声明 方法更加灵活且可以采用链调用--> | ||||
|     <rabbit:queue name="remoting.queue"/> | ||||
|  | ||||
|     <rabbit:direct-exchange name="remoting.exchange"> | ||||
|         <rabbit:bindings> | ||||
|             <rabbit:binding queue="remoting.queue" key="remoting.binding"/> | ||||
|         </rabbit:bindings> | ||||
|     </rabbit:direct-exchange> | ||||
|  | ||||
|     <!--扫描rabbit包 自动声明交换器、队列、绑定关系--> | ||||
|     <context:component-scan base-package="com.heibaiying.rabbit"/> | ||||
|  | ||||
| </beans> | ||||
		Reference in New Issue
	
	Block a user