久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

spring boot+redis 監(jiān)聽過期Key的操作方法

瀏覽:73日期:2023-08-21 14:06:02

前言:

在訂單業(yè)務(wù)中,有時(shí)候需要對(duì)訂單設(shè)置有效期,有效期到了后如果還未支付,就需要修改訂單狀態(tài)。對(duì)于這種業(yè)務(wù)的實(shí)現(xiàn),有多種不同的辦法,比如:

1、使用querytz,每次生成一個(gè)訂單,就創(chuàng)建一個(gè)定時(shí)任務(wù),到期后執(zhí)行業(yè)務(wù)代碼;

2、rabbitMq中的延遲隊(duì)列;

3、對(duì)Redis的Key進(jìn)行監(jiān)控;

1、引入依賴

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>

2、修改boot的redis配置

spring: #redis redis: database: 0 host: 127.0.0.1 password: redis_123456 port: 6379

3、在服務(wù)器中 修改redis.conf配置文件(原來notify-keyspace-events 屬性是' ' 空的,我們只需要填上“Ex”就行了)

notify-keyspace-events 'Ex'

4、創(chuàng)建一個(gè)Redis監(jiān)控類,用于監(jiān)控過期的key,該類需繼承KeyExpirationEventMessageListener

import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.data.redis.connection.Message;import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;import org.springframework.data.redis.listener.RedisMessageListenerContainer; import java.nio.charset.StandardCharsets; /** * @program: SpringCloud * @description: redis Key過期監(jiān)聽 * @author: zhang yi * @create: 2020-03-24 14:14 */public class KeyExpiredListener extends KeyExpirationEventMessageListener { public KeyExpiredListener(RedisMessageListenerContainer listenerContainer) { super(listenerContainer); } @Override public void onMessage(Message message, byte[] pattern) { System.out.println('過期key:' + message.toString()); }}

5、創(chuàng)建Redis配置類

import com.zy.rabbitmq.base.Listener.KeyExpiredListener;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.connection.RedisConnectionFactory;import org.springframework.data.redis.listener.RedisMessageListenerContainer; /** * @program: SpringCloud * @description: redis配置類 * @author: zhang yi * @create: 2020-03-24 14:17 */@Configurationpublic class RedisConfiguration { @Autowired private RedisConnectionFactory redisConnectionFactory; @Bean public RedisMessageListenerContainer redisMessageListenerContainer() { RedisMessageListenerContainer redisMessageListenerContainer = new RedisMessageListenerContainer(); redisMessageListenerContainer.setConnectionFactory(redisConnectionFactory); return redisMessageListenerContainer; } @Bean public KeyExpiredListener keyExpiredListener() { return new KeyExpiredListener(this.redisMessageListenerContainer()); } }

6、這里提供一個(gè)redis工具類,用于存儲(chǔ)值,獲取值,獲取過期時(shí)間等操作。

import org.springframework.data.redis.core.RedisTemplate;import org.springframework.stereotype.Component;import org.springframework.util.CollectionUtils; import javax.annotation.Resource;import java.util.concurrent.TimeUnit;/** * redis 工具類 * @Author ZhangYi */@Componentpublic class RedisUtil { @Resourceprivate RedisTemplate<String, Object> redisTemplate; /** * 指定緩存失效時(shí)間 * * @param key 鍵 * @param time 時(shí)間(秒) * @return */public boolean expire(String key, long time) {try {if (time > 0) {redisTemplate.expire(key, time, TimeUnit.SECONDS);}return true;} catch (Exception e) {e.printStackTrace();return false;}} /** * 根據(jù)key 獲取過期時(shí)間 * * @param key 鍵 不能為null * @return 時(shí)間(秒) 返回0代表為永久有效 */public long getExpire(String key) {return redisTemplate.getExpire(key, TimeUnit.SECONDS);} /** * 判斷key是否存在 * * @param key 鍵 * @return true 存在 false不存在 */public boolean hasKey(String key) {try {return redisTemplate.hasKey(key);} catch (Exception e) {e.printStackTrace();return false;}} /** * 刪除緩存 * * @param key 可以傳一個(gè)值 或多個(gè) */@SuppressWarnings('unchecked')public void del(String... key) {if (key != null && key.length > 0) {if (key.length == 1) {redisTemplate.delete(key[0]);} else {redisTemplate.delete(CollectionUtils.arrayToList(key));}}} // ============================String=============================/** * 普通緩存獲取 * * @param key 鍵 * @return 值 */public Object get(String key) {return key == null ? null : redisTemplate.opsForValue().get(key);} /** * 普通緩存放入 * * @param key 鍵 * @param value 值 * @return true成功 false失敗 */public boolean set(String key, Object value) {try {redisTemplate.opsForValue().set(key, value);return true;} catch (Exception e) {e.printStackTrace();return false;} } /** * 普通緩存放入并設(shè)置時(shí)間 * * @param key 鍵 * @param value 值 * @param time 時(shí)間(秒) time要大于0 如果time小于等于0 將設(shè)置無限期 * @return true成功 false 失敗 */public boolean set(String key, Object value, long time) {try {if (time > 0) {redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);} else {set(key, value);}return true;} catch (Exception e) {e.printStackTrace();return false;}}}

7、測(cè)試。(這里開放兩個(gè)接口,一個(gè)set值,并設(shè)置過期時(shí)間為10秒,一個(gè)獲取值和過期時(shí)間,當(dāng)?shù)竭_(dá)過期時(shí)間,看是否回去到過期Key)

@GetMapping('/put') public String demo(){ redisUtil.set('name','zhangyi',10); return 'aaa'; } @GetMapping('/get') public Map<String,Object> get(){ Map<String,Object> m =new HashMap<>(); m.put('time',redisUtil.getExpire('name')); m.put('val',redisUtil.get('name')); return m; }

spring boot+redis 監(jiān)聽過期Key的操作方法

spring boot+redis 監(jiān)聽過期Key的操作方法

成功獲取到了過期Key,這里亂碼是因?yàn)閎oot集成的Redis存key或者value的時(shí)候,沒有配置字符串序列化。沒有配置的話是默認(rèn)使用jdk本身的序列化的。

到此這篇關(guān)于spring boot+redis 監(jiān)聽過期Key的文章就介紹到這了,更多相關(guān)spring boot+redis 監(jiān)聽過期Key內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 临漳县| 榕江县| 江津市| 日喀则市| 辽阳市| 余干县| 五常市| 佛学| 台湾省| 南宫市| 邓州市| 昌图县| 汝阳县| 海伦市| 蕲春县| 张家口市| 竹溪县| 庐江县| 特克斯县| 抚松县| 溆浦县| 西吉县| 准格尔旗| 哈尔滨市| 泉州市| 寻乌县| 绍兴市| 阿尔山市| 万全县| 济阳县| 四子王旗| 抚松县| 平利县| 格尔木市| 墨竹工卡县| 顺平县| 江永县| 淄博市| 银川市| 台州市| 彭州市|