本文主要是介绍锁-spring shedlock,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
背景
spring shedlock用于在分布式服务的情况下执行定时任务,例如定时删除数据库中的一些数据,做数据迁移等等操作。这项技术在项目的分布式服务中大量使用。
使用的主要原因有以下几点:
- 定时任务的业务需要,要在服务service正常运行的过程当中同时在背后执行一些操作,满足我们的业务需要,定时任务也就是schedule task必不可少。
- 分布式服务的要求。试想下面一个场景: 随着业务增长,有一天单个服务service的压力过大,一个服务支撑不住了,我们要考虑部署多个服务来分散压力。这时问题就来了,之前的定时任务,在各个服务上全都会跑,做着同样的事情,并且还会造成一些并发问题。这必然不是我们想要的结果,这时我们就会发现,虽然有多个服务,但是我们只能让这样的定时任务执行一次. 这时就可以考虑通过数据库来控制任务。因为多个服务的数据库依然是同一个。
用法配置
以postgres为例,我们可以按如下方式使用shedlock
首先我们需要引入对应的依赖:
<!-- shed lock --><dependency><groupId>net.javacrumbs.shedlock</groupId><artifactId>shedlock-spring</artifactId><version>${schedlock.version}</version></dependency><dependency><groupId>net.javacrumb
这篇关于锁-spring shedlock的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!