-
Notifications
You must be signed in to change notification settings - Fork 533
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Provide more generic lock annotation for non scheduler based contexts #899
Comments
Update: For the moment I use a pseudo annotation: package de.dehst.platform.waiting.area.service.core;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import net.javacrumbs.shedlock.spring.annotation.SchedulerLock;
import org.springframework.core.annotation.AliasFor;
import java.lang.annotation.Documented;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
@Documented
@Inherited
@Retention(RUNTIME)
@Target(METHOD)
@SchedulerLock
public @interface DistributedLock {
@AliasFor(annotation = SchedulerLock.class) String name();
} That way it looks a bit cleaner at the places where it gets declared. |
JFYI We are using shedlock in production without @scheduled annotation, because we have dynamic jobs. Works amazing. |
Thanks for feedback. The workaround with the pseudoanotation is a grat idea. I have to think about it. I do not want to ofically declare that it's possible to use it as a generic "lock". I am afraid that there will be some new edgecases which will force me to bend the library. Morover, I do not know how to call it. It's not a lock. If it's not available, the process does not wait but just skips the execution. Any ideas about the name? |
Having 'TryLock' in the name seems to be the most popular way to convey a lock does not wait. E.g. in java.util.concurrent.locks |
how about skip lock or no wait lock? |
@lukas-krecan |
No, as I understand it |
We are using ShedLock in our projects and like it pretty much.
It's very mature and neatly integrated.
Yesterday I came to the point where I needed a distributed lock in a non
scheduler based context.
The use case is to create database table partitions on startup of an Spring
boot app by a method annotated with
@EventListener(ApplicationStartedEvent.class)
.I know that ShedLock is primarily designed for scheduler based stuff, but I gave
it a shot and tried to use it as a "regular" distributed lock for the
partition creation. What can I say - it worked.
From this situation a few thoughts arise that might end in a feature request
for this project or just documentation stuff, so please forgive me if that is
not a typical Github issue.
These are the points that I am thinking about:
@SchedulerLock
without@Scheduled
@DistributedLock
Sure I could add another framework for providing the distributed lock or
implement something custom in our code base. But why if ShedLock already has
everything in its package? Looking at for example https://github.com/alturkovic/distributed-lock
you can see that it is pretty close to what ShedLock offers but require an
extra lock table if used with JDBC.
I'd rather like to start a discussion upon this to decide whether to actually
add a refined issue. If you see a better place to post this, please tell me.
The text was updated successfully, but these errors were encountered: