Redis分布式锁加时效和不加时效两种方案的最全代码实现
生活随笔
收集整理的這篇文章主要介紹了
Redis分布式锁加时效和不加时效两种方案的最全代码实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?鎖住3秒:
@Autowired private RedisTemplate redisTemplate;String withdrawals_apply_key = WITHDRAWALS_REDIS_KEY+driver.getId(); boolean flag = redisTemplate.opsForValue().setIfAbsent(withdrawals_apply_key,WITHDRAWALS_LOCK); log.info("任務是否獲取到鎖:" + flag); if (flag) {redisTemplate.expire(withdrawals_apply_key,3,TimeUnit.SECONDS);//要鎖住的代碼。。。。。。 }else{log.info("任務沒有獲取到鎖,不執行!");return; }鎖不設置時效:
@Autowired private RedisTemplate redisTemplate;boolean flag = false; try{flag = redisTemplate.opsForValue().setIfAbsent(REDIS_KEY, LOCK);log.info("是否獲取到鎖:" + flag);if (flag){//要鎖住的代碼。。。。。。}else {log.info("沒有獲取到鎖,不執行定時任務!");return;} }finally {if (flag) {redisTemplate.delete(REDIS_KEY);log.info("任務結束,釋放鎖!");} else {log.info("沒有獲取到鎖,無需釋放鎖!");} }?redis的配置類(springboot):
import com.fengyuncx.common.utils.json.FastJsonRedisSerializer; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; import org.springframework.boot.autoconfigure.data.redis.RedisProperties; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.data.redis.cache.RedisCacheConfiguration; import org.springframework.data.redis.cache.RedisCacheManager; import org.springframework.data.redis.cache.RedisCacheWriter; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.connection.RedisPassword; import org.springframework.data.redis.connection.RedisStandaloneConfiguration; import org.springframework.data.redis.connection.jedis.JedisClientConfiguration; import org.springframework.data.redis.connection.jedis.JedisConnectionFactory; import org.springframework.data.redis.core.*; import org.springframework.data.redis.serializer.RedisSerializationContext; import org.springframework.data.redis.serializer.StringRedisSerializer; import redis.clients.jedis.JedisPoolConfig;import java.time.Duration;@Configuration @EnableCaching @ConditionalOnClass(RedisOperations.class) @EnableConfigurationProperties(RedisProperties.class) public class RedisConfig {@Value("${spring.driverRedis.host}")private String host;@Value("${spring.driverRedis.port}")private int port;@Value("${spring.driverRedis.password}")private String password;@Value("${spring.driverRedis.maxTotal}")private Integer maxTotal;@Value("${spring.driverRedis.maxIdle}")private Integer maxIdle;@Value("${spring.driverRedis.maxWaitMillis}")private Integer maxWaitMillis;@Value("${spring.driverRedis.timeout}")private int timeout;@Value("${spring.driverRedis.database}")private int database;@Primary@Beanpublic RedisConnectionFactory cacheBusinessRedisConnectionFactory() {JedisPoolConfig poolConfig = new JedisPoolConfig();poolConfig.setMaxTotal(maxTotal);poolConfig.setMaxIdle(maxIdle);poolConfig.setMaxWaitMillis(maxWaitMillis);poolConfig.setTestOnBorrow(true);poolConfig.setTestOnReturn(false);poolConfig.setTestWhileIdle(true);JedisClientConfiguration clientConfig = JedisClientConfiguration.builder().usePooling().poolConfig(poolConfig).and().readTimeout(Duration.ofMillis(timeout)).build();// 單點redisRedisStandaloneConfiguration redisConfig = new RedisStandaloneConfiguration();// 哨兵redis// RedisSentinelConfiguration redisConfig = new RedisSentinelConfiguration();// 集群redis// RedisClusterConfiguration redisConfig = new RedisClusterConfiguration();redisConfig.setHostName(host);redisConfig.setPassword(RedisPassword.of(password));redisConfig.setPort(port);redisConfig.setDatabase(database);return new JedisConnectionFactory(redisConfig, clientConfig);}/*** 管理緩存 springboot2** @param redisTemplate* @return*/@Beanpublic RedisCacheManager redisCacheManager(RedisTemplate redisTemplate) {//初始化一個RedisCacheWriterRedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisTemplate.getConnectionFactory());RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig().serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(redisTemplate.getValueSerializer()));//設置序列化//設置默認超過期時間是30秒redisCacheConfiguration.entryTtl(Duration.ofSeconds(30));//初始化RedisCacheManagerRedisCacheManager cacheManager = new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);return cacheManager;}@Beanpublic RedisTemplate<String, Object> redisTemplate() {RedisTemplate<String, Object> template = new RedisTemplate<>();// Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class); // template.setValueSerializer(jackson2JsonRedisSerializer); // template.setHashValueSerializer(jackson2JsonRedisSerializer);//使用fastjson序列化FastJsonRedisSerializer fastJsonRedisSerializer = new FastJsonRedisSerializer(Object.class);// value值的序列化采用fastJsonRedisSerializertemplate.setValueSerializer(fastJsonRedisSerializer);template.setHashValueSerializer(fastJsonRedisSerializer);// key的序列化采用StringRedisSerializertemplate.setKeySerializer(new StringRedisSerializer());template.setHashKeySerializer(new StringRedisSerializer()); //template.setConnectionFactory(cacheBusinessRedisConnectionFactory());return template;}/*** 對hash類型的數據操作** @param redisTemplate* @return*/@Beanpublic HashOperations<String, String, Object> hashOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForHash();}/*** 對redis字符串類型數據操作** @param redisTemplate* @return*/@Beanpublic ValueOperations<String, Object> valueOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForValue();}/*** 對鏈表類型的數據操作** @param redisTemplate* @return*/@Beanpublic ListOperations<String, Object> listOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForList();}/*** 對無序集合類型的數據操作** @param redisTemplate* @return*/@Beanpublic SetOperations<String, Object> setOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForSet();}/*** 對有序集合類型的數據操作** @param redisTemplate* @return*/@Beanpublic ZSetOperations<String, Object> zSetOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForZSet();} }application.yml配置內容:
spring:driverRedis:host: 192.168.101.100port: 6379password: 123456maxIdle: 300maxTotal: 600maxWaitMillis: 1000timeout: 3000database: 4dictRedis:host: 192.168.101.100port: 6379password: 123456maxIdle: 300maxTotal: 600maxWaitMillis: 1000timeout: 3000database: 0?
總結
以上是生活随笔為你收集整理的Redis分布式锁加时效和不加时效两种方案的最全代码实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL使用覆盖索引来优化limit语
- 下一篇: VMware快照管理器