我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java如何使用redis加锁

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java如何使用redis加锁

java使用redis加锁

1.编写LockUtil工具类

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.RedisStringCommands.SetOption;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.types.Expiration;
import org.springframework.stereotype.Service;
 

@Service
public class LockUtil {
 
    @Autowired
    private RedisTemplate redisTemplate;
 
    @Autowired
    private StringRedisTemplate stringRedisTemplate;
 
    
    public boolean lock(String lockKey, int lockSeconds) {
        return (Boolean) redisTemplate.execute((RedisCallback) connection -> {
            byte[] key = lockKey.getBytes();
            Boolean set = connection.set(key, key, Expiration.seconds(lockSeconds), SetOption.SET_IF_ABSENT);
            if (set == null) {
                return false;
            }
            return set;
        });
    }
 
    public boolean isLock(String lockKey) {
        return stringRedisTemplate.opsForValue().get(lockKey)!=null;
    }
 
 
    public boolean clearLock(String lockKey){
       return redisTemplate.delete(lockKey);
    }
}

2.使用锁

public abstract class AbstractTask {
 
    @Autowired
    private LockUtil lockUtil;
 
    
    protected abstract String getLockKey();
 
    protected boolean lock() {
        return lockUtil.lock(getLockKey(), 120);
    }
 
    protected boolean lockManual() {
        return lockUtil.lock(getLockKey(), 299);
    }
 
    protected boolean clearLock() {
        return lockUtil.clearLock(getLockKey());
    }
}
@Component
@Slf4j
@RefreshScope
public class FileCapacityCountTask extends AbstractTask{
    @Autowired
    private FileCapacityCountService fileCapacityCountService;
   
 
    @Scheduled(cron = "${batch.verification.schedule.capacity}")
    public void task(){
        if (!lock()) {
            log.info("本实例无需执行定时任务");
            return;
        }
        fileCapacityCountService.fileCapacityCountTask();
    }
 
    @Override
    protected String getLockKey() {
        String today = DateUtil.formatDate(new Date());
        return FileCapacityCountTask.class.getSimpleName() + CommonConstant.APPLICATION_NAME + today;
    }
}

redis锁用法java代码

由于redis是串行的,所以可以用redis实现锁机制。

下方是java代码:

@Component
@Slf4j
public class RedisSingleLock {
    private final StringRedisTemplate redis;

    public SimpleDistributedLock(StringRedisTemplate redis) {
        this.redis = redis;
    }

    //这个方法,可以传入key加锁;多线程调用时,只有1个能获取锁成功,其它线程则会进入循环,不停尝试获取锁
    public void lock(String key) {
        do {
            Boolean lockSuccess = redis.opsForValue().setIfAbsent(key, "1", 1, TimeUnit.DAYS);
            if (lockSuccess == null) {
                throw new IllegalStateException();
            }
            if (!lockSuccess) {
                try {
                    TimeUnit.MILLISECONDS.sleep(100);
                } catch (InterruptedException e) {
                    log.error(e.getMessage(), e);
                }
            } else {
                break;
            }
        } while (true);
    }

    //这个方法,传入key释放锁,当持有锁的线程执行业务代码完毕后调用,释放这个锁;上方某一个在lock方法中循环尝试获得锁的线程可以获得锁,另外的线程则继续循环等待
    public void releaseLock(String key) {
        redis.delete(key);
    }
	
	//这个方法只尝试获取一次锁,返回获取结果
    public boolean tryLock(String key) {
        Boolean lockSuccess = redis.opsForValue().setIfAbsent(key, "1", 1, TimeUnit.DAYS);
        if (lockSuccess == null) {
            throw new IllegalStateException();
        }

        return lockSuccess;
    }
}

    

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java如何使用redis加锁

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java如何使用redis加锁

这篇文章主要介绍了java如何使用redis加锁问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-09

如何用redis setNX命令来加锁

目录用Redis setNX命令来加锁redis几种加python锁的实现1. redis加锁分类2. 第一种锁命令INCR3. 第二种锁SETNX4. 第三种锁SET5. 其它问题6. 解决办法7. 另外一个锁总结用redis setNX
2023-01-09

如何使用Redis和Java开发分布式锁功能

如何使用Redis和Java开发分布式锁功能引言分布式锁是在分布式系统中实现互斥访问共享资源的一种机制。在多个节点同时访问共享资源时,需要确保只有一个节点在访问,其他节点需要等待。Redis是一个常用的内存数据库,具备高性能和高可靠性的特点
2023-10-22

java redis对象锁怎么使用

JavaRedis对象锁是一种分布式锁机制,用于协调对共享资源的并发访问。它使用Redis的原子性命令来实现,确保只有单个客户端一次持有锁。客户端使用SETNX命令尝试设置锁键,使用EXPIRE命令设置超时时间,在超时时间内持有锁,使用DEL命令显式释放锁。该锁具有分布式、原子性、超时机制和简单易用等优势,但需要注意确保在释放锁之前清除超时,避免死锁,同时考虑使用分布式协调器或第三方库以提高鲁棒性。
java redis对象锁怎么使用
2024-04-02

