使用shedlock实现分布式互斥执行

avatar
作者
猴君
阅读量:0

前言

前序章节:springboot基础(82):分布式定时任务解决方案shedlock

如果你不清楚shedlock,建议先阅读前序章节,再来查看本文。

如果我们不在spring环境下,如何使用shedlock实现分布式互斥执行?

我们可以使用shedlock为我们提供的DefaultLockingTaskExecutor来实现手动调用。

在这里插入图片描述

示例

void executeWithLock(@NonNull Runnable var1, @NonNull LockConfiguration var2)

  @GetMapping("/testRunnable")     public R testRunnable(HttpServletRequest request) {         log.info("进入方法");         String name = request.getParameter("name");         LockingTaskExecutor executor = new DefaultLockingTaskExecutor(lockProvider);         Instant now = Instant.now();         try {             executor.executeWithLock(new Runnable() {                 @Override                 public void run() {                     log.info("执行");                     helloService.helloCn(name);                 }             }, new LockConfiguration(now, "testRunnable", Duration.ofSeconds(30), Duration.ofSeconds(5)));             log.info("end");             return R.ok("success", null);         } catch (Throwable throwable) {             throwable.printStackTrace();         }         return R.fail("fail");     }  

LockingTaskExecutor.TaskResult executeWithLock(@NonNull LockingTaskExecutor.TaskWithResult task, @NonNull LockConfiguration lockConfig)
利用此API,我们可以让一个方法不能在一个时间只能有一次实例在执行,排斥调用者,且其它调用者的调用失败,这是与分布式锁不一样的地方。

 @GetMapping("/testTaskWithResult")     public R testTaskWithResult(HttpServletRequest request) {         log.info("进入方法");         String name = request.getParameter("name");         LockingTaskExecutor executor = new DefaultLockingTaskExecutor(lockProvider);         Instant now = Instant.now();         try {             LockingTaskExecutor.TaskResult taskResult = executor.executeWithLock(new LockingTaskExecutor.TaskWithResult() {                 @Override                 public Object call() throws Throwable {                     log.info("执行");                     return helloService.helloCn(name);                 }             }, new LockConfiguration(now, "testTaskWithResult", Duration.ofSeconds(30), Duration.ofSeconds(5)));             boolean flag = taskResult.wasExecuted();             log.info("end");             return R.ok("任务是否被执行:" + flag, taskResult.getResult());         } catch (Throwable throwable) {             throwable.printStackTrace();         }         return R.fail("fail");     } 

传送门

https://github.com/lukas-krecan/ShedLock

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!