2014-04-10 17:41:49 -07:00
---
layout: "intro"
page_title: "Key/Value Data"
sidebar_current: "gettingstarted-kv"
2014-10-19 19:40:10 -04:00
description: |-
2015-03-18 10:49:41 -04:00
In addition to providing service discovery and integrated health checking, Consul provides an easy to use Key/Value store. This can be used to hold dynamic configuration, assist in service coordination, build leader election, and enable anything else a developer can think to build.
2014-04-10 17:41:49 -07:00
---
# Key/Value Data
2014-04-10 19:27:48 -07:00
In addition to providing service discovery and integrated health checking,
Consul provides an easy to use Key/Value store. This can be used to hold
dynamic configuration, assist in service coordination, build leader election,
2015-03-18 10:49:41 -04:00
and enable anything else a developer can think to build.
2014-04-14 14:05:27 -07:00
2015-03-18 10:49:41 -04:00
This step assumes you have at least one Consul agent already running.
2014-04-10 19:27:48 -07:00
## Simple Usage
To demonstrate how simple it is to get started, we will manipulate a few keys
2014-04-14 14:05:27 -07:00
in the K/V store.
2014-04-10 19:27:48 -07:00
2015-03-18 10:49:41 -04:00
Querying the local agent we started in the [Run the Agent step ](agent.html ),
we can first verify that there are no existing keys in the k/v store:
2014-04-10 19:27:48 -07:00
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:27:48 -07:00
$ curl -v http://localhost:8500/v1/kv/?recurse
* About to connect() to localhost port 8500 (#0 )
* Trying 127.0.0.1... connected
> GET /v1/kv/?recurse HTTP/1.1
> User-Agent: curl/7.22.0 (x86_64-pc-linux-gnu) libcurl/7.22.0 OpenSSL/1.0.1 zlib/1.2.3.4 libidn/1.23 librtmp/2.3
> Host: localhost:8500
> Accept: */*
>
< HTTP / 1 . 1 404 Not Found
< X-Consul-Index: 1
< Date: Fri , 11 Apr 2014 02:10:28 GMT
< Content-Length: 0
< Content-Type: text / plain ; charset = utf-8
<
* Connection #0 to host localhost left intact
* Closing connection #0
```
2015-03-18 10:49:41 -04:00
Since there are no keys, we get a 404 response back. Now, we can `PUT` a
few example keys:
2014-04-10 19:27:48 -07:00
```
$ curl -X PUT -d 'test' http://localhost:8500/v1/kv/web/key1
true
$ curl -X PUT -d 'test' http://localhost:8500/v1/kv/web/key2?flags=42
true
$ curl -X PUT -d 'test' http://localhost:8500/v1/kv/web/sub/key3
true
$ curl http://localhost:8500/v1/kv/?recurse
[{"CreateIndex":97,"ModifyIndex":97,"Key":"web/key1","Flags":0,"Value":"dGVzdA=="},
{"CreateIndex":98,"ModifyIndex":98,"Key":"web/key2","Flags":42,"Value":"dGVzdA=="},
{"CreateIndex":99,"ModifyIndex":99,"Key":"web/sub/key3","Flags":0,"Value":"dGVzdA=="}]
```
2014-04-14 14:05:27 -07:00
Here we have created 3 keys, each with the value of "test". Note that the
2015-03-18 10:49:41 -04:00
`Value` field returned is base64 encoded to allow non-UTF8 characters. For the
key "web/key2", we set a `flag` value of 42. All keys support setting a 64-bit
integer flag value. This is not used internally by Consul, but it can be used by
clients to add meaningful metadata to any KV.
2014-04-14 14:05:27 -07:00
2015-03-18 10:49:41 -04:00
After setting the values, we then issued a `GET` request to retrieve multiple
2014-04-14 14:05:27 -07:00
keys using the `?recurse` parameter.
2014-04-10 19:27:48 -07:00
2014-04-14 14:05:27 -07:00
You can also fetch a single key just as easily:
2014-04-10 19:27:48 -07:00
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:27:48 -07:00
$ curl http://localhost:8500/v1/kv/web/key1
[{"CreateIndex":97,"ModifyIndex":97,"Key":"web/key1","Flags":0,"Value":"dGVzdA=="}]
```
2015-03-18 10:49:41 -04:00
Deleting keys is simple as well, accomplished by using the `DELETE` verb. We can
delete a single key by specifying the full path, or we can recursively delete all
keys under a root using "?recurse":
2014-04-10 19:27:48 -07:00
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:27:48 -07:00
$ curl -X DELETE http://localhost:8500/v1/kv/web/sub?recurse
$ curl http://localhost:8500/v1/kv/web?recurse
[{"CreateIndex":97,"ModifyIndex":97,"Key":"web/key1","Flags":0,"Value":"dGVzdA=="},
{"CreateIndex":98,"ModifyIndex":98,"Key":"web/key2","Flags":42,"Value":"dGVzdA=="}]
```
2015-03-18 10:49:41 -04:00
A key can be modified by issuing a `PUT` request to the same URI and
providing a different message body. Additionally, Consul provides a
Check-And-Set operation, enabling atomic key updates. This is done by
providing the `?cas=` parameter with the last `ModifyIndex` value from
the GET request. For example, suppose we wanted to update "web/key1":
2014-04-10 19:27:48 -07:00
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:27:48 -07:00
$ curl -X PUT -d 'newval' http://localhost:8500/v1/kv/web/key1?cas=97
true
$ curl -X PUT -d 'newval' http://localhost:8500/v1/kv/web/key1?cas=97
false
```
2015-03-18 10:49:41 -04:00
In this case, the first CAS update succeeds because the `ModifyIndex` is 97.
2014-04-10 19:27:48 -07:00
However the second operation fails because the `ModifyIndex` is no longer 97.
We can also make use of the `ModifyIndex` to wait for a key's value to change.
For example, suppose we wanted to wait for key2 to be modified:
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:27:48 -07:00
$ curl "http://localhost:8500/v1/kv/web/key2?index=101& wait=5s"
[{"CreateIndex":98,"ModifyIndex":101,"Key":"web/key2","Flags":42,"Value":"dGVzdA=="}]
```
2015-03-18 10:49:41 -04:00
By providing "?index=", we are asking to wait until the key has a `ModifyIndex` greater
2014-04-10 19:27:48 -07:00
than 101. However the "?wait=5s" parameter restricts the query to at most 5 seconds,
returning the current, unchanged value. This can be used to efficiently wait for
key modifications. Additionally, this same technique can be used to wait for a list
of keys, waiting only until any of the keys has a newer modification time.
2015-03-18 10:49:41 -04:00
## Next Steps
These are only a few examples of what the API supports. For full documentation, please
see [the /kv/ route of the HTTP API ](/docs/agent/http/kv.html ).
Next, we will look at the [web UI ](ui.html ) options supported by Consul.