IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> redis-优雅的实现分布式锁 -> 正文阅读

[大数据]redis-优雅的实现分布式锁

文章内容已实现,详细gitHub地址:https://github.com/gl0726/redisson-anno-distributed-lock

在企业开发中,分布式锁十分常见,但依赖redis做好分布式锁需要注意很多细节:

1、可重入锁

2、自动续约

3、唯一ID解锁

4、设置超时时间避免永久锁

5、加锁、解锁的原子性操作

6、适配redis多种集群模式

针对以上6点这里推荐使用redisson,不仅默认支持原子操作,同时也支持自动续约,另外,Redisson 还提供了对 Redlock 算法的支持;

如何优雅的使用分布式锁?

1、常见的分布式锁代码如下:

try {
    lock = redisClient.tryLock(key, true, 30, 10);
    if (lock) {
        ......
    }
} catch (Exception e) {
    log.error("acquire task error!", e);
} finally {
    if (lock) {
        try {
            redisClient.unLock(RedisConstants.REDIS_WORKER_CONSUME_TASK_LOCK);
        } catch (Exception e) {
            log.error("unlock error!", e);
        }
    }
}

缺点:一个项目中很多函数都有可能用到分布式锁,而函数中的锁使用代码完全一致,造成了大量冗余代码。

2、本案例分布式锁的使用:

@RedisLock(key = "com:haizhi:test:lock:first") // 使用注解即可
public void processFirst() {
    ......
}

优点:通过注解 & AOP 实现了只需在需要使用分布式的函数上加上注解即可实现, 开发者只需要关注业务即可, 使用优雅;
另外通过AOP扫描的方式, 无需开发者自己实现扫描程序, 十分巧妙。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-11 22:17:06  更:2022-03-11 22:21:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:43:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码