[英]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.