SpringBoot基于数据库实现简单的分布式锁

  1. 云栖社区>
  2. Java技术进阶>
  3. 博客>
  4. 正文

SpringBoot基于数据库实现简单的分布式锁

dalaoyang 2019-07-28 12:23:23 浏览800
展开阅读全文

本文介绍SpringBoot基于数据库实现简单的分布式锁。

1.简介

分布式锁的方式有很多种,通常方案有:

  • 基于mysql数据库
  • 基于redis
  • 基于ZooKeeper

网上的实现方式有很多,本文主要介绍的是如果使用mysql实现简单的分布式锁,加锁流程如下图:

其实大致思想如下:

  • 1.根据一个值来获取锁(也就是我这里的tag),如果当前不存在锁,那么在数据库插入一条记录,然后进行处理业务,当结束,释放锁(删除锁)。
  • 2.如果存在锁,判断锁是否过期,如果过期则更新锁的有效期,然后继续处理业务,当结束时,释放锁。如果没有过期,那么获取锁失败,退出。

2.数据库设计

2.1 数据表介绍

数据库表是由JPA自动生成的,稍后会对实体进行介绍,内容如下:

CREATE TABLE `lock_info` (
  `id` bigint(20) NOT NULL,
 

网友评论

登录后评论
0/500
评论
dalaoyang
+ 关注
所属云栖号: Java技术进阶