java中redis缓存如何加

Redis缓存的高性能键值存储提高Java应用程序性能和减少数据库负载,可通过以下步骤实现:引入Redis库、创建Redis连接、设置缓存项、获取缓存项、删除缓存项、检查缓存项是否存在、缓存命中策略。遵循这些步骤和最佳实践,如使用连接池、设置过期时间、处理并发、监控和维护,可以有效地集成Redis缓存,增强应用程序可扩展性和响应能力。
java中redis缓存如何加
2024-04-02

redis在java中如何使用

本文介绍了在Java中使用Redis的方法,包括建立连接、设置和获取键值、使用不同数据类型、事务处理、管道操作和订阅功能。此外,文中也提到了使用Redis的最佳实践,如连接池、批量命令、键过期时间和实例监控。通过本文,读者可以全面了解如何在Java应用程序中集成Redis,以提高性能和可扩展性。
redis在java中如何使用
2024-04-02

redis如何在java中使用

本教程详细介绍了如何在Java中使用RedisAPI,包括连接到服务器、存储和检索值、使用数据结构(列表、集合、哈希表、有序集合)、发布和订阅消息、事务、管道以及高级功能(Lua脚本、连接池、哨兵监控、集群模式)。通过这些功能,Java开发者可以轻松地将Redis集成到他们的应用程序中,构建健壮且可扩展的解决方案。
redis如何在java中使用
2024-04-02

如何使用Java操作Redis

这篇文章给大家分享的是有关如何使用Java操作Redis的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。首先让我们创建一个普通的Maven工程,添加相应的依赖
2023-06-15

java web 中如何使用redis

在JavaWeb开发中,Redis是一款流行的键值存储数据库,可用于缓存数据、会话管理和消息传递等场景。它以快速、可扩展和多功能性著称,可大幅提升应用程序性能。本文详细讲解了如何在JavaWeb中使用Redis,包括依赖项、连接池、缓存、会话管理、消息传递,以及其他用例,为开发者提供了实战指导。
java web 中如何使用redis
2024-04-02

SpringBoot中如何使用Redis作为全局锁

这篇文章主要讲解了“SpringBoot中如何使用Redis作为全局锁”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot中如何使用Redis作为全局锁”吧!一、模拟没有锁情况
2023-06-29

redis怎么使用锁

使用redis进行锁操作需要通过setnx命令获取锁,然后使用expire命令设置过期时间。具体步骤为:(1) 使用setnx命令尝试设置一个键值对;(2) 使用expire命令为锁设置过期时间;(3) 当不再需要锁时,使用del命令删除该
redis怎么使用锁
2024-06-03

如何使用Java中无锁技术

本篇内容介绍了“如何使用Java中无锁技术”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、原子工具类JDK 1.8 中,java.util
2023-06-16

java怎么使用redis实现分布式锁

使用Redis实现Java分布式锁使用RedisSETNX和EXPIRE命令,可以实现分布式锁,协调对共享资源的访问。获取锁时,尝试设置唯一键,并设置过期时间。释放锁时,删除键。使用Redis的分布式特性和命令的易用性,可以简单且健壮地实现分布式锁。但需要注意键的唯一性、过期时间和竞争条件等注意事项。
java怎么使用redis实现分布式锁
2024-04-11

java怎么使用redis实现分布式锁

在Java中使用Redis实现分布式锁可以通过以下步骤:1. 引入Redis相关的依赖,例如Jedis或Lettuce。2. 创建一个Redis连接池或连接工厂,用于获取Redis连接。3. 使用Redis连接实例,调用setnx命令(或相
2023-10-09

redis如何使用在java开发

Redis是一款高性能的开源键值存储数据库,将其集成到Java应用程序中可以提升性能和可扩展性。本文介绍了使用Jedis连接到Redis,以及存储、检索数据,使用哈希、列表、集合,发布和订阅,事务和持久化等操作。通过使用Redis,Java应用程序可以显著提高其性能、可扩展性和可靠性。
redis如何使用在java开发
2024-04-02

java如何使用redis做缓存

使用Redis在Java中实现缓存,可以提升应用程序性能和可伸缩性。步骤包括:引入Redis客户端库。创建Redis连接。设置缓存,使用set命令。获取缓存,使用get命令。设置过期时间,使用expire命令。检查缓存存在,使用exists命令。删除缓存,使用del命令。刷新缓存,使用flushDB命令。最佳实践建议:使用不同的缓存键前缀。设置适当的过期时间。使用批量操作。监控缓存。处理缓存丢失。
java如何使用redis做缓存
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录