Skip to content

Commit

Permalink
Readme updated
Browse files Browse the repository at this point in the history
  • Loading branch information
lukas-krecan committed Jan 13, 2025
1 parent d21fdbc commit 47d0d0c
Showing 1 changed file with 6 additions and 5 deletions.
11 changes: 6 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -113,14 +113,15 @@ public void scheduledTask() {
1. Only methods annotated by `@SchedulerLock` are locked, the library ignores all other scheduled tasks. By default, the lock will be applied
even if the method is called directly, not only thorough the scheduler.
2. Only one task with the same name can be executed at the same time.
3. The lock is released as soon as the task is finished (unless `lockAtLeastFor` is specified, see below)
4. If the JVM crashes before the task finishes, `lockAtMostFor` attribute comes to play. The lock is always released after
3. If the lock is being held by a task, **other tasks protected by the same lock are not blocked, but are simply skipped.**
4. The lock is released as soon as the task is finished (unless `lockAtLeastFor` is specified, see below)
5. If the JVM crashes before the task finishes, `lockAtMostFor` attribute comes to play. The lock is always released after
`lockAtMostFor`. **You have to set `lockAtMostFor` to a value which is much longer than normal execution time.** If the task takes longer than
`lockAtMostFor` the resulting behavior may be unpredictable (more than one process will effectively hold the lock).
5. If you don't specify `lockAtMostFor` in `@SchedulerLock`, the default value from `@EnableSchedulerLock` will be used.
6. You can set `lockAtLeastFor` attribute which specifies minimum amount of time for which the lock should be kept.
6. If you don't specify `lockAtMostFor` in `@SchedulerLock`, the default value from `@EnableSchedulerLock` will be used.
7. You can set `lockAtLeastFor` attribute which specifies minimum amount of time for which the lock should be kept.
Its main purpose is to prevent execution from multiple nodes in case of really short tasks and clock difference between the nodes.
7. All the annotations support Spring Expression Language (SpEL).
8. All the annotations support Spring Expression Language (SpEL).

#### Example
Let's say you have a task which you execute every 15 minutes and which usually takes few minutes to run.
Expand Down

0 comments on commit 47d0d0c

Please sign in to comment.