亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

flask - Python使用redis發布訂閱時,監聽頻道時出現的問題?【一句話描述不清楚,請各位細看內容】

瀏覽:113日期:2022-08-21 17:05:26

問題描述

我想在Flask應用中添加一個簡單的消息通知功能,查了很多資料,發現通知功能主要有兩個問題【這也只是個人愚見,請指正】1:服務器如何向客戶端發送消息?2:服務器如何知道何時該發送消息了?【例如,管理員想發個全站公告,這時就需要對應的模塊向客戶端發送通知,該如何通知該模塊呢?】

對于問題1:我使用H5推出的SSE規范,使得服務器可以單向向客戶端發送消息。對于問題2:我首先想到的是輪詢數據庫中的消息表,一旦發現有相應的消息插入,就向客戶端推送。但是感覺這樣太耗資源了。于是又詢問了網上的前輩,有人說使用redis做緩存。于是今天又仔細看了一天關于redis消息的發布/訂閱功能【比較愚笨】。于是我想到了下面的方法:每當消息表插入消息時,就向對應的頻道發布一條消息,內容主要是要發送消息的主要組成部分,然后對應的消息發送模塊已經訂閱了這個頻道,當然就能收到要發送的消息了??墒锹犞唵?,我在實踐時又遇到了一個問題,具體的示例如下所示:問題一:這是SSE訪問的路由,在該路由中訂閱頻道

flask - Python使用redis發布訂閱時,監聽頻道時出現的問題?【一句話描述不清楚,請各位細看內容】

ps.listen是用來監聽頻道的,源碼中是一個while循環,如下所示:

flask - Python使用redis發布訂閱時,監聽頻道時出現的問題?【一句話描述不清楚,請各位細看內容】

如果頻道中有發布消息,那么for循環中就能取出data,然后返回,這樣看著挺好,但是SSE規范中,如果每隔一段時間服務器沒有發送數據的話,就會重新請求連接。我設置的時間是1分鐘【自我感覺已經夠長了】,可是如果10分鐘甚至更長時間頻道中都沒有消息,那么for循環就取不出data,’/sse’請求就會一直得不到響應,就會出現下面的情況:

flask - Python使用redis發布訂閱時,監聽頻道時出現的問題?【一句話描述不清楚,請各位細看內容】

這種情況應該也是很消耗資源的吧,請問該怎么解決這種情況呢?

問題二:我的SSE規范的代碼在message.html中寫的,訪問路由如下【hello_world只是示例】:flask - Python使用redis發布訂閱時,監聽頻道時出現的問題?【一句話描述不清楚,請各位細看內容】

總感覺訪問’/message’的時候特別卡,這是怎么回事,是跟線程有關系嗎?

望各位前輩能夠指導下該怎么解決上述的問題。

問題解答

回答1:

import redis, threadingr = redis.Redis(host=’127.0.0.1’, port=6379, db=3)def x(): while 1:time.sleep(3)r.publish('a', ’a_%s’% time.time())r.publish(’b’, ’b_%s’% time.time())xt = threading.Thread(target=x)xt.setDaemon(True)xt.start()ps = r.pubsub()ps.subscribe([’a’, ’b’])for item in ps.listen(): print item

標簽: Python 編程
主站蜘蛛池模板: 欧美日韩专区国产精品 | 999精品 | 欧美伦理一区二区三区 | 另类欧美亚洲 | 一级黄色片黄色片 | 香蕉久久国产精品免 | 爱逼综合 | 一级毛片大全免费播放 | 成人做爰全过程免费的叫床看视频 | 视频在线观看一区二区三区 | 国产福利视频一区美女 | 一本色道久久综合狠狠躁篇 | 亚洲黄v| 91视频网| 在线免费观看亚洲视频 | 2021久久精品国产99国产 | 欧美一级视频在线高清观看 | 女人被免费视频网站 | 国产日韩欧美不卡www | 免费看黄网址 | 亚洲视频91| 网红主播vip福利视频 | 538精品视频 | 99re5久久在热线播放 | 午夜一级视频 | 国产欧美国日产网站 | 黄色中文字幕在线观看 | 中文字幕亚洲一区二区va在线 | 国产这里只有精品 | 91精品国产综合久久婷婷 | 国产一国产一级毛片视频 | 亚洲国产经典 | 日韩免费小视频 | 亚洲精品在线第一页 | 无夜精品久久久久久 | 国产各种盗摄视频 | 特别黄的免费视频大片 | 拍拍拍精品视频在线观看 | 亚洲欧美另类在线视频 | 国产亚洲情侣一区二区无 | 小明www永久免费播放平台 |