Home > docs > plugins v1 > Lock Task
The lock
and unlock
tasks provide methods to allow exclusive execution between
one or more running Concord processes.
To be able to use the task in a Concord flow, it must be added as a dependency:
configuration:
dependencies:
- mvn://com.walmartlabs.concord.plugins.basic:lock-tasks:2.14.0
This adds the task to the classpath and allows you to invoke it in any flow.
name
- string, lock name used across processes to match exclusivityscope
- string, scope to apply exclusivity. One of PROJECT
, ORG
Acquire a lock in order to execute mutually exclusive steps across individual processes across a Concord Project or Organization. For example, deployments to a particular environment may need to be blocked while an existing deployment or integration testing is active.
# acquire lock so it's safe to deploy
- "${lock.lock('my-app-deployment', 'PROJECT')}"
# perform the deployment...
# release lock
- "${lock.unlock('my-app-deployment', 'PROJECT')}"
If the process does not immediately acquire a lock, then it suspends execution
until the lock is acquired. Temporary files in the working directory created at
runtime are cleaned up when processes suspend and resume. If set,
suspendTimeout
settings apply.
Exclusive process configuration
is preferable to locking at runtime due to the more straightforward application
of exclusivity. The lock
task enables mutual exclusivity across disparate
workflow repositories.