悲观锁、乐观锁与分布式锁详解及Redisson应用

目录

  • [1. 悲观锁(Pessimistic Lock)](#1. 悲观锁(Pessimistic Lock))
  • [2. 乐观锁(Optimistic Lock)](#2. 乐观锁(Optimistic Lock))
  • [3. Redis分布式锁](#3. Redis分布式锁)
  • [4. Redisson锁](#4. Redisson锁)

在多线程或多进程环境下,为了保证数据的一致性,锁机制扮演着至关重要的角色。本文将深入探讨悲观锁、乐观锁的概念,以及如何利用Redis实现分布式锁,并通过Redisson客户端展示具体的应用实例。最后,我们也会简要提及如何从Redis中删除缓存信息。

1. 悲观锁(Pessimistic Lock)

概念: 悲观锁假设最坏的情况,即每次数据操作都可能发生并发冲突,因此在数据被处理前就将其锁定,阻止其他线程访问,直到该线程完成操作并释放锁。这种方式适合写操作频繁的场景。

Java中的应用: 在Java中,synchronized关键字和ReentrantLock类可以用来实现悲观锁。

java 复制代码
public class PessimisticLockExample {
    private final ReentrantLock lock = new ReentrantLock();

    public void doSomething() {
        lock.lock(); // 获取锁
        try {
            // 执行业务逻辑
        } finally {
            lock.unlock(); // 释放锁
        }
    }
}

2. 乐观锁(Optimistic Lock)

概念: 乐观锁则假设读多写少的情况,不直接加锁,而是在更新数据时检查在此期间数据是否被其他线程修改过。乐观锁常通过版本号或时间戳来实现,仅当数据实际需要更新时才进行冲突检查。

Java中的应用: 在数据库操作中,可以通过版本字段实现乐观锁。

java 复制代码
@Entity
class User {
    @Version
    private Long version;

    // 省略其他代码...
}

// 更新用户信息时检查版本号
@Modifying
@Query("UPDATE User u SET u.name = ?1 WHERE u.id = ?2 AND u.version = ?3")
int updateUser(String newName, Long id, Long version);

3. Redis分布式锁

概念: 在分布式系统中,传统的锁机制无法跨越多个节点,因此需要分布式锁。Redis由于其高性能和易用性,常被用作分布式锁的实现基础。

基本用法:

SETNX (SET if Not eXists) 命令可以用来实现简单的分布式锁。

需要考虑锁的超时释放问题,使用 expire 命令设置锁的生存时间。

java 复制代码
@RequiredArgsConstructor
public class RedisLock {

    private final String key;
    private final StringRedisTemplate redisTemplate;

    public boolean lock(long leaseTime, TimeUnit timeUnit) {
        String value = Thread.currentThread().getName();
        Boolean success = redisTemplate.opsForValue().setIfAbsent(key, value, leaseTime, timeUnit);
        return BooleanUtils.isTrue(success);
    }
    public void unlock() {
            redisTemplate.delete(key);

    }
}
java 复制代码
        String key="lock:coupon:userId:"+userId;
        RedisLock redisLock = new RedisLock(key, redisTemplate);
        boolean locked = redisLock.lock(5, TimeUnit.SECONDS);
        if(!locked)
        {
            throw new BadRequestException("请求太频繁");
        }
        try {
            // 获取用户优惠券服务
            IUserCouponService userCouponService = (IUserCouponService) AopContext.currentProxy();
            // 校验并创建用户优惠券
            userCouponService.checkAndCreateUserCoupon(coupon, userId, null);
        } finally {
            redisLock.unlock();
        }

4. Redisson锁

Redisson是Redis的Java客户端,它提供了丰富的并发工具,包括基于Redis的分布式锁、信号量、计数器等高级功能,简化了分布式环境下的并发控制。

Redisson分布式锁示例:

java 复制代码
import org.redisson.Redisson;
import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;

public class RedissonDistributedLockExample {
    public static void main(String[] args) {
        Config config = new Config();
        config.useSingleServer().setAddress("redis://localhost:6379");
        RedissonClient redisson = Redisson.create(config);

        RLock lock = redisson.getLock("myLock");
        
        try {
            // 尝试获取锁,最多等待100秒,上锁后自动续期
            boolean isLocked = lock.tryLock(100, TimeUnit.SECONDS);
            if (isLocked) {
                // 执行业务逻辑
            } else {
                System.out.println("未能获取到锁");
            }
        } catch (InterruptedException e) {
            Thread.currentThread().interrupt();
        } finally {
            // 释放锁
            if (lock.isHeldByCurrentThread()) {
                lock.unlock();
            }
        }
        redisson.shutdown();
    }
}

通过上述介绍和示例,我们可以看到,悲观锁、乐观锁以及分布式锁(特别是通过Redisson实现)在不同场景下各有优势,选择合适的锁机制对于提升系统并发性能和数据一致性至关重要。

相关推荐
ok_hahaha2 小时前
java从头开始-黑马点评-分布式锁-redis实现基础版
java·redis·分布式
传感器与混合集成电路3 小时前
法珀干涉与光栅补偿:井下压力温度一体化光纤监测技术
分布式
@insist1233 小时前
数据库系统工程师-分布式数据库与数据仓库核心考点及应用体系
数据库·数据仓库·分布式·软考·数据库系统工程师·软件水平考试
XDHCOM5 小时前
TP5框架Redis分布式缓存实战,解决高并发场景下的数据一致性问题
redis·分布式·缓存
Fzuim5 小时前
从CLI到分布式智能体:重新理解AI Agent的演进路径与工程现实
人工智能·分布式·ai·agent·agentic
_院长大人_7 小时前
Spring Boot 3.3 + Atomikos 分布式事务日志路径配置踩坑记录
spring boot·分布式·后端
Data 实验室7 小时前
TaskPyro “小龙虾版本”专业爬虫管理平台来了:AI+分布式+IM 机器人,一套搞定企业级爬虫调度
人工智能·分布式·爬虫
想你依然心痛7 小时前
HarmonyOS 5.0教育行业解决方案:基于分布式能力的沉浸式智慧课堂系统
分布式·wpf·harmonyos
霖霖总总8 小时前
[Redis小技巧29]从 Setnx 到 Redlock:Redis 分布式锁的演进之路与生产级实践
数据库·redis·分布式
七夜zippoe8 小时前
联邦学习实战:隐私保护的分布式机器学习——联邦平均与差分隐私
分布式·python·机器学习·差分隐私·联邦平均