美畅物联丨分布式锁实战:Spring Boot项目中的Redis应用

embedded/2024/12/28 5:53:37/

在分布式系统里,多个节点或许会同时对共享资源进行访问与操作。为防止出现数据不一致、资源竞争等状况,就需要一种机制来对这些并发访问加以协调,于是分布式锁就出现了。它如同一把全局的钥匙,在同一时刻仅有一个节点能够获取该钥匙以访问共享资源,进而确保了数据的一致性以及系统的稳定性。

在Spring Boot应用里,利用Redis达成分布式锁是一种常见的操作方式,Redis提供了简洁且有效的机制以实现该功能。

以下为在Spring Boot中运用Redis实现分布式锁的步骤:

一、搭建 Spring Boot 项目并引入 Redis 依赖

1、创建 Spring Boot 项目

(1)利用Spring Initializr创建一个Spring Boot项目。在项目配置期间,挑选合适的Spring Boot版本,一般推荐使用稳定版本。

要确保添加Web依赖,因为在Web服务中我们通常会使用分布式锁来保护共享资源。此外,添加Redis依赖,这会让我们在项目中便捷地使用Redis相关功能。

(2)检查项目结构与配置文件

在生成的项目结构里,pom.xml(针对Maven项目)或者build.gradle(针对Gradle项目)属于项目构建文件,其作用是管理项目的依赖关系。

src/main/java目录是用于编写Java代码的地方,src/main/resources目录则用于存放配置文件、静态资源等。

2、配置 Redis 连接

(1)在application.properties或者application.yml中进行配置。

若使用application.properties文件,则添加如下配置:

properties
spring.redis.host=localhostspring.redis.port=6379

(2)这里假定Redis服务在本地运行,其主机名是localhost,端口为6379。若Redis服务受密码保护,那么还需添加spring.redis.password配置项。

若采用application.yml文件,配置如下:

yaml
spring:redis:host: localhostport: 6379

这种配置方式更为直观,具有清晰的层次结构。同样地,若存在密码,也能够在password(密码)字段添加密码信息。

二、实现 Redis 分布式锁的基本步骤

1、注入 RedisTemplate

在需要运用分布式锁的类里注入RedisTemplate。

在Spring Boot框架下,RedisTemplate属于操作Redis的核心类。在服务类或者相关业务逻辑类当中,借助@Autowired注解来注入RedisTemplate。

java
import org.springframework.data.redis.core.RedisTemplate;import org.springframework.stereotype.Service;@Servicepublic class MyService {private final RedisTemplate<String, Object> redisTemplate;@Autowiredpublic MyService(RedisTemplate<String, Object> redisTemplate) {this.redisTemplate = redisTemplate;}// 以下是使用分布式锁的业务逻辑}

在这里,把RedisTemplate注入到MyService类里,以便于在这个类之后的业务逻辑当中,运用Redis操作达成分布式锁。

2、获取分布式锁

利用Redis的SETNX命令达成锁获取

在MyService类里,编写一个用于获取分布式锁的方法。能够借助RedisTemplate的opsForValue方法来操作Redis中的字符串类型数据,该方法对应SETNX(SET if Not eXists)命令,此命令的作用是当键不存在时设置键值。

java
public boolean tryLock(String lockKey, long expireTime) {Boolean result = redisTemplate.opsForValue().setIfAbsent(lockKey, "locked");if (result!= null && result) {// 设置锁的过期时间,防止死锁redisTemplate.expire(lockKey, expireTime, TimeUnit.SECONDS);return true;}return false;}

此方法接收两个参数,其中lockKey为用于标识锁的唯一键,expireTime则是锁的过期时间(单位为秒)。首先尝试获取锁,若键不存在(也就是说当前没有其他节点持有该锁),便将键值设为locked,并且返回true以表明获取锁成功。接着设置锁的过期时间,如此一来,即便持有锁的节点发生故障,锁也会在一段时间后自动释放,从而避免了死锁状况。若获取锁失败(键已经存在),则返回false。

3、释放分布式锁

利用Redis的DEL命令达成锁的释放

编写一个用于释放分布式锁的方法,同样借助RedisTemplate进行操作。

java
public void unlock(String lockKey) {redisTemplate.delete(lockKey);}

这个方法十分简单,利用redisTemplate.delete方法删除相应的锁键,进而释放锁。但在实际应用时,必须注意确保只有持有锁的节点才能够释放锁,防止误将其他节点持有的锁释放。

三、注意事项

1、锁的过期时间:要确保设定合理的锁过期时间,防止由于某些原因(例如服务器宕机)致使锁无法释放。

2、重试机制:运用Spring Retry或者其他重试机制来处理锁获取失败的状况。

3、锁的唯一性:要保证锁键具有唯一性,以免不同业务逻辑发生冲突。

4、性能考量:分布式锁会带来一定的性能损耗,在高并发场景下尤其需要谨慎使用。

通过以上步骤,我们可以在 Spring Boot 项目中有效地使用 Redis 实现分布式锁,保护共享资源,确保分布式系统的稳定运行和数据一致性。不过,在实际应用中,还需要根据具体的业务场景和系统架构进行更多的优化和调整。

————————————————

关注“美畅物联”,了解更多视频汇聚及AIoT底座解决方案。


http://www.ppmy.cn/embedded/148681.html

相关文章

【HarmonyOS 5.0】第十二篇-ArkUI公共属性(一)

一、公共样式类属性 ArkUI框架提供的基础组件直接或者间接的继承自 CommonMethod &#xff0c; CommonMethod 中定义的属性样式属于公共样式。下面就来学习这些样式 1.1.尺寸设置 宽高设置 设置组件的宽高&#xff0c;缺省时使用组件自身内容的宽高&#xff0c;比如充满父布…

信息安全管理与评估赛题第9套

全国职业院校技能大赛 高等职业教育组 信息安全管理与评估 赛题九 模块一 网络平台搭建与设备安全防护 1 赛项时间 共计180分钟。 2 赛项信息 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 第一阶段 网络平台搭建与设备安全防护 任务1 网络平台搭建 XX:XX- XX:XX 50 任务2…

[Unity Shader]【图形渲染】 数学基础4 - 矩阵定义和矩阵运算详解

矩阵是计算机图形学中的重要数学工具,尤其在Shader编程中,它被广泛用于坐标变换、投影变换和模型动画等场景。本文将详细介绍矩阵的定义、基本运算以及如何在Shader中应用矩阵,为初学者打下坚实的数学基础。 一、什么是矩阵? 矩阵是一个由数字排列成的长方形数组,通常记作…

无人零售 4G 工业无线路由器赋能自助贩卖机高效运营

工业4G路由器为运营商赋予 “千里眼”&#xff0c;实现对贩卖机销售、库存、设备状态的远程精准监控&#xff0c;便于及时补货与维护&#xff1b;凭借强大的数据实时传输&#xff0c;助力深度洞察销售趋势、优化库存、挖掘商机&#xff1b;还能远程升级、保障交易安全、快速处理…

【es6复习笔记】箭头函数(5)

简介 本教程将介绍如何在 JavaScript 中使用箭头函数&#xff0c;包括箭头函数的基本语法、特点以及在实际开发中的应用。通过本教程&#xff0c;你将学会如何使用箭头函数来简化代码&#xff0c;提高代码的可读性和简洁性。 箭头函数的基本语法 箭头函数是 ES6 引入的一种新…

加密货币地址的基本概念

什么是地址&#xff1f; 在日常生活中&#xff0c;地址可能指房屋、电子邮件或官网的位置&#xff0c;用来精确定位在系统中的特定位置或端点。在加密货币领域&#xff0c;地址也起着类似的基础作用&#xff0c;只不过是在数字环境中。 加密货币地址是区块链网络中使用的唯一…

Linux 环境下运行 .NET 8.0 core项目

在 Linux 环境下运行 .NET 8.0 项目&#xff0c;.NET 已支持跨平台运行&#xff0c;以下是完整的步骤&#xff1a; 1. 安装 .NET 8.0 SDK 或运行时 首先需要在 Linux 系统中安装 .NET 8.0 SDK 或运行时。 1.1 添加 Microsoft 包管理源 运行以下命令添加 Microsoft 包管理源并安…

微软在AI时代的战略布局和挑战

微软的CEO萨提亚纳德拉&#xff08;Satya Nadella&#xff09;在与投资人比尔格里&#xff08;Bill Gurley&#xff09;和布拉德格斯特纳&#xff08;Brad Gerstner&#xff09;的一场深度对话中&#xff0c;详细回顾了微软在AI时代的战略布局与所面临的挑战。这场对话不仅总结…