国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
一 、功能概覽
二、事件類型
三、配置
三、案例
代碼
新增和修改都是set指令
刪除
過期
首頁 數(shù)據(jù)庫 Redis SpringBoot怎么監(jiān)聽redis?Key變化事件

SpringBoot怎么監(jiān)聽redis?Key變化事件

May 26, 2023 pm 01:55 PM
redis springboot key

一 、功能概覽

鍵空間通知使得客戶端可以通過訂閱頻道或模式, 來接收那些以某種方式改動(dòng)了 Redis key變化的事件。

所有修改key鍵的命令。

所有接收到 LPUSH key value [value …] 命令的鍵。

db數(shù)據(jù)庫中所有已過期的鍵。

事件通過 Redis 的訂閱與發(fā)布功能(pub/sub)來進(jìn)行分發(fā), 因此所有支持訂閱與發(fā)布功能的客戶端都可以在無須做任何修改的情況下, 直接使用鍵空間通知功能。

因?yàn)?Redis 目前的訂閱與發(fā)布功能采取的是發(fā)送即忘(fire and forget)策略, 所以如果你的程序需要可靠事件通知(reliable notification of events), 那么目前的鍵空間通知可能并不適合你: 當(dāng)訂閱事件的客戶端斷線時(shí), 它會(huì)丟失所有在斷線期間分發(fā)給它的事件。

未來將會(huì)支持更可靠的事件分發(fā), 這種支持可能會(huì)通過讓訂閱與發(fā)布功能本身變得更可靠來實(shí)現(xiàn), 也可能會(huì)在 Lua 腳本中對(duì)消息(message)的訂閱與發(fā)布進(jìn)行監(jiān)聽, 從而實(shí)現(xiàn)類似將事件推入到列表這樣的操作。

二、事件類型

對(duì)于每個(gè)修改數(shù)據(jù)庫的操作,鍵空間通知都會(huì)發(fā)送兩種不同類型的事件。

比如說,對(duì)?0?號(hào)數(shù)據(jù)庫的鍵?mykey?執(zhí)行?DEL key [key …]命令時(shí), 系統(tǒng)將分發(fā)兩條消息, 相當(dāng)于執(zhí)行以下兩個(gè)?PUBLISH channel message?命令:

PUBLISH __keyspace@0__:mykey del
PUBLISH __keyevent@0__:del mykey

訂閱第一個(gè)頻道 __keyspace@0__:mykey 可以接收 0 號(hào)數(shù)據(jù)庫中所有修改鍵 mykey 的事件, 而訂閱第二個(gè)頻道 __keyevent@0__:del則可以接收 0 號(hào)數(shù)據(jù)庫中所有執(zhí)行 del 命令的鍵。

以 keyspace 為前綴的頻道被稱為鍵空間通知(key-space notification), 而以 keyevent 為前綴的頻道則被稱為鍵事件通知(key-event notification)。

當(dāng) del mykey 命令執(zhí)行時(shí):

  • 鍵空間頻道的訂閱者將接收到被執(zhí)行的事件的名字,在這個(gè)例子中,就是 del 。

  • 鍵事件頻道的訂閱者將接收到被執(zhí)行事件的鍵的名字,在這個(gè)例子中,就是 mykey 。

三、配置

因?yàn)殚_啟鍵空間通知功能需要消耗一些 CPU , 所以在默認(rèn)配置下, 該功能處于關(guān)閉狀態(tài)。

可以通過修改 redis.conf 文件, 或者直接使用 CONFIG SET 命令來開啟或關(guān)閉鍵空間通知功能:

當(dāng) notify-keyspace-events 選項(xiàng)的參數(shù)為空字符串時(shí),功能關(guān)閉。

另一方面,當(dāng)參數(shù)不是空字符串時(shí),功能開啟。

notify-keyspace-events 的參數(shù)可以是以下字符的任意組合, 它指定了服務(wù)器該發(fā)送哪些類型的通知:

SpringBoot怎么監(jiān)聽redis?Key變化事件

輸入的參數(shù)中至少要有一個(gè) K或者 E , 否則的話, 不管其余的參數(shù)是什么, 都不會(huì)有任何通知被分發(fā)。

舉個(gè)例子, 如果只想訂閱鍵空間中和列表相關(guān)的通知, 那么參數(shù)就應(yīng)該設(shè)為 Kl , 諸如此類。

將參數(shù)設(shè)為字符串"AKE" 表示發(fā)送所有類型的通知。

每當(dāng)一個(gè)鍵因?yàn)檫^期而被刪除時(shí),產(chǎn)生一個(gè) expired 通知。

每當(dāng)一個(gè)鍵因?yàn)?code>maxmemory政策而被刪除以回收內(nèi)存時(shí),產(chǎn)生一個(gè) evicted 通知。

所有命令都只在鍵真的被改動(dòng)了之后,才會(huì)產(chǎn)生通知。

比如說,當(dāng) SREM key member [member …]試圖刪除不存在于集合的元素時(shí),刪除操作會(huì)執(zhí)行失敗,因?yàn)闆]有真正的改動(dòng)鍵,所以這一操作不會(huì)發(fā)送通知。

如果對(duì)命令所產(chǎn)生的通知有疑問, 最好還是使用以下命令, 自己來驗(yàn)證一下:

Redis 使用以下兩種方式刪除過期的鍵:

當(dāng)一個(gè)鍵被訪問時(shí),程序會(huì)對(duì)這個(gè)鍵進(jìn)行檢查,如果鍵已經(jīng)過期,那么該鍵將被刪除。

底層系統(tǒng)會(huì)在后臺(tái)漸進(jìn)地查找并刪除那些過期的鍵,從而處理那些已經(jīng)過期、但是不會(huì)被訪問到的鍵。
當(dāng)過期鍵被以上兩個(gè)程序的任意一個(gè)發(fā)現(xiàn)、 并且將鍵從數(shù)據(jù)庫中刪除時(shí), Redis 會(huì)產(chǎn)生一個(gè) expired 通知。

Redis 并不保證生存時(shí)間(TTL)變?yōu)?0 的鍵會(huì)立即被刪除: 如果程序沒有訪問這個(gè)過期鍵, 或者帶有生存時(shí)間的鍵非常多的話, 那么在鍵的生存時(shí)間變?yōu)?0 , 直到鍵真正被刪除這中間, 可能會(huì)有一段比較顯著的時(shí)間間隔。

因此, Redis 產(chǎn)生expired通知的時(shí)間為過期鍵被刪除的時(shí)候, 而不是鍵的生存時(shí)間變?yōu)?0 的時(shí)候。

三、案例

按上文內(nèi)容,我們先將redis的鍵空間通知開啟,我們開啟所有的通知,在可以端中測(cè)試后沒問題再到代碼中測(cè)試。

連接到redis 輸入一下命令

SpringBoot怎么監(jiān)聽redis?Key變化事件

config set notify-keyspace-events KEA

訂閱鍵空間和鍵事件的主題

SpringBoot怎么監(jiān)聽redis?Key變化事件

psubscribe '__key*__:*'#對(duì)所有庫鍵空間通知
 
psubscribe '__keyspace@2__:*' #是對(duì)db2數(shù)據(jù)庫鍵空間通知
 
psubscribe '__keyspace@2__:order*' #是對(duì)db2數(shù)據(jù)庫,key前綴為order所有鍵的鍵空間通知

創(chuàng)建一個(gè) key :name valus:zhangsan

set name wsl

觀察訂閱的窗口 會(huì)受到兩個(gè)消息,第一個(gè)是:鍵空間 第二個(gè)是鍵事件,鍵空間是內(nèi)容是操作指令,主題中包含有key,鍵事件主題中包含了指令,內(nèi)容是key。

SpringBoot怎么監(jiān)聽redis?Key變化事件

到這里說明已經(jīng)開啟了鍵空間通知

代碼

以下代碼采用string類型演示

在配置一下MessageListenerContainer類,將我們寫好的監(jiān)聽類添加到該類中即可,刪除和過期都是需要添加,我這里就一起添加了后面就不做演示。

@Configuration
public class RedisConfig {
 
    @Autowired
    private RedisTemplate redisTemplate;
 
    @Autowired
    private RedisUpdateAndAddListener redisUpdateAndAddListener;
 
    @Autowired
    private RedisDeleteListener redisDeleteListener;
 
    @Autowired
    private RedisExpiredListener redisExpiredListener;
 
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
        //監(jiān)聽所有的key的set事件
        container.addMessageListener(redisUpdateAndAddListener, redisUpdateAndAddListener.getTopic());
        //監(jiān)聽所有key的刪除事件
        container.addMessageListener(redisDeleteListener,redisDeleteListener.getTopic());
        //監(jiān)聽所有key的過期事件
        container.addMessageListener(redisExpiredListener,redisExpiredListener.getTopic());
        return container;
    }
 
 
}

新增和修改都是set指令

所以監(jiān)聽的主題都一樣,實(shí)現(xiàn)MessageListener接口,重寫onMessage這里就是收到消息的處理邏輯

@Component
@Data
public class RedisUpdateAndAddListener implements MessageListener {
	//監(jiān)聽的主題
    private  final PatternTopic topic = new PatternTopic("__keyevent@*__:set");
 
    @Override
    public void onMessage(Message message,byte[] pattern){
        String topic = new String(pattern);
        String msg = new String(message.getBody());
        System.out.println("收到key更新或修改,消息主題是:"+ topic+",消息內(nèi)容是:"+msg);
    }
 
}

在redis中對(duì)name這個(gè)key進(jìn)行set操作

set name wsl

在控制臺(tái)就可以看到name這個(gè)key被操作了

SpringBoot怎么監(jiān)聽redis?Key變化事件

刪除

跟上面的更新監(jiān)聽一樣,只需要把訂閱主題更改一下即可。同樣需要添加到這個(gè)RedisMessageListenerContainer,上面已經(jīng)添加,這里不做演示

@Component
@Data
public class RedisDeleteListener implements MessageListener {
 
    //監(jiān)聽主題
    private  final PatternTopic topic = new PatternTopic("__keyevent@*__:del");
 
    /**
     *
     * @param message 消息
     * @param pattern 主題
     */
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String topic = new String(pattern);
        String msg = new String(message.getBody());
        System.out.println("收到key的刪除,消息主題是:"+ topic+",消息內(nèi)容是:"+msg);
    }
}

在redis輸入命令,del name 在控制臺(tái)可以看到已經(jīng)收到消息了。

SpringBoot怎么監(jiān)聽redis?Key變化事件

過期

如上面的操作方式一樣

@Data
@Component
public class RedisExpiredListener implements MessageListener {
 
    //監(jiān)聽主題
    private  final PatternTopic topic = new PatternTopic("__keyevent@*__:expired");
 
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String topic = new String(pattern);
        String msg = new String(message.getBody());
        System.out.println("收到key的過期,消息主題是:"+ topic+",消息內(nèi)容是:"+msg);
    }
}

?在redis中寫一個(gè)定時(shí)刪除的keySETEX age 18 3三秒后就可以控制臺(tái)打印了相關(guān)信息

SpringBoot怎么監(jiān)聽redis?Key變化事件

以上是SpringBoot怎么監(jiān)聽redis?Key變化事件的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門話題

Laravel 教程
1601
29
PHP教程
1502
276
Laravel 最佳擴(kuò)展包推薦:2024 年必備工具 Laravel 最佳擴(kuò)展包推薦:2024 年必備工具 Apr 30, 2025 pm 02:18 PM

2024年必備的Laravel擴(kuò)展包包括:1.LaravelDebugbar,用于監(jiān)控和調(diào)試代碼;2.LaravelTelescope,提供詳細(xì)的應(yīng)用監(jiān)控;3.LaravelHorizon,管理Redis隊(duì)列任務(wù)。這些擴(kuò)展包能提升開發(fā)效率和應(yīng)用性能。

Laravel 環(huán)境搭建與基礎(chǔ)配置(Windows/Mac/Linux) Laravel 環(huán)境搭建與基礎(chǔ)配置(Windows/Mac/Linux) Apr 30, 2025 pm 02:27 PM

在不同操作系統(tǒng)上搭建Laravel環(huán)境的步驟如下:1.Windows:使用XAMPP安裝PHP和Composer,配置環(huán)境變量,安裝Laravel。2.Mac:使用Homebrew安裝PHP和Composer,安裝Laravel。3.Linux:使用Ubuntu更新系統(tǒng),安裝PHP和Composer,安裝Laravel。每個(gè)系統(tǒng)的具體命令和路徑有所不同,但核心步驟一致,確保順利搭建Laravel開發(fā)環(huán)境。

