好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > redis鍵空間通知使用實現

redis鍵空間通知使用實現

熱門標簽:貴州電銷卡外呼系統 十堰營銷電銷機器人哪家便宜 魔獸2青云地圖標注 超呼電話機器人 日本中國地圖標注 山東外呼銷售系統招商 宿遷便宜外呼系統平臺 鄭州人工智能電銷機器人系統 北京400電話辦理收費標準

導語

最近在開發一個定時活動,而且活動是多個場次的。這個是后就需要在活動開始的時候推送信息給客戶端,結束的時候也要推送一次。簡單的設計方案就是將配置緩存在redis,然后每隔一秒就輪詢reids,獲取配置信息,然后判斷是不是到活動開始或者結束的時間點,然后推送給客戶端。

但是,這里會有一個問題,如果沒有到活動開始或結束的時間點,這里會造成很多無用的輪詢操作。這個操作不但增大了對這個key的訪問量,同時也會占用cpu,降低機器性能。

redis在2.8.0版本提供了一個鍵空間通知功能機制,對于這個功能的詳細描述,可以查閱官方文檔。簡單總結就是,客戶端可以訂閱一個key,當這個可以發生改變時,redis會通知到已經訂閱的客戶端。

實現

這個實現也很簡單,我們可以通過一個demo來看看如何使用這個機制。

package main

import (
   "context"
   "fmt"
   "github.com/go-redis/redis/v8"
   "time"
)

var redisCli *redis.Client

func init() {
   // 連接redis
   redisCli = redis.NewClient(redis.Options{
      Addr:     "127.0.0.1:6379",
      Password: "redis123",
   })
}

/*
 * redis key 過期自動通知
 */
func SetExpireEvent() {
   // 設置一個鍵,并且3秒鐘之后過期
   redisCli.Set(context.Background(), "test_expire_event_notify", "測試鍵值過期通知", 3*time.Second)
}

func SubExpireEvent() {
   // 訂閱key過期事件
   sub := redisCli2.Subscribe(context.Background(), "__keyevent@0__:expired")
   
   // 這里通過一個for循環監聽redis-server發來的消息。
   // 當客戶端接收到redis-server發送的事件通知時,
   // 客戶端會通過一個channel告知我們。我們再根據
   // msg的channel字段來判斷是不是我們期望收到的消息,
   // 然后再進行業務處理。
   for {
      msg := -sub.Channel()
      fmt.Println("Channel ", msg.Channel)
      fmt.Println("pattern ", msg.Pattern)
      fmt.Println("pattern ", msg.Payload)
      fmt.Println("PayloadSlice ", msg.PayloadSlice)
   }
}

func main() {
   SetExpireEvent()
   go SubExpireEvent()
   
   // 這里sleep是為了防止main方法直接推出
   time.Sleep(10 * time.Second)
}

代碼結果輸出如下:

上面代碼實現邏輯很簡單,核心邏輯就是訂閱__keyevent@0__:expired這個事件,然后一個循環等待事件的通知。值得注意的是,要啟用這個特性需要修改配置文件,啟用notify-keyspace-events這個配置,可以參考配置文件中的注釋對不同事件進行啟用。

在業務中使用

回到開始提及的業務場景,如何在這種場景中使用redis的機制呢?其實很簡單,當活動配置到數據庫之后,會有一個更新緩存的步驟。在將數據設置在活動緩存時,只要我們計算當前時間到活動開始/結束這個時間差,將這個差作為鍵的過期時間。

例如,活動id1的開始時間為t0, 結束時間為t2, 當前時間為t。這個時候就可以這么設置:

// 活動開始的key設置
redisCli.Set(context.Background(), "id1:start", "活動開始了", t0 - t)
// 活動結束結束的key設置
redisCli.Set(context.Background(), "id1:start", "活動開始了", t1 - t)

通過這么設置,當活動開啟/結束就可以接收到相應的通知了。

總結

這種方案其實可以完全滿足文中的需求場景,但是這種方案其實也存在一些問題。其實這些問題在redis文檔中也有相應說明。

  • 第一,redis-server在推送這個事件通知時,只要訂閱了這個事件的客戶端端都會收到這個消息。通常,我們的業務都是跑在多個結點中,所以這個時候就要根據場景看要不要進行業務的原子操作。
  • 第二,redis-server只會推送一次這個通知。假如說在redis-server推送這個通知時,結點掛了或者由于其他異常情況沒有收到消息,redis-server不會再重新推送。
  • 第三,通知可能會延遲。由于redis實現機制,對于過期的鍵,會有兩種機制進行處理,一種是當命令訪問鍵時,發現鍵已過期。另一種是通過后臺系統在后臺逐步查找過期的鍵,以便能夠收集那些從未被訪問的鍵。所以會有出現延遲的可能。

本文介紹了使用redis的鍵空間通知機制來實現了一種業務場景,當然這種方式并不是最好的,還有其他方式來實現。在實際開發中會有很多的因素要考慮,而且實現方式也是多種多樣,這個就需要我們分析每一種方案的利弊,然后進行抉擇。

到此這篇關于redis鍵空間通知使用實現的文章就介紹到這了,更多相關redis鍵空間通知 內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • redis學習之RDB、AOF與復制時對過期鍵的處理教程
  • 大家都應該知道的Redis過期鍵與過期策略
  • Redis 2.8-4.0過期鍵優化過程全紀錄
  • Redis開啟鍵空間通知實現超時通知的步驟詳解
  • 使用redis實現延遲通知功能(Redis過期鍵通知)

標簽:果洛 北京 江蘇 大慶 臺州 楊凌 吉安 朝陽

巨人網絡通訊聲明:本文標題《redis鍵空間通知使用實現》,本文關鍵詞  redis,鍵,空間,通知,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《redis鍵空間通知使用實現》相關的同類信息!
  • 本頁收集關于redis鍵空間通知使用實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 91精品国产综合久久久夜色撩人| 极品粉嫩軳600张美女图片| 精产国品一二三产品区别视频手机| 午夜欧美大片视频| 激情偷乱在线观看视频播放| 免费看一级黄色录像| 无码国产精品一区二区| 豪妇荡乳1一5潘金莲| 欧美乱肉狂野一级A片| 被触手强制扒开侵犯动漫女性| 日本乱中文字幕系列| 男女一进一出猛进式抽搐视频| 久久久精品3d动漫一区二区三区| 国产精品一区二区在线观看迅雷下载 | 在线免费看黄的网站| 欧美不卡网| 国产精成人品| 扒开末成年粉嫩的小缝视频| 午夜传情三级在线观看| 漂亮的人妻佐佐木希的登录方式| 美女隐私黄www| 是不是想要了我这就给你| 久久精品亚洲AV无码一区二区| 182久久大肚婆无码免费| 日产国产精品久久久久久| 国产十八禁在线观看十八禁宿舍| 粗大白浆h| 嗯哦哦啊灬用力哦啊快点| 白丝老师让我?了一夜动漫| 办公室震动揉弄求求你| 啊…别了小黄文| 极品吹潮视频大喷潮tv| 狠狠躁夜夜躁人爽碰88A| 免费A毛片视频播放网站| 男人桶女人30分钟末满18 在线观看 | 韩国巜干柴烈火〉床戏| chinese耄耋老太交| 国产盗撮XXXX精品XXXX| 色淫小说有声网站ww| 隐士把卢卡肚子撑满| 精品无码久久久久S888AV|