繁体   English   中英

Java Spring Scheduler Lock

[英]Java Spring Scheduler Lock

我一直试图向客户发送通知。 我正在使用kubernetes并且我创建了多个spring boot应用程序,因为我有2个副本。 这很好,但是当调度程序运行时,每个调度程序都可以发送通知。 我看了一下石英,但配置似乎有点复杂。 有一个简单的方法吗?

@Scheduled(fixedDelayString = "300000")
public void sendFlowerNotification() {
  //Code
}

您还可以使用dlock仅在多个节点上执行一次计划任务。 您可以简单地执行以下操作。

@Scheduled(fixedDelayString = "300000")
@TryLock(name = "flowerNotification", owner = POD_NAME, lockFor = THREE_MINUTES)
public void sendFlowerNotifications() {
  List<Notification> notifications = notificationService.getNotifications();
  for(Notification notification: notifications){
    sendNotification(notification);
  }
}

您可以将POD_NAME作为环境变量发送到spring。 dlock会自动处理它。

 env:
 - name: POD_NAME
   valueFrom:
     fieldRef:
       fieldPath: metadata.name

请参阅有关使用它的文章

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM