Redis Key過(guò)期監(jiān)聽(tīng)的配置詳解
默認(rèn)情況下在Windows系統(tǒng)中雙擊redis-server.exe用的是內(nèi)置的配置文件
如果希望用這兩個(gè)配置文件

- redis.windows.conf:這是用于在Windows上運(yùn)行Redis服務(wù)器的標(biāo)準(zhǔn)配置文件??梢允褂眠@個(gè)文件通過(guò)命令行啟動(dòng)Redis服務(wù)器。
- redis.windows-service.conf:這是專門為在Windows服務(wù)中運(yùn)行Redis設(shè)計(jì)的配置文件??梢允褂眠@個(gè)文件將Redis作為Windows服務(wù)來(lái)運(yùn)行。

Window安裝Redis為服務(wù)并設(shè)置開(kāi)機(jī)自啟
在redis安裝目錄下管理員運(yùn)行cmd
redis-server --service-install redis.windows.conf --service-name redis
net start redis //開(kāi)機(jī)自啟
修改redis的配置文件

@Configuration
public class RedisConfig2 {
@Bean
RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory,
MessageListenerAdapter listenerAdapter) {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
// 訂閱鍵過(guò)期事件
container.addMessageListener(listenerAdapter, new ChannelTopic("__keyevent@0__:expired"));
return container;
}
@Bean
MessageListenerAdapter listenerAdapter(RedisKeyExpiredListener listener) {
return new MessageListenerAdapter(listener);
}
}@Component
public class RedisKeyExpiredListener implements MessageListener {
@Autowired
private ITReportTimesService tReportTimesService;
@Override
public void onMessage(Message message, byte[] pattern) {
String expiredKey = message.toString();
if (expiredKey.startsWith("sleep:decibels:")) {//只處理該key過(guò)期刪除時(shí)間
Long userId = Long.valueOf(expiredKey.split(":")[2]);
// 處理非正常關(guān)機(jī)導(dǎo)致的睡眠結(jié)束邏輯
handleUnexpectedShutdown(userId);
}
}
private void handleUnexpectedShutdown(Long userId) {
// 處理睡眠監(jiān)測(cè)結(jié)束邏輯,例如記錄結(jié)束時(shí)間
System.out.println("監(jiān)測(cè)到了@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@");
//要處理的邏輯.......
}
} @Autowired
private RedisTemplate redisTemplate;
@GetMapping("/sleepTimes")//監(jiān)測(cè)時(shí)候每多少分鐘調(diào)用一次
public AjaxResult sleepTimes(){
LoginUser loginUser = getLoginUser();
Long userId = loginUser.getUserId();
// 往redis中記錄,延時(shí)30秒,通過(guò)Redis key過(guò)期監(jiān)聽(tīng)判斷用戶是否非正常關(guān)機(jī)
String redisKey = "sleep:decibels:" + userId;
//第一次會(huì)創(chuàng)建key和value 第二次調(diào)用會(huì)更新(覆蓋相同key)key和value
redisTemplate.opsForValue().set(redisKey, "I am active", 60, TimeUnit.SECONDS);
System.out.println("sleepTimes");
return success();
}到此這篇關(guān)于Redis Key過(guò)期監(jiān)聽(tīng)的配置詳解的文章就介紹到這了,更多相關(guān)Redis Key過(guò)期監(jiān)聽(tīng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何利用Redis?List實(shí)現(xiàn)Java數(shù)據(jù)庫(kù)分頁(yè)快速查詢
這篇文章主要給大家介紹了關(guān)于如何利用Redis?List實(shí)現(xiàn)Java數(shù)據(jù)庫(kù)分頁(yè)快速查詢的相關(guān)資料,Redis是一個(gè)高效的內(nèi)存數(shù)據(jù)庫(kù),它支持包括String、List、Set、SortedSet和Hash等數(shù)據(jù)類型的存儲(chǔ),需要的朋友可以參考下2024-02-02
面試分析分布式架構(gòu)Redis熱點(diǎn)key大Value解決方案
這篇文章主要為大家介紹了分布式架構(gòu)Redis熱點(diǎn)key大Value解決方案,以及在面試中如果遇到這類問(wèn)題的分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03
Redis數(shù)據(jù)庫(kù)分布式設(shè)計(jì)方案介紹
大家好,本篇文章主要講的是Redis數(shù)據(jù)庫(kù)分布式設(shè)計(jì)方案介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
從MySQL到Redis的簡(jiǎn)單數(shù)據(jù)庫(kù)遷移方法
這篇文章主要介紹了從MySQL到Redis的簡(jiǎn)單數(shù)據(jù)庫(kù)遷移方法,注意Redis數(shù)據(jù)庫(kù)基于內(nèi)存,并不能代替?zhèn)鹘y(tǒng)數(shù)據(jù)庫(kù),需要的朋友可以參考下2015-06-06
Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過(guò)程解析
大家都知道Redis支持五種數(shù)據(jù)類型:string(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合),本文重點(diǎn)給大家介紹Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過(guò)程,需要的朋友參考下吧2021-12-12
?Redis?實(shí)現(xiàn)計(jì)數(shù)器和限速器的示例代碼
本文主要介紹了?Redis?實(shí)現(xiàn)計(jì)數(shù)器和限速器的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-02-02
shell腳本批量導(dǎo)出redis key-value方式
為避免keys全量掃描導(dǎo)致Redis卡頓,可先通過(guò)dump.rdb備份文件在本地恢復(fù),再使用scan命令漸進(jìn)導(dǎo)出key-value,通過(guò)CNT和INTERVAL參數(shù)控制負(fù)載,且scan不指定游標(biāo)可減少阻塞2025-08-08