REDIS:與傳統(tǒng)數(shù)據(jù)庫服務(wù)器的比較 REDIS:與傳統(tǒng)數(shù)據(jù)庫服務(wù)器的比較 May 07, 2025 am 12:09 AM

Redis在高并發(fā)和低延遲場(chǎng)景下優(yōu)于傳統(tǒng)數(shù)據(jù)庫,但不適合復(fù)雜查詢和事務(wù)處理。1.Redis使用內(nèi)存存儲(chǔ),讀寫速度快,適合高并發(fā)和低延遲需求。2.傳統(tǒng)數(shù)據(jù)庫基于磁盤,支持復(fù)雜查詢和事務(wù)處理,數(shù)據(jù)一致性和持久性強(qiáng)。3.Redis適用于作為傳統(tǒng)數(shù)據(jù)庫的補(bǔ)充或替代,但需根據(jù)具體業(yè)務(wù)需求選擇。

linux如何限制用戶資源?ulimit怎么配置? linux如何限制用戶資源?ulimit怎么配置? May 29, 2025 pm 11:09 PM

Linux系統(tǒng)通過ulimit命令限制用戶資源,防止資源過度占用。1.ulimit是shell內(nèi)置命令,可限制文件描述符數(shù)(-n)、內(nèi)存大?。?v)、線程數(shù)(-u)等,分為軟限制(當(dāng)前生效值)和硬限制(最高上限)。2.臨時(shí)修改直接使用ulimit命令,如ulimit-n2048,但僅對(duì)當(dāng)前會(huì)話有效。3.永久生效需修改/etc/security/limits.conf及PAM配置文件,并添加sessionrequiredpam_limits.so。4.systemd服務(wù)需在unit文件中設(shè)置Lim

Redis主要是數(shù)據(jù)庫嗎? Redis主要是數(shù)據(jù)庫嗎? May 05, 2025 am 12:07 AM

Redis主要是一個(gè)數(shù)據(jù)庫,但它不僅僅是數(shù)據(jù)庫。1.作為數(shù)據(jù)庫,Redis支持持久化,適合高性能需求。2.作為緩存,Redis提升應(yīng)用響應(yīng)速度。3.作為消息代理,Redis支持發(fā)布-訂閱模式,適用于實(shí)時(shí)通信。

REDIS:超越SQL- NOSQL的觀點(diǎn) REDIS:超越SQL- NOSQL的觀點(diǎn) May 08, 2025 am 12:25 AM

Redis超越SQL數(shù)據(jù)庫的原因在于其高性能和靈活性。1)Redis通過內(nèi)存存儲(chǔ)實(shí)現(xiàn)極快的讀寫速度。2)它支持多種數(shù)據(jù)結(jié)構(gòu),如列表和集合,適用于復(fù)雜數(shù)據(jù)處理。3)單線程模型簡化開發(fā),但高并發(fā)時(shí)可能成瓶頸。

用PhpStudy搭建動(dòng)態(tài)PHP網(wǎng)站的步驟與示例 用PhpStudy搭建動(dòng)態(tài)PHP網(wǎng)站的步驟與示例 May 16, 2025 pm 07:54 PM

使用PhpStudy搭建動(dòng)態(tài)PHP網(wǎng)站的步驟包括:1.安裝PhpStudy并啟動(dòng)服務(wù);2.配置網(wǎng)站根目錄和數(shù)據(jù)庫連接;3.編寫PHP腳本生成動(dòng)態(tài)內(nèi)容;4.調(diào)試和優(yōu)化網(wǎng)站性能。通過這些步驟,你可以從零開始搭建一個(gè)功能完整的動(dòng)態(tài)PHP網(wǎng)站。

REDIS:揭示其目的和關(guān)鍵應(yīng)用程序 REDIS:揭示其目的和關(guān)鍵應(yīng)用程序 May 03, 2025 am 12:11 AM

Redisisanopen-Source,內(nèi)存內(nèi)部的庫雷斯塔氏菌,卡赫和梅斯吉級(jí),excellingInsPeedAndVersatory.itiswidelysusedforcaching,Real-Timeanalytics,Session Management,Session Managements,and sessighterboarderboarderboardobboardotoitsssupportfortfortfortfortfortfortfortfortorvortfortfortfortfortfortforvortfortforvortforvortforvortfortforvortforvortforvortforvortdatastherctuct anddatataCcessandcessanddataaCces

See all articles