2016-09-26 10:12:29 -05:00
|
|
|
---
|
2020-09-01 10:14:13 -05:00
|
|
|
layout: commands
|
2020-04-07 14:55:19 -04:00
|
|
|
page_title: 'Commands: KV Put'
|
2023-01-26 12:42:13 -06:00
|
|
|
description: >-
|
|
|
|
The `consul kv put` command writes data to Consul's key/value store.
|
2016-09-26 10:12:29 -05:00
|
|
|
---
|
|
|
|
|
|
|
|
# Consul KV Put
|
|
|
|
|
|
|
|
Command: `consul kv put`
|
|
|
|
|
2023-01-25 10:52:43 -06:00
|
|
|
Corresponding HTTP API Endpoint: [\[PUT\] /v1/kv/:key](/consul/api-docs/kv#create-update-key)
|
2022-01-10 12:40:11 -05:00
|
|
|
|
2017-04-04 12:33:22 -04:00
|
|
|
The `kv put` command writes the data to the given path in the KV store.
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 15:53:41 +00:00
|
|
|
-> **Note**: When writing multiple entries at once, consider using
|
2023-01-25 10:52:43 -06:00
|
|
|
[`kv import`](/consul/commands/kv/import) instead. Alternatively, the
|
|
|
|
[transaction API](/consul/api-docs/txn) provides support for performing up to
|
2022-01-10 12:30:28 +00:00
|
|
|
64 KV operations atomically.
|
|
|
|
|
2023-01-25 10:52:43 -06:00
|
|
|
The table below shows this command's [required ACLs](/consul/api-docs/api-structure#authentication). Configuration of
|
|
|
|
[blocking queries](/consul/api-docs/features/blocking) and [agent caching](/consul/api-docs/features/caching)
|
2022-01-10 16:44:56 -05:00
|
|
|
are not supported from commands, but may be from the corresponding HTTP endpoint.
|
|
|
|
|
|
|
|
| ACL Required |
|
|
|
|
| ------------ |
|
|
|
|
| `key:write` |
|
|
|
|
|
2016-09-26 10:12:29 -05:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
Usage: `consul kv put [options] KEY [DATA]`
|
|
|
|
|
2022-07-26 23:17:11 -07:00
|
|
|
#### Command Options
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-acquire` - Obtain a lock on the key. If the key does not exist, this
|
2016-09-26 10:12:29 -05:00
|
|
|
operation will create the key and obtain the lock. The session must already
|
|
|
|
exist and be specified via the -session flag. The default value is false.
|
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-base64` - Treat the data as base 64 encoded. The default value is false.
|
2017-01-04 16:05:08 -06:00
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-cas` - Perform a Check-And-Set operation. Specifying this value also
|
2016-09-26 16:15:27 -07:00
|
|
|
requires the -modify-index flag to be set. The default value is false.
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-flags=<int>` - Unsigned integer value to assign to this KV pair. This
|
2016-09-26 10:12:29 -05:00
|
|
|
value is not read by Consul, so clients can use this value however makes sense
|
|
|
|
for their use case. The default value is 0 (no flags).
|
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-modify-index=<int>` - Unsigned integer representing the ModifyIndex of the
|
2016-09-26 16:06:32 -07:00
|
|
|
key. This is used in combination with the -cas flag.
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-release` - Forfeit the lock on the key at the given path. This requires the
|
2016-09-26 10:12:29 -05:00
|
|
|
-session flag to be set. The key must be held by the session in order to be
|
|
|
|
unlocked. The default value is false.
|
|
|
|
|
2020-04-07 14:55:19 -04:00
|
|
|
- `-session=<string>` - User-defined identifier for this session as a string.
|
2016-09-26 10:12:29 -05:00
|
|
|
This is commonly used with the -acquire and -release operations to build
|
|
|
|
robust locking, but it can be set on any key. The default value is empty (no
|
|
|
|
session).
|
|
|
|
|
2022-07-26 23:17:11 -07:00
|
|
|
#### Enterprise Options
|
|
|
|
|
|
|
|
@include 'http_api_partition_options.mdx'
|
|
|
|
|
|
|
|
@include 'http_api_namespace_options.mdx'
|
|
|
|
|
|
|
|
#### API Options
|
|
|
|
|
|
|
|
@include 'http_api_options_client.mdx'
|
|
|
|
|
|
|
|
@include 'http_api_options_server.mdx'
|
|
|
|
|
2016-09-26 10:12:29 -05:00
|
|
|
## Examples
|
|
|
|
|
|
|
|
To insert a value of "5" for the key named "redis/config/connections" in the
|
2017-04-04 12:33:22 -04:00
|
|
|
KV store:
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv put redis/config/connections 5
|
|
|
|
Success! Data written to: redis/config/connections
|
|
|
|
```
|
|
|
|
|
|
|
|
If no data is specified, the key will be created with empty data:
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv put redis/config/connections
|
|
|
|
Success! Data written to: redis/config/connections
|
|
|
|
```
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
!> **Be careful of overwriting data!** The above operation would overwrite
|
|
|
|
any existing value at the key to the empty value.
|
2022-01-10 11:40:25 +00:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
### Base64 Encoded Values
|
2017-01-04 16:05:08 -06:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
If the `-base64` flag is set, the given data will be Base64-decoded before writing:
|
2017-01-04 16:05:08 -06:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2017-01-04 16:05:08 -06:00
|
|
|
$ consul kv put -base64 foo/encoded aGVsbG8gd29ybGQK
|
|
|
|
Success! Data written to: foo/encoded
|
|
|
|
```
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
### Longer or Sensitive Values
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
For longer or sensitive values, it is possible to read from a file by
|
|
|
|
supplying its path prefixed with the `@` symbol:
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv put redis/config/password @password.txt
|
2022-01-10 12:15:59 +00:00
|
|
|
Success! Data written to: redis/config/password
|
2016-09-26 10:12:29 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
Or read values from stdin by specifying the `-` symbol:
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
|
|
|
$ echo "5" | consul kv put redis/config/connections -
|
2016-09-26 10:12:29 -05:00
|
|
|
Success! Data written to: redis/config/connections
|
2022-01-10 12:15:59 +00:00
|
|
|
```
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
|
|
|
$ consul kv put redis/config/connections -
|
2016-09-26 10:12:29 -05:00
|
|
|
5
|
|
|
|
<CTRL+D>
|
|
|
|
Success! Data written to: redis/config/connections
|
|
|
|
```
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
|
|
|
$ consul kv put leaderboard/scores - <<EOF
|
|
|
|
{
|
|
|
|
"user-a": 100,
|
|
|
|
"user-b": 250,
|
|
|
|
"user-c": 75
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
Success! Data written to: leaderboard/scores
|
|
|
|
```
|
|
|
|
|
2022-01-10 15:53:41 +00:00
|
|
|
~> **Warning**: For secret and sensitive values, you should consider using a
|
2023-01-25 10:52:43 -06:00
|
|
|
secret management solution like **[HashiCorp's Vault](/vault/tutorials/secrets-management/static-secrets)**.
|
2022-01-20 08:54:23 -08:00
|
|
|
While it is possible to encrypt data before writing it to Consul's KV store,
|
2022-01-10 12:15:59 +00:00
|
|
|
Consul provides no built-in support for encryption at-rest.
|
|
|
|
|
|
|
|
### Atomic Check-And-Set (CAS)
|
2016-09-26 10:12:29 -05:00
|
|
|
|
|
|
|
To only update a key if it has not been modified since a given index, specify
|
|
|
|
the `-cas` and `-modify-index` flags:
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv get -detailed redis/config/connections | grep ModifyIndex
|
|
|
|
ModifyIndex 456
|
|
|
|
|
|
|
|
$ consul kv put -cas -modify-index=123 redis/config/connections 10
|
|
|
|
Error! Did not write to redis/config/connections: CAS failed
|
|
|
|
|
|
|
|
$ consul kv put -cas -modify-index=456 redis/config/connections 10
|
|
|
|
Success! Data written to: redis/config/connections
|
|
|
|
```
|
|
|
|
|
2022-01-10 15:53:41 +00:00
|
|
|
### Locking Primitives
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2016-11-25 11:00:02 -05:00
|
|
|
To create or tune a lock, use the `-acquire` and `-session` flags. The session must already exist (this command will not create it or manage it):
|
2016-09-26 10:12:29 -05:00
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv put -acquire -session=abc123 redis/lock/update
|
|
|
|
Success! Lock acquired on: redis/lock/update
|
|
|
|
```
|
|
|
|
|
|
|
|
When you are finished, release the lock:
|
|
|
|
|
2022-01-10 12:15:59 +00:00
|
|
|
```shell-session hideClipboard
|
2016-09-26 10:12:29 -05:00
|
|
|
$ consul kv put -release -session=acb123 redis/lock/update
|
|
|
|
Success! Lock released on: redis/lock/update
|
|
|
|
```
|
|
|
|
|
|
|
|
~> **Warning!** If you are trying to build a locking mechanism with these
|
|
|
|
low-level primitives, you may want to look at the [<tt>consul
|
2023-01-25 10:52:43 -06:00
|
|
|
lock</tt>](/consul/commands/lock) command. It provides higher-level
|
2016-09-26 10:12:29 -05:00
|
|
|
functionality without exposing the internal APIs of Consul.
|
2022-01-10 12:15:59 +00:00
|
|
|
|
|
|
|
### Flags
|
|
|
|
|
|
|
|
To set user-defined flags on the entry, use the `-flags` option. These flags
|
|
|
|
are completely controlled by the user and have no special meaning to Consul:
|
|
|
|
|
|
|
|
```shell-session hideClipboard
|
|
|
|
$ consul kv put -flags=42 redis/config/password s3cr3t
|
|
|
|
Success! Data written to: redis/config/password
|
|
|
|
```
|