色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何用Redis實現(xiàn)延遲隊列呢?

jf_ro2CN3Fa ? 來源:三友的java日記 ? 2023-03-16 14:28 ? 次閱讀

背景

前段時間有個小項目需要使用延遲任務(wù),談到延遲任務(wù),我腦子第一時間一閃而過的就是使用消息隊列來做,比如RabbitMQ的死信隊列又或者RocketMQ的延遲隊列,但是奈何這是一個小項目,并沒有引入MQ,我也不太想因為一個延遲任務(wù)就引入MQ,增加系統(tǒng)復(fù)雜度,所以這個方案直接就被pass了。

雖然基于MQ這個方式走不通了,但是這個項目中使用到Redis,所以我就想是否能夠使用Redis來代替MQ實現(xiàn)延遲隊列的功能,于是我就查了一下有沒有現(xiàn)成可用的方案,別說,還真給我查到了兩種方案,并且我還仔細(xì)研究對比了這兩個方案,發(fā)現(xiàn)要想很好的實現(xiàn)延遲隊列,并不簡單。

監(jiān)聽過期key

基于監(jiān)聽過期key的方式來實現(xiàn)延遲隊列是我查到的第一個方案,為了弄懂這個方案實現(xiàn)的細(xì)節(jié),我還特地去扒了扒官網(wǎng),還真有所收獲

1、Redis發(fā)布訂閱模式

一談到發(fā)布訂閱模式,其實一想到的就是MQ,只不過Redis也實現(xiàn)了一套,并且跟MQ賊像,如圖:

f3e30a0a-c3b1-11ed-bfe3-dac502259ad0.png

圖中的channel的概念跟MQ中的topic的概念差不多,你可以把channel理解成MQ中的topic。

生產(chǎn)者在消息發(fā)送時需要到指定發(fā)送到哪個channel上,消費者訂閱這個channel就能獲取到消息。

2、keyspace notifications

在Redis中,有很多默認(rèn)的channel,只不過向這些channel發(fā)送消息的生產(chǎn)者不是我們寫的代碼,而是Redis本身。當(dāng)消費者監(jiān)聽這些channel時,就可以感知到Redis中數(shù)據(jù)的變化。

這個功能Redis官方稱為keyspace notifications,字面意思就是鍵空間通知。

這些默認(rèn)的channel被分為兩類:

以__keyspace@__:為前綴,后面跟的是key的名稱,表示監(jiān)聽跟這個key有關(guān)的事件。

舉個例子,現(xiàn)在有個消費者監(jiān)聽了__keyspace@0__:sanyou這個channel,sanyou就是Redis中的一個普通key,那么當(dāng)sanyou這個key被刪除或者發(fā)生了其它事件,那么消費者就會收到sanyou這個key刪除或者其它事件的消息

以__keyevent@__:為前綴,后面跟的是消息事件類型,表示監(jiān)聽某個事件

同樣舉個例子,現(xiàn)在有個消費者監(jiān)聽了__keyevent@0__:expired這個channel,代表了監(jiān)聽key的過期事件。那么當(dāng)某個Redis的key過期了(expired),那么消費者就能收到這個key過期的消息。如果把expired換成del,那么監(jiān)聽的就是刪除事件。具體支持哪些事件,可從官網(wǎng)查。

上述db是指具體的數(shù)據(jù)庫,Redis不是默認(rèn)分為16個庫么,序號從0-15,所以db就是0到15的數(shù)字,示例中的0就是指0對應(yīng)的數(shù)據(jù)庫。

f3fa3f36-c3b1-11ed-bfe3-dac502259ad0.png

3、延遲隊列實現(xiàn)原理

通過對上面的兩個概念了解之后,應(yīng)該就對監(jiān)聽過期key的實現(xiàn)原理一目了然了,其實就是當(dāng)這個key過期之后,Redis會發(fā)布一個key過期的事件到__keyevent@__:expired這個channel,只要我們的服務(wù)監(jiān)聽這個channel,那么就能知道過期的Key,從而就算實現(xiàn)了延遲隊列功能。

