国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

springboot基于Redis發布訂閱集群下WebSocket的解決方案

瀏覽:11日期:2023-03-27 17:15:12
一、背景

單機節點下,WebSocket連接成功后,可以直接發送消息。而多節點下,連接時通過nginx會代理到不同節點。

假設一開始用戶連接了node1的socket服務。觸發消息發送的條件的時候也通過nginx進行代理,假如代理轉到了node2節點上,那么node2節點的socket服務就發送不了消息,因為一開始用戶注冊的是node1節點。這就導致了消息發送失敗。

springboot基于Redis發布訂閱集群下WebSocket的解決方案

為了解決這一方案,消息發送時,就需要一個中間件來記錄,這樣,三個節點都可以獲取消息,然后在根據條件進行消息推送。

二、解決方案(springboot 基于 Redis發布訂閱)

1、依賴

<!-- redis --> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!-- websocket --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId></dependency>

2、創建業務處理類 Demo.class,該類可以實現MessageListener接口后重寫onMessage方法,也可以不實現,自己寫方法。

import com.alibaba.fastjson.JSON;import com.dy.service.impl.OrdersServiceImpl;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.data.redis.connection.Message;import org.springframework.data.redis.connection.MessageListener;import org.springframework.stereotype.Component; import java.util.HashMap; /** * @program: * @description: redis消息訂閱-業務處理 * @author: zhang yi * @create: 2021-01-25 16:46 */@Componentpublic class Demo implements MessageListener { Logger logger = LoggerFactory.getLogger(this.getClass()); @Override public void onMessage(Message message, byte[] pattern) { logger.info('消息訂閱成功---------'); logger.info('內容:'+message.getBody()); logger.info('交換機:'+message.getChannel()); }}

3、創建PubSubConfig配置類

import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.cache.annotation.EnableCaching;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;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; /** * @program: * @description: redis發布訂閱配置 * @author: zhang yi * @create: 2021-01-25 16:49 */@Configuration@EnableCachingpublic class PubSubConfig { Logger logger = LoggerFactory.getLogger(this.getClass()); //如果是多個交換機,則參數為(RedisConnectionFactory connectionFactory, // MessageListenerAdapter listenerAdapter, // MessageListenerAdapter listenerAdapter2) @Bean RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory, MessageListenerAdapter listenerAdapter) { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(connectionFactory); // 可以添加多個 messageListener,配置不同的交換機 container.addMessageListener(listenerAdapter, new PatternTopic('channel:demo')); //container.addMessageListener(listenerAdapter2, new PatternTopic('channel:demo2')); return container; } /** * 消息監聽器適配器,綁定消息處理器,利用反射技術調用消息處理器的業務方法 * @param demo 第一步的業務處理類 * @return */ @Bean MessageListenerAdapter listenerAdapter(Demo demo) { logger.info('----------------消息監聽器加載成功----------------'); // onMessage 就是方法名,基于反射調用 return new MessageListenerAdapter(demo, 'onMessage'); } /** * 多個交換機就多寫一個 * @param subCheckOrder * @return */ //@Bean //MessageListenerAdapter listenerAdapter2(SubCheckOrder subCheckOrder) { // logger.info('----------------消息監聽器加載成功----------------'); // return new MessageListenerAdapter(subCheckOrder, 'onMessage'); //} @Bean StringRedisTemplate template(RedisConnectionFactory connectionFactory) { return new StringRedisTemplate(connectionFactory); }}

4、消息發布

@Autowiredprivate RedisTemplate<String, Object> redisTemplate; redisTemplate.convertAndSend('channel:demo', '我是內容');三、具體用法 socket連接成功。 socket消息推送時,把信息發布到redis中。socket服務訂閱redis的消息,訂閱成功后進行推送。集群下的socket都能訂閱到消息,但是只有之前連接成功的節點能推送成功,其余的無法推送。

標簽: Spring
相關文章:
主站蜘蛛池模板: 性欧美另类老妇高清 | 中国女人真人一级毛片 | 国产成人综合亚洲 | 国产精品美女一区二区 | 久草在在线视频免费 | 精品中文字幕不卡在线视频 | 一级毛片成人免费看a | 欧美亚洲日本一区二区三区浪人 | 国产高清免费影视在线观看 | 中文字幕无线码中文字幕网站 | 色精品视频 | 天天看夜夜看 | 久久99国产一区二区三区 | www夜色| 五月天激激婷婷大综合蜜芽 | 特级毛片全部免费播放a一级 | 午夜毛片视频高清不卡免费 | 播播网手机在线播放 | 国产毛片久久国产 | 一级做a爰片性色毛片男 | 亚洲欧美日韩国产专区一区 | 伊大人香蕉久久网欧美 | 日a在线| 毛片网站免费在线观看 | 9191精品国产费久久 | 日本美女性爱 | 亚洲成a人片在线网站 | 一级特级欧美aaaaa毛片 | 看一级特黄a大一片 | 国产综合久久 | 久久99久久精品视频 | 中文字幕久久亚洲一区 | 免费观看性欧美大片无片 | 成人手机看片 | 免费一级毛片在线播放放视频 | 毛片在线看免费 | 日本三级网站在线线观看 | 国产三片高清在线观看 | 亚洲三级黄色 | 中日韩美中文字幕 | 日韩精品一区二区三区 在线观看 |