繁体   English   中英

创建一个守护线程,该线程恰好在(可能是复制的)Spring Boot 服务的一个实例中运行

[英]Create a daemon thread that runs in exactly one instance of a (possibly replicated) Spring Boot service

我有一个部署在多个实例中的 Spring Boot 服务。 我想在其中一个实例中连续运行“守护线程”。 如果该实例出现故障,该线程最终(超时后)应该在其他某个实例上处于活动状态。

该服务使用通用 MongoDB 数据库,原则上可以提供锁定,但我正在寻找一种模式或库可以正确执行此操作。

我查看了Shedlock ,但它似乎仅适用于具有可预测持续时间的短期运行的作业,而不是长时间运行的守护线程。

我们使用 Shedlock,我强烈推荐它,因为它很简单。 你说你想要一个长时间运行的守护线程 - 但是你能不能有一个 @Scheduled(fixedDelay=0) 注释的方法,该方法会运行,然后在上一次迭代完成后立即被 Spring 再次触发运行? 您可以将其用作“while”循环,而不是在内部具有永无止境的 while 循环的单个方法。

我目前正在使用LockExtender来扩展活动锁。 它对您的用例有帮助吗? 用法是

LockExtender.extendActiveLock(Duration.of(5, MINUTES), ZERO);

暂无
暂无

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

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