1.Maven引用
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
2.redis屬性配置
spring.redis.database=0 spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password=****** server.port=5555
3.設置監聽相關對象
3.1接聽對象
RedisReceiver可以是普通類或者繼承MessageListener,普通類的寫法如下,接收的時候只接收到消息,沒有頻道名
package com.example.redistest.config; import org.springframework.data.redis.connection.Message; import org.springframework.data.redis.connection.MessageListener; import org.springframework.stereotype.Component; @Component public class RedisReceiver { public void receiveMessage(String message) { // TODO 這里是收到通道的消息之后執行的方法 System.out.println(message); } }
繼承MessageListener,就能拿到消息體和頻道名。
package com.example.redistest.config; import org.springframework.data.redis.connection.Message; import org.springframework.data.redis.connection.MessageListener; import org.springframework.stereotype.Component; @Component public class RedisReceiver implements MessageListener { @Override public void onMessage(Message message, byte[] pattern) { System.out.println(new String(message.getBody())); System.out.println(new String(message.getChannel())); } }
3.2 配置監聽適配器、消息監聽容器
container.addMessageListener(listenerAdapter, new PatternTopic("channel:test"));
消息監聽容器增加監聽的消息,第一個參數是監聽適配器,第2個參數是監聽的頻道。
package com.example.redistest.config; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.MessageListener; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.data.redis.listener.PatternTopic; import org.springframework.data.redis.listener.RedisMessageListenerContainer; import org.springframework.data.redis.listener.adapter.MessageListenerAdapter; @Configuration @EnableCaching public class RedisCacheConfig { @Bean RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory, MessageListenerAdapter listenerAdapter) { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(connectionFactory); // 可以添加多個 messageListener,配置不同的交換機 container.addMessageListener(listenerAdapter, new PatternTopic("channel:test")); return container; } @Bean MessageListenerAdapter listenerAdapter(RedisReceiver receiver) { System.out.println("消息適配器1"); return new MessageListenerAdapter(receiver, "onMessage"); } @Bean StringRedisTemplate template(RedisConnectionFactory connectionFactory) { return new StringRedisTemplate(connectionFactory); } }
3.3 消息發送
package com.example.redistest.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.data.redis.core.ValueOperations; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import java.util.Date; @RequestMapping("/redis") @Controller public class RedisController { @Autowired StringRedisTemplate template; /** * 發布消息 * * @param id * @return */ @RequestMapping("/sendMessage/{id}") public String sendMessage(@PathVariable String id) { for(int i = 1; i <= 5; i++) { template.convertAndSend("channel:test", String.format("我是消息{%d}號: %tT", i, new Date())); } return ""; } }
測試
postman訪問http://localhost:5555/redis/sendMessage/1
接收消息后打印