所以這種方式實現(xiàn)延遲隊列就只需要兩步:

發(fā)送延遲任務(wù),key是延遲消息本身,過期時間就是延遲時間

監(jiān)聽__keyevent@__:expired這個channel,處理延遲任務(wù)

4、demo

好了,基本概念和核心原理都說完了之后,又到了show me the code環(huán)節(jié)。

好巧不巧,Spring已經(jīng)實現(xiàn)了監(jiān)聽__keyevent@*__:expired這個channel這個功能,__keyevent@*__:expired中的*代表通配符的意思,監(jiān)聽所有的數(shù)據(jù)庫。

所以demo寫起來就很簡單了,只需3步即可

引入pom


org.springframework.boot
spring-boot-starter-data-redis
2.2.5.RELEASE



org.springframework.boot
spring-boot-starter-web
2.2.5.RELEASE

配置類

@Configuration
publicclassRedisConfiguration{

@Bean
publicRedisMessageListenerContainerredisMessageListenerContainer(RedisConnectionFactoryconnectionFactory){
RedisMessageListenerContainerredisMessageListenerContainer=newRedisMessageListenerContainer();
redisMessageListenerContainer.setConnectionFactory(connectionFactory);
returnredisMessageListenerContainer;
}

@Bean
publicKeyExpirationEventMessageListenerredisKeyExpirationListener(RedisMessageListenerContainerredisMessageListenerContainer){
returnnewKeyExpirationEventMessageListener(redisMessageListenerContainer);
}

}

KeyExpirationEventMessageListener實現(xiàn)了對__keyevent@*__:expiredchannel的監(jiān)聽

f4060884-c3b1-11ed-bfe3-dac502259ad0.png

當(dāng)KeyExpirationEventMessageListener收到Redis發(fā)布的過期Key的消息的時候,會發(fā)布RedisKeyExpiredEvent事件

f4560ff0-c3b1-11ed-bfe3-dac502259ad0.png

所以我們只需要監(jiān)聽RedisKeyExpiredEvent事件就可以拿到過期消息的Key,也就是延遲消息。

對RedisKeyExpiredEvent事件的監(jiān)聽實現(xiàn)MyRedisKeyExpiredEventListener

@Component
publicclassMyRedisKeyExpiredEventListenerimplementsApplicationListener{

@Override
publicvoidonApplicationEvent(RedisKeyExpiredEventevent){
byte[]body=event.getSource();
System.out.println("獲取到延遲消息:"+newString(body));
}

}

整個工程目錄也簡單

f4a5f2f4-c3b1-11ed-bfe3-dac502259ad0.png

代碼寫好,啟動應(yīng)用

之后我直接通過Redis命令設(shè)置消息,就沒通過代碼發(fā)送消息了,消息的key為sanyou,值為task,值不重要,過期時間為5s

setsanyoutask

expiresanyou5

如果上面都理論都正確,不出意外的話,5s后MyRedisKeyExpiredEventListener應(yīng)該可以監(jiān)聽到sanyou這個key過期的消息,也就相當(dāng)于拿到了延遲任務(wù),控制臺會打印出獲取到延遲消息:sanyou。

于是我滿懷希望,靜靜地等待了5s。。

5、4、3、2、1,時間一到,我查看控制臺,但是控制臺并沒有按照預(yù)期打印出上面那句話。

為什么會沒打印出?難道是代碼寫錯了?正當(dāng)我準(zhǔn)備檢查代碼的時候,官網(wǎng)的一段話道出了真實原因。

f4dd25ee-c3b1-11ed-bfe3-dac502259ad0.png

我給大家翻譯一下上面這段話講的內(nèi)容。

上面這段話主要討論的是key過期事件的時效性問題,首先提到了Redis過期key的兩種清除策略,就是面試八股文常背的兩種:

惰性清除。當(dāng)這個key過期之后,訪問時,這個Key才會被清除

定時清除。后臺會定期檢查一部分key,如果有key過期了,就會被清除

再后面那段話是核心,意思是說,key的過期事件發(fā)布時機(jī)并不是當(dāng)這個key的過期時間到了之后就發(fā)布,而是這個key在Redis中被清理之后,也就是真正被刪除之后才會發(fā)布。

到這我終于明白了,上面的例子中即使我設(shè)置了5s的過期時間,但是當(dāng)5s過去之后,只要兩種清除策略都不滿足,沒人訪問sanyou這個key,后臺的定時清理的任務(wù)也沒掃描到sanyou這個key,那么就不會發(fā)布key過期的事件,自然而然也就監(jiān)聽不到了。

至于后臺的定時清理的任務(wù)什么時候能掃到,這個沒有固定時間,可能一到過期時間就被掃到,也可能等一定時間才會被掃到,這就可能會造成了客戶端從發(fā)布到監(jiān)聽到的消息時間差會大于等于過期時間,從而造成一定時間消息的延遲,這就著實有點坑了。。

5、坑

除了上面測試demo的時候遇到的坑之外,在我深入研究之后,還發(fā)現(xiàn)了一些更離譜的坑。

丟消息太頻繁

Redis的丟消息跟MQ不一樣,因為MQ都會有消息的持久化機(jī)制,可能只有當(dāng)機(jī)器宕機(jī)了,才會丟點消息,但是Redis丟消息就很離譜,比如說你的服務(wù)在重啟的時候就消息會丟消息。

Redis實現(xiàn)的發(fā)布訂閱模式,消息是沒有持久化機(jī)制,當(dāng)消息發(fā)布到某個channel之后,如果沒有客戶端訂閱這個channel,那么這個消息就丟了,并不會像MQ一樣進(jìn)行持久化,等有消費者訂閱的時候再給消費者消費。

所以說,假設(shè)服務(wù)重啟期間,某個生產(chǎn)者或者是Redis本身發(fā)布了一條消息到某個channel,由于服務(wù)重啟,沒有監(jiān)聽這個channel,那么這個消息自然就丟了。

消息消費只有廣播模式

Redis的發(fā)布訂閱模式消息消費只有廣播模式一種。

所謂的廣播模式就是多個消費者訂閱同一個channel,那么每個消費者都能消費到發(fā)布到這個channel的所有消息。

f500e1e6-c3b1-11ed-bfe3-dac502259ad0.png

如圖,生產(chǎn)者發(fā)布了一條消息,內(nèi)容為sanyou,那么兩個消費者都可以同時收到sanyou這條消息。

所以,如果通過監(jiān)聽channel來獲取延遲任務(wù),那么一旦服務(wù)實例有多個的話,還得保證消息不能重復(fù)處理,額外地增加了代碼開發(fā)量。

接收到所有key的某個事件

這個不屬于Redis發(fā)布訂閱模式的問題,而是Redis本身事件通知的問題。

當(dāng)消費者監(jiān)聽了以__keyevent@__:開頭的消息,那么會導(dǎo)致所有的key發(fā)生了事件都會被通知給消費者。

舉個例子,某個消費者監(jiān)聽了__keyevent@*__:expired這個channel,那么只要key過期了,不管這個key是張三還會李四,消費者都能收到。

所以如果你只想消費某一類消息的key,那么還得自行加一些標(biāo)記,比如消息的key加個前綴,消費的時候判斷一下帶前綴的key就是需要消費的任務(wù)。

所以,綜上能夠得出一個非常重要的結(jié)論,那就是監(jiān)聽Redis過期Key這種方式實現(xiàn)延遲隊列,不穩(wěn)定,坑賊多!

那有沒有比較靠譜的延遲隊列的實現(xiàn)方案呢?這就不得不提到我研究的第二種方案了。

Redisson實現(xiàn)延遲隊列

Redisson他是Redis的兒子(Redis son),基于Redis實現(xiàn)了非常多的功能,其中最常使用的就是Redis分布式鎖的實現(xiàn),但是除了實現(xiàn)Redis分布式鎖之外,它還實現(xiàn)了延遲隊列的功能。

先來個demo,后面再來說說這種實現(xiàn)的原理。

1、demo

引入pom


org.redisson
redisson
3.13.1

封裝了一個RedissonDelayQueue類

@Component
@Slf4j
publicclassRedissonDelayQueue{

privateRedissonClientredissonClient;

privateRDelayedQueuedelayQueue;
privateRBlockingQueueblockingQueue;

@PostConstruct
publicvoidinit(){
initDelayQueue();
startDelayQueueConsumer();
}

privatevoidinitDelayQueue(){
Configconfig=newConfig();
SingleServerConfigserverConfig=config.useSingleServer();
serverConfig.setAddress("redis://localhost:6379");
redissonClient=Redisson.create(config);

blockingQueue=redissonClient.getBlockingQueue("SANYOU");
delayQueue=redissonClient.getDelayedQueue(blockingQueue);
}

privatevoidstartDelayQueueConsumer(){
newThread(()->{
while(true){
try{
Stringtask=blockingQueue.take();
log.info("接收到延遲任務(wù):{}",task);
}catch(Exceptione){
e.printStackTrace();
}
}
},"SANYOU-Consumer").start();
}

publicvoidofferTask(Stringtask,longseconds){
log.info("添加延遲任務(wù):{}延遲時間:{}s",task,seconds);
delayQueue.offer(task,seconds,TimeUnit.SECONDS);
}

}

這個類在創(chuàng)建的時候會去初始化延遲隊列,創(chuàng)建一個RedissonClient對象,之后通過RedissonClient對象獲取到RDelayedQueue和RBlockingQueue對象,傳入的隊列名字叫SANYOU,這個名字無所謂。

當(dāng)延遲隊列創(chuàng)建之后,會開啟一個延遲任務(wù)的消費線程,這個線程會一直從RBlockingQueue中通過take方法阻塞獲取延遲任務(wù)。

添加任務(wù)的時候是通過RDelayedQueue的offer方法添加的。

controller類,通過接口添加任務(wù),延遲時間為5s

@RestController
publicclassRedissonDelayQueueController{

@Resource
privateRedissonDelayQueueredissonDelayQueue;

@GetMapping("/add")
publicvoidaddTask(@RequestParam("task")Stringtask){
redissonDelayQueue.offerTask(task,5);
}

}

啟動項目,添加任務(wù)

靜靜等待5s,成功獲取到任務(wù)。

f510d5e2-c3b1-11ed-bfe3-dac502259ad0.png

2、實現(xiàn)原理

如下圖就是上面demo中,一個延遲隊列會在Redis內(nèi)部使用到的channel和數(shù)據(jù)類型

f51a509a-c3b1-11ed-bfe3-dac502259ad0.png

SANYOU前面的前綴都是固定的,Redisson創(chuàng)建的時候會拼上前綴。

redisson_delay_queue_timeout:SANYOU,sorted set數(shù)據(jù)類型,存放所有延遲任務(wù),按照延遲任務(wù)的到期時間戳(提交任務(wù)時的時間戳 + 延遲時間)來排序的,所以列表的最前面的第一個元素就是整個延遲隊列中最早要被執(zhí)行的任務(wù),這個概念很重要

redisson_delay_queue:SANYOU,list數(shù)據(jù)類型,也是存放所有的任務(wù),但是研究下來發(fā)現(xiàn)好像沒什么用。。

SANYOU,list數(shù)據(jù)類型,被稱為目標(biāo)隊列,這個里面存放的任務(wù)都是已經(jīng)到了延遲時間的,可以被消費者獲取的任務(wù),所以上面demo中的RBlockingQueue的take方法是從這個目標(biāo)隊列中獲取到任務(wù)的

redisson_delay_queue_channel:SANYOU,是一個channel,用來通知客戶端開啟一個延遲任務(wù)

有了這些概念之后,再來看看整體的運行原理圖

f534b340-c3b1-11ed-bfe3-dac502259ad0.png

生產(chǎn)者在提交任務(wù)的時候?qū)⑷蝿?wù)放到redisson_delay_queue_timeout:SANYOU中,分?jǐn)?shù)就是提交任務(wù)的時間戳+延遲時間,就是延遲任務(wù)的到期時間戳

客戶端會有一個延遲任務(wù),為了區(qū)分,后面我都說是客戶端延遲任務(wù)。這個延遲任務(wù)會向Redis Server發(fā)送一段lua腳本,Redis執(zhí)行l(wèi)ua腳本中的命令,并且是原子性的

f5718518-c3b1-11ed-bfe3-dac502259ad0.png

這段lua腳本主要干了兩件事:

將到了延遲時間的任務(wù)從redisson_delay_queue_timeout:SANYOU中移除,存到SANYOU這個目標(biāo)隊列

獲取到redisson_delay_queue_timeout:SANYOU中目前最早到過期時間的延遲任務(wù)的到期時間戳,然后發(fā)布到redisson_delay_queue_channel:SANYOU這個channel中

當(dāng)客戶端監(jiān)聽到redisson_delay_queue_channel:SANYOU這個channel的消息時,會再次提交一個客戶端延遲任務(wù),延遲時間就是消息(最早到過期時間的延遲任務(wù)的到期時間戳)- 當(dāng)前時間戳,這個時間其實也就是redisson_delay_queue_channel:SANYOU中最早到過期時間的任務(wù)還剩余的延遲時間。

此處可以等待10s,好好想想。。

這樣,一旦時間來到了上面說的最早到過期時間任務(wù)的到期時間戳,redisson_delay_queue_timeout:SANYOU中上面說的最早到過期時間的任務(wù)已經(jīng)到期了,客戶端的延遲任務(wù)也同時到期,于是開始執(zhí)行l(wèi)ua腳本操作,及時將到了延遲時間的任務(wù)放到目標(biāo)隊列中。然后再次發(fā)布剩余的延遲任務(wù)中最早到期的任務(wù)到期時間戳到channe中,如此循環(huán)往復(fù),一直運行下去,保證redisson_delay_queue_timeout:SANYOU中到期的數(shù)據(jù)能及時放到目標(biāo)隊列中。

所以,上述說了一大堆的主要的作用就是保證到了延遲時間的任務(wù)能夠及時被放到目標(biāo)隊列。

這里再補(bǔ)充兩個特殊情況,圖中沒有畫出:

第一個就是如果redisson_delay_queue_timeout:SANYOU是新添加的任務(wù)(隊列之前有或者沒有任務(wù))是隊列中最早需要被執(zhí)行的,也會發(fā)布消息到channel,之后就按時上面說的流程走了。

添加任務(wù)代碼如下,也是通過lua腳本來的

f5ad6d94-c3b1-11ed-bfe3-dac502259ad0.png

第二種特殊情況就是項目啟動的時候會執(zhí)行一次客戶端延遲任務(wù)。項目在重啟時,由于沒有客戶端延遲任務(wù)的執(zhí)行,可能會出現(xiàn)redisson_delay_queue_timeout:SANYOU隊列中有到期但是沒有被放到目標(biāo)隊列的可能,重啟就執(zhí)行一次就是為了保證到期的數(shù)據(jù)能被及時放到目標(biāo)隊列中。

3、與第一種方案比較

現(xiàn)在來比較一下第一種方案和Redisson的這種方案,看看有沒有第一種方案的那些坑。

第一個任務(wù)延遲的問題,Redisson方案理論上是沒有延遲的,但是當(dāng)消息數(shù)量增加,消費者消費緩慢這個情況下可能會導(dǎo)致延遲任務(wù)消費的延遲。

第二個丟消息的問題,Redisson方案很大程度上減輕了丟消息的可能性,因為所有的任務(wù)都是存在list和sorted set兩種數(shù)據(jù)類型中,Redis有持久化機(jī)制,就算Redis宕機(jī)了,也就可能會丟一點點數(shù)據(jù)。

第三個廣播消費任務(wù)的問題,這個是不會出現(xiàn)的,因為每個客戶端都是從同一個目標(biāo)隊列中獲取任務(wù)的。

第四個問題是Redis內(nèi)部channel發(fā)布事件的問題,跟這種方案不沾邊,就更不可能存在了。

所以,通過上面的對比可以看出,Redisson這種實現(xiàn)方案就顯得更加的靠譜了。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)庫
    +關(guān)注

    關(guān)注

    7

    文章

    3816

    瀏覽量

    64448
  • lua腳本
    +關(guān)注

    關(guān)注

    0

    文章

    21

    瀏覽量

    7590
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    376

    瀏覽量

    10882

原文標(biāo)題:用 Redis 實現(xiàn)延遲隊列,我研究了兩種方案,發(fā)現(xiàn)并不簡單

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    延遲隊列實現(xiàn)方式

    延遲任務(wù) 最近有一個需求,基于消息隊列對數(shù)據(jù)消費,并根據(jù)多次消費的結(jié)果對數(shù)據(jù)進(jìn)行重新組裝,如果在指定時間內(nèi),需要的數(shù)據(jù)全部到達(dá),則進(jìn)行數(shù)據(jù)組裝以及后續(xù)邏輯。簡單的說,設(shè)置一個超時時間,如果在該時間內(nèi)
    的頭像 發(fā)表于 09-30 11:17 ?819次閱讀

    MySQL與Redis延遲雙刪策略

    中,并且如果數(shù)據(jù)庫中的數(shù)據(jù)發(fā)生了改變則需要同步到redis中,同步過程中需要保證 MySQL與redis數(shù)據(jù)一致性問題,在這個同步過程中出現(xiàn)短暫的數(shù)據(jù)延遲也是正常現(xiàn)象,但是最終需要保證mysql與緩存中的一致性。 //我們通常使
    的頭像 發(fā)表于 09-25 14:28 ?923次閱讀
    MySQL與<b class='flag-5'>Redis</b><b class='flag-5'>延遲</b>雙刪策略

    Redis Stream應(yīng)用案例

    的基本使用介紹和設(shè)計理念可以看我之前的一篇文章(Redis Stream簡介)。Redis Stream本質(zhì)上是在Redis內(nèi)核上(非Redis Module)
    發(fā)表于 06-26 17:15

    FreeRtos中消息隊列API的調(diào)用該怎樣去實現(xiàn)

    消息隊列是什么?消息隊列有何作用?FreeRtos中消息隊列API的調(diào)用該怎樣去實現(xiàn)
    發(fā)表于 01-20 07:04

    如何去實現(xiàn)一種隊列程序的設(shè)計

    隊列的原理是什么?隊列有何作用?如何去實現(xiàn)一種隊列程序的設(shè)計
    發(fā)表于 02-25 07:50

    環(huán)形隊列的操作如何去實現(xiàn)

    環(huán)形隊列結(jié)構(gòu)的定義是什么?環(huán)形隊列的操作如何去實現(xiàn)
    發(fā)表于 02-25 06:35

    redis工作原理

    Redis作為內(nèi)存數(shù)據(jù)庫,擁有非常高的性能,單個實例的QPS能夠達(dá)到10W左右。但我們在使用Redis時,經(jīng)常時不時會出現(xiàn)訪問延遲很大的情況,如果你不知道Redis的內(nèi)部
    的頭像 發(fā)表于 09-24 15:57 ?3567次閱讀

    Redis 延時隊列,一次性搞明白

    所謂延時隊列就是延時的消息隊列,下面說一下一些業(yè)務(wù)場景 實踐場景 訂單支付失敗,每隔一段時間提醒用戶 用戶并發(fā)量的情況,可以延時2分鐘給用戶發(fā)短信 先來看看Redis實現(xiàn)普通的消息
    的頭像 發(fā)表于 10-30 16:34 ?2154次閱讀
    <b class='flag-5'>Redis</b> 延時<b class='flag-5'>隊列</b>,一次性搞明白

    Springboot+redis操作多種實現(xiàn)

    操作。Jedis客戶端實例不是線程安全的,需要通過連接池來使用Jedis。 1.2、Redisson 優(yōu)點點:分布式鎖,分布式集合,可通過Redis支持延遲隊列。 1.3、
    的頭像 發(fā)表于 09-22 10:48 ?1842次閱讀
    Springboot+<b class='flag-5'>redis</b>操作多種<b class='flag-5'>實現(xiàn)</b>

    什么是 Redis

    其他用例中變得可行,包括發(fā)布-訂閱機(jī)制、流(streaming)和隊列。 主要來說,Redis 是一個內(nèi)存數(shù)據(jù)庫,用作另一個“真實”數(shù)據(jù)
    的頭像 發(fā)表于 05-22 15:32 ?1121次閱讀
    什么是 <b class='flag-5'>Redis</b>

    何用Springboot整合Redis

    本篇文件我們來介紹如何用Springboot整合Redis。 1、Docker 安裝 Redis 1.1 下載鏡像 docker pull redis: 6 . 2 . 6 1.2 創(chuàng)
    的頭像 發(fā)表于 10-08 14:56 ?590次閱讀
    如<b class='flag-5'>何用</b>Springboot整合<b class='flag-5'>Redis</b>

    Java redis鎖怎么實現(xiàn)

    在Java中實現(xiàn)Redis鎖涉及到以下幾個方面:Redis的安裝配置、Redis連接池的使用、Redis數(shù)據(jù)結(jié)構(gòu)的選擇、
    的頭像 發(fā)表于 12-04 10:47 ?1173次閱讀

    redis hash底層實現(xiàn)原理

    數(shù)據(jù)結(jié)構(gòu)是如何實現(xiàn)?本文將詳細(xì)介紹Redis哈希底層的實現(xiàn)原理。 在Redis中,每個哈希都是由一個類似于字典(Dictionary)的
    的頭像 發(fā)表于 12-04 16:27 ?588次閱讀

    redis容器內(nèi)怎么查看redis日志

    redis是一款流行的開源內(nèi)存數(shù)據(jù)庫,常用于緩存、消息隊列、任務(wù)管理等場景。在使用redis時,了解如何查看redis日志對于排查問題、監(jiān)控性能和分析應(yīng)用程序行為非常重要。在本文中,我
    的頭像 發(fā)表于 12-05 10:10 ?3684次閱讀

    redis數(shù)據(jù)結(jié)構(gòu)的底層實現(xiàn)

    Redis是一種內(nèi)存鍵值數(shù)據(jù)庫,常用于緩存、消息隊列、實時數(shù)據(jù)分析等場景。它的高性能得益于其精心設(shè)計的數(shù)據(jù)結(jié)構(gòu)和底層實現(xiàn)。本文將詳細(xì)介紹Redis常用的數(shù)據(jù)結(jié)構(gòu)和它們的底層
    的頭像 發(fā)表于 12-05 10:14 ?624次閱讀
    主站蜘蛛池模板: 国产亚洲色婷婷久久精品99 | 久久国产精品免费网站| 亲胸揉胸膜下刺激视频在线观看| 2021国产精品| 男人的天堂黄色片| 动漫女主被扒开双腿羞辱| 四虎影视库永久免费| 好大太快了快插穿子宫了| 在线免费中文字幕| 欧美日韩亚洲一区视频二区 | 国产精品AV无码免费播放| 一区二区三区毛AAAA片特级| 男人J桶进男人屁股过程| 动漫美女3d被爆漫画| 亚洲视频第二页| 琪琪电影午夜理论片77网| 国产午夜视频在永久在线观看| 最近中文字幕2019免费版| 秋霞电影网午夜鲁丝片无码| 国语自产视频在线| CHINESE熟女老女人HD视频| 亚洲AV国产精品无码精| 男男h啪肉np文总受| 国产午夜一级鲁丝片| 91精品国产色综合久久| 无人区乱码区1卡2卡三卡在线| 萝莉御姐被吸奶| 污文乖不疼的| 久久青草免费线观最新| 伊人久久久久久久久香港| 欧美精品AV无码一区二区| 国语自产视频在线| 成人1000部免费观看视频| 亚洲欧美无码2017在线| 日本久久和电影| 看电影就来5566先锋av| 国产精品久久久久久久久久免费 | 国产成人小视频在线观看| 最近免费中文字幕完整版HD| 偷偷要色偷偷| 欧美激情一区二区三区AA片|