2015-01-19 16:43:38 -10:00
---
layout: "docs"
page_title: "Commands: Lock"
sidebar_current: "docs-commands-lock"
description: |-
2015-01-21 17:35:06 -08:00
The lock command provides a mechanism for leader election, mutual exclusion, or worker pools. For example, this can be used to ensure a maximum number of services running at once across a cluster.
2015-01-19 16:43:38 -10:00
---
# Consul Lock
Command: `consul lock`
The `lock` command provides a mechanism for simple distributed locking.
A lock (or semaphore) is created at a given prefix in the Key/Value store,
and only when held, is a child process invoked. If the lock is lost or
2015-01-25 11:42:26 +01:00
communication is disrupted, the child process is terminated.
2015-01-19 16:43:38 -10:00
2015-01-25 11:42:26 +01:00
The number of lock holders is configurable with the `-n` flag. By default,
2015-01-19 16:43:38 -10:00
a single holder is allowed, and a lock is used for mutual exclusion. This
uses the [leader election algorithm ](/docs/guides/leader-election.html ).
If the lock holder count is more than one, then a semaphore is used instead.
2015-06-01 08:34:54 -05:00
A semaphore allows more than a single holder, but this is less efficient than
2015-01-19 16:43:38 -10:00
a simple lock. This follows the [semaphore algorithm ](/docs/guides/semaphore.html ).
2015-01-23 22:11:15 +01:00
All locks using the same prefix must agree on the value of `-n` . If conflicting
2015-01-21 17:35:06 -08:00
values of `-n` are provided, an error will be returned.
2015-01-19 16:43:38 -10:00
An example use case is for highly-available N+1 deployments. In these
cases, if N instances of a service are required, N+1 are deployed and use
consul lock with `-n=N` to ensure only N instances are running. For singleton
services, a hot standby waits until the current leader fails to take over.
## Usage
Usage: `consul lock [options] prefix child...`
The only required options are the key prefix and the command to execute.
The prefix must be writable. The child is invoked only when the lock is held,
and the `CONSUL_LOCK_HELD` environment variable will be set to `true` .
2015-01-25 11:42:26 +01:00
If the lock is lost, communication is disrupted, or the parent process
2015-05-28 12:24:32 -07:00
interrupted, the child process will receive a `SIGTERM` . After a grace period
of 5 seconds, a `SIGKILL` will be used to force termination. For Consul agents
on Windows, the child process is always terminated with a `SIGKILL` , since
Windows has no POSIX compatible notion for `SIGTERM` .
2015-01-19 16:43:38 -10:00
The list of available flags are:
* `-http-addr` - Address to the HTTP server of the agent you want to contact
to send this command. If this isn't specified, the command will contact
"127.0.0.1:8500" which is the default HTTP address of a Consul agent.
* `-n` - Optional, limit of lock holders. Defaults to 1. The underlying
implementation switches from a lock to a semaphore when increased past
2015-01-21 17:35:06 -08:00
one. All locks on the same prefix must use the same value.
2015-01-19 16:43:38 -10:00
* `-name` - Optional name to associate with the underlying session.
If not provided, one is generated based on the child command.
* `-token` - ACL token to use. Defaults to that of agent.
2015-09-01 11:00:26 +09:00
* `-pass-stdin` - Pass stdin to child process.
2016-01-06 09:40:20 -08:00
* `-try` - Attempt to acquire the lock up to the given timeout. The timeout is a
positive decimal number, with unit suffix, such as "500ms". Valid time units
are "ns", "us" (or "µs"), "ms", "s", "m", "h".
2016-01-05 16:40:35 -08:00
2016-01-05 17:59:58 -08:00
* `-monitor-retry` - Retry up to this number of times if Consul returns a 500 error
while monitoring the lock. This allows riding out brief periods of unavailability
without causing leader elections, but increases the amount of time required
2016-01-05 18:34:22 -08:00
to detect a lost lock in some cases. Defaults to 3, with a 1s wait between retries.
Set to 0 to disable.
2016-01-05 17:59:58 -08:00
2015-01-19 16:43:38 -10:00
* `-verbose` - Enables verbose output.
2016-06-03 17:01:05 -07:00
## SHELL
Consul lock launches its children in a shell. By default, Consul will use the shell
defined in the environment variable `SHELL` . If `SHELL` is not defined, it will
default to `/bin/sh` . It should be noted that not all shells terminate child
processes when they receive `SIGTERM` . Under Ubuntu, `/bin/sh` is linked to `dash` ,
which does **not** terminate its children. In order to ensure that child processes
are killed when the lock is lost, be sure to set the `SHELL` environment variable
appropriately.