2017-03-15 18:31:14 +00:00
---
layout: "docs"
2017-09-13 01:48:52 +00:00
page_title: "Replication - Vault Enterprise"
New Docs Website (#5535)
* conversion stage 1
* correct image paths
* add sidebar title to frontmatter
* docs/concepts and docs/internals
* configuration docs and multi-level nav corrections
* commands docs, index file corrections, small item nav correction
* secrets converted
* auth
* add enterprise and agent docs
* add extra dividers
* secret section, wip
* correct sidebar nav title in front matter for apu section, start working on api items
* auth and backend, a couple directory structure fixes
* remove old docs
* intro side nav converted
* reset sidebar styles, add hashi-global-styles
* basic styling for nav sidebar
* folder collapse functionality
* patch up border length on last list item
* wip restructure for content component
* taking middleman hacking to the extreme, but its working
* small css fix
* add new mega nav
* fix a small mistake from the rebase
* fix a content resolution issue with middleman
* title a couple missing docs pages
* update deps, remove temporary markup
* community page
* footer to layout, community page css adjustments
* wip downloads page
* deps updated, downloads page ready
* fix community page
* homepage progress
* add components, adjust spacing
* docs and api landing pages
* a bunch of fixes, add docs and api landing pages
* update deps, add deploy scripts
* add readme note
* update deploy command
* overview page, index title
* Update doc fields
Note this still requires the link fields to be populated -- this is solely related to copy on the description fields
* Update api_basic_categories.yml
Updated API category descriptions. Like the document descriptions you'll still need to update the link headers to the proper target pages.
* Add bottom hero, adjust CSS, responsive friendly
* Add mega nav title
* homepage adjustments, asset boosts
* small fixes
* docs page styling fixes
* meganav title
* some category link corrections
* Update API categories page
updated to reflect the second level headings for api categories
* Update docs_detailed_categories.yml
Updated to represent the existing docs structure
* Update docs_detailed_categories.yml
* docs page data fix, extra operator page remove
* api data fix
* fix makefile
* update deps, add product subnav to docs and api landing pages
* Rearrange non-hands-on guides to _docs_
Since there is no place for these on learn.hashicorp, we'll put them
under _docs_.
* WIP Redirects for guides to docs
* content and component updates
* font weight hotfix, redirects
* fix guides and intro sidenavs
* fix some redirects
* small style tweaks
* Redirects to learn and internally to docs
* Remove redirect to `/vault`
* Remove `.html` from destination on redirects
* fix incorrect index redirect
* final touchups
* address feedback from michell for makefile and product downloads
2018-10-19 15:40:11 +00:00
sidebar_title: "Replication"
2017-03-16 10:50:33 +00:00
sidebar_current: "docs-vault-enterprise-replication"
2017-03-15 18:31:14 +00:00
description: |-
2017-08-15 02:02:02 +00:00
Vault Enterprise has support for Replication, allowing critical data to be replicated across clusters to support horizontally scaling and disaster recovery workloads.
2017-03-15 18:31:14 +00:00
---
2017-09-13 01:48:52 +00:00
# Vault Enterprise Replication
2017-03-15 18:31:14 +00:00
## Overview
Many organizations have infrastructure that spans multiple datacenters. Vault
provides the critical services of identity management, secrets storage, and
policy management. This functionality is expected to be highly available and
to scale as the number of clients and their functional needs increase; at the
same time, operators would like to ensure that a common set of policies are
enforced globally, and a consistent set of secrets and keys are exposed to
2017-09-13 01:48:52 +00:00
applications that need to interoperate.
2017-03-15 18:31:14 +00:00
2017-09-13 01:48:52 +00:00
Vault replication addresses both of these needs in providing consistency,
scalability, and highly-available disaster recovery.
2017-03-15 18:31:14 +00:00
## Architecture
2017-09-13 01:48:52 +00:00
The core unit of Vault replication is a **cluster** , which is comprised of a
collection of Vault nodes (an active and its corresponding HA nodes). Multiple Vault
2017-08-15 02:02:02 +00:00
clusters communicate in a one-to-many near real-time flow.
2017-03-15 18:31:14 +00:00
2017-09-13 01:48:52 +00:00
Replication operates on a leader/follower model, wherein a leader cluster (known as a
**primary**) is linked to a series of follower **secondary** clusters. The primary
2017-08-15 02:02:02 +00:00
cluster acts as the system of record and asynchronously replicates most Vault data.
2017-03-15 18:31:14 +00:00
All communication between primaries and secondaries is end-to-end encrypted
2017-08-15 02:02:02 +00:00
with mutually-authenticated TLS sessions, setup via replication tokens which are
2017-03-15 18:31:14 +00:00
exchanged during bootstrapping.
2017-08-15 02:02:02 +00:00
What data is replicated between the primary and secondary depends on the type of
replication that is configured between the primary and secondary. These types
of relationships are either **disaster recovery** or **performance**
relationships.
## Performance Replication and Disaster Recovery (DR) Replication
2017-09-13 01:48:52 +00:00
*Performance Replication*:
In performance replication, secondaries keep track of their own tokens and leases
2017-08-15 02:02:02 +00:00
but share the underlying configuration, policies, and supporting secrets (K/V values,
2017-09-13 01:48:52 +00:00
encryption keys for `transit` , etc).
2017-08-15 02:02:02 +00:00
2017-09-13 01:48:52 +00:00
If a user action would modify underlying shared state, the secondary forwards the request
to the primary to be handled; this is transparent to the client. In practice, most
2017-09-20 20:05:00 +00:00
high-volume workloads (reads in the `kv` backend, encryption/decryption operations
2017-08-15 02:02:02 +00:00
in `transit` , etc.) can be satisfied by the local secondary, allowing Vault to scale
2017-09-13 01:48:52 +00:00
relatively horizontally with the number of secondaries rather than vertically as
2017-08-15 02:02:02 +00:00
in the past.
*Disaster Recovery (DR) Replication*:
In disaster recovery (or DR) replication, secondaries share the same underlying configuration,
policy, and supporting secrets (K/V values, encryption keys for `transit` , etc) infrastructure
as the primary. They also share the same token and lease infrastructure as the primary, as
they are designed to allow for continuous operations with applications connecting to the
2017-09-13 01:48:52 +00:00
original primary on the election of the DR secondary.
2017-08-15 02:02:02 +00:00
2017-09-13 01:48:52 +00:00
DR is designed to be a mechanism to protect against catastrophic failure of entire clusters.
They do not forward service read or write requests until they are elected and become a new primary.
2017-08-15 02:02:02 +00:00
| Capability | Disaster Recovery | Performance |
|-------------------------------------------------------------------------------------------------------------------------- |------------------- |-------------------------------------------------------------------------- |
2018-02-08 23:11:00 +00:00
| Mirrors the configuration of a primary cluster | Yes | Yes |
| Mirrors the configuration of a primary cluster’ s backends (i.e.: auth methods, secrets engines, audit devices, etc.) | Yes | Yes |
2018-06-29 13:32:35 +00:00
| Mirrors the tokens and leases for applications and users interacting with the primary cluster | Yes | No. Secondaries keep track of their own tokens and leases. When the secondary is promoted, applications must reauthenticate and obtain new leases from the newly-promoted primary. |
2018-02-08 23:11:00 +00:00
| Allows the secondary cluster to handle client requests | No | Yes |
2017-08-15 02:02:02 +00:00
For more information on the capabilities of performance and disaster recovery replication, see the Vault Replication [API Documentation ](/api/system/replication.html ).
2017-03-15 18:31:14 +00:00
## Internals
Details on the internal design of the replication feature can be found in the
[replication
2017-03-16 19:04:36 +00:00
internals](/docs/internals/replication.html)
2017-03-15 18:31:14 +00:00
document.
## Security Model
Vault is trusted all over the world to keep secrets safe. As such, we have put
extreme focus to detail to our replication model as well.
### Primary/Secondary Communication
When a cluster is marked as the primary it generates a self-signed CA
certificate. On request, and given a user-specified identifier, the primary
uses this CA certificate to generate a private key and certificate and packages
these, along with some other information, into a replication bootstrapping
bundle, a.k.a. a secondary activation token. The certificate is used to perform
TLS mutual authentication between the primary and that secondary.
This CA certificate is never shared with secondaries, and no secondary ever has
access to any other secondary’ s certificate. In practice this means that
revoking a secondary’ s access to the primary does not allow it continue
replication with any other machine; it also means that if a primary goes down,
there is full administrative control over which cluster becomes primary. An
attacker cannot spoof a secondary into believing that a cluster the attacker
controls is the new primary without also being able to administratively direct
the secondary to connect by giving it a new bootstrap package (which is an
ACL-protected call).
Vault makes use of Application Layer Protocol Negotiation on its cluster port.
This allows the same port to handle both request forwarding and replication,
even while keeping the certificate root of trust and feature set different.
### Secondary Activation Tokens
A secondary activation token is an extremely sensitive item and as such is
protected via response wrapping. Experienced Vault users will note that the
wrapping format for replication bootstrap packages is different from normal
response wrapping tokens: it is a signed JWT. This allows the replication token
to carry the redirect address of the primary cluster as part of the token. In
most cases this means that simply providing the token to a new secondary is
enough to activate replication, although this can also be overridden when the
token is provided to the secondary.
Secondary activation tokens should be treated like Vault root tokens. If
disclosed to a bad actor, that actor can gain access to all Vault data. It
should therefore be treated with utmost sensitivity. Like all
response-wrapping tokens, once the token is used successfully (in this case, to
activate a secondary) it is useless, so it is only necessary to safeguard it
from one machine to the next. Like with root tokens, HashiCorp recommends that
when a secondary activation token is live, there are multiple eyes on it from
generation until it is used.
Once a secondary is activated, its cluster information is stored safely behind
its encrypted barrier.
## Setup and Best Practices
2018-02-08 00:29:07 +00:00
A [setup guide ](/guides/operations/replication.html ) is
2017-03-15 18:31:14 +00:00
available to help you get started; this guide also contains best practices
around operationalizing the replication feature.
## API
2017-04-10 13:46:25 +00:00
The Vault replication component has a full HTTP API. Please see the
2017-03-17 18:06:03 +00:00
[Vault Replication API ](/api/system/replication.html ) for more
2017-03-16 18:57:06 +00:00
details.