| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325 | [role="xpack"][[ccr-getting-started-tutorial]]=== Tutorial: Set up {ccr}++++<titleabbrev>Set up {ccr}</titleabbrev>++++////[source,console]----PUT /server-metrics{  "settings" : {    "index" : {      "number_of_shards" : 1,      "number_of_replicas" : 0    }  },  "mappings" : {    "properties" : {      "@timestamp" : {        "type" : "date"      },      "accept" : {        "type" : "long"      },      "deny" : {        "type" : "long"      },      "host" : {        "type" : "keyword"      },      "response" : {        "type" : "float"      },      "service" : {        "type" : "keyword"      },      "total" : {        "type" : "long"      }    }  }}----// TESTSETUP////Use this guide to set up {ccr} (CCR) between clusters in twodatacenters. Replicating your data across datacenters provides several benefits:* Brings data closer to your users or application server to reduce latency andresponse time* Provides your mission-critical applications with the tolerance to withstand datacenter or region outagesIn this guide, you'll learn how to:* Configure a <<remote-clusters,remote cluster>> with a leader index* Create a follower index on a local cluster* Create an auto-follow pattern to automatically follow time series indicesthat are periodically created in a remote clusterYou can manually create follower indices to replicate specific indices on aremote cluster, or configure auto-follow patterns to replicate rolling time series indices.TIP: If you want to replicate data across clusters in the cloud, you canlink:{cloud}/ec-enable-ccs.html[configure remote clusters on {ess}]. Then, youcan <<modules-cross-cluster-search,search across clusters>> and set up {ccr}.[[ccr-getting-started-prerequisites]]==== PrerequisitesTo complete this tutorial, you need:* The `manage` cluster privilege on the local cluster.* A license on both clusters that includes {ccr}. {kibana-ref}/managing-licenses.html[Activate a free 30-day trial].* An index on the remote cluster that contains the data you want to replicate.This tutorial uses the sample eCommerce orders data set.{kibana-ref}/get-started.html#gs-get-data-into-kibana[Load sample data].* In the local cluster, all nodes with the `master` <<node-roles,node role>> mustalso have the <<remote-node,`remote_cluster_client`>> role. The local clustermust also have at least one node with both a data role and the<<remote-node,`remote_cluster_client`>> role. Individual tasks for coordinatingreplication scale based on the number of data nodes with the`remote_cluster_client` role in the local cluster.==== Connect to a remote clusterTo replicate an index on a remote cluster (Cluster A) to a local cluster (Cluster B), you configure Cluster A as a remote on Cluster B.image::images/ccr-tutorial-clusters.png[ClusterA contains the leader index and ClusterB contains the follower index]To configure a remote cluster from Stack Management in {kib}:. Select *Remote Clusters* from the side navigation.. Specify the {es} endpoint URL, or the IP address or host name of the remotecluster (`ClusterA`) followed by the transport port (defaults to `9300`). Forexample, `cluster.es.eastus2.staging.azure.foundit.no:9400` or`192.168.1.1:9300`.[%collapsible%open].API example====You can also use the <<cluster-update-settings,cluster update settings API>> toadd a remote cluster:[source,console]----PUT /_cluster/settings{  "persistent" : {    "cluster" : {      "remote" : {        "leader" : {          "seeds" : [            "127.0.0.1:9300" <1>          ]        }      }    }  }}----// TEST[setup:host]// TEST[s/127.0.0.1:9300/\${transport_host}/]<1> Specifies the hostname and transport port of a seed node in the remote    cluster.You can verify that the local cluster is successfully connected to the remotecluster.[source,console]----GET /_remote/info----// TEST[continued]The API response indicates that the local cluster is connected to the remotecluster with cluster alias `leader`.[source,console-result]----{  "leader" : {    "seeds" : [      "127.0.0.1:9300"    ],    "connected" : true,    "num_nodes_connected" : 1, <1>    "max_connections_per_cluster" : 3,    "initial_connect_timeout" : "30s",    "skip_unavailable" : false,    "mode" : "sniff"  }}----// TESTRESPONSE[s/127.0.0.1:9300/$body.leader.seeds.0/]// TEST[s/"connected" : true/"connected" : $body.leader.connected/]// TEST[s/"num_nodes_connected" : 1/"num_nodes_connected" : $body.leader.num_nodes_connected/]<1> The number of nodes in the remote cluster the local cluster is    connected to.====include::../../../x-pack/docs/en/security/authentication/remote-clusters-privileges-cert.asciidoc[tag=configure-ccr-privileges][[ccr-getting-started-follower-index]]==== Create a follower index to replicate a specific indexWhen you create a follower index, you reference the remote cluster and theleader index in your remote cluster.To create a follower index from Stack Management in {kib}:. Select *Cross-Cluster Replication* in the side navigation and choose the*Follower Indices* tab.. Choose the cluster (ClusterA) containing the leader index you want toreplicate.. Enter the name of the leader index, which is`kibana_sample_data_ecommerce` if you are following the tutorial.. Enter a name for your follower index, such as `follower-kibana-sample-data`.{es} initializes the follower using the<<ccr-remote-recovery, remote recovery>>process, which transfers the existing Lucene segment files from the leaderindex to the follower index. The index status changes to *Paused*. When theremote recovery process is complete, the index following begins and the statuschanges to *Active*.When you index documents into your leader index, {es} replicates the documentsin the follower index.[role="screenshot"]image::images/ccr-follower-index.png["The Cross-Cluster Replication page in {kib}"][%collapsible%open].API example====You can also use the <<ccr-put-follow,create follower API>> to create followerindices. When you create a follower index, you must reference the remote clusterand the leader index that you created in the remote cluster.When initiating the follower request, the response returns before the<<ccr-remote-recovery, remote recovery>> process completes. To wait for the processto complete, add the `wait_for_active_shards` parameter to your request.[source,console]----PUT /server-metrics-follower/_ccr/follow?wait_for_active_shards=1{  "remote_cluster" : "leader",  "leader_index" : "server-metrics"}----// TEST[continued]//////////////////////////[source,console-result]--------------------------------------------------{  "follow_index_created" : true,  "follow_index_shards_acked" : true,  "index_following_started" : true}--------------------------------------------------//////////////////////////Use the<<ccr-get-follow-stats,get follower stats API>> to inspect the status ofreplication.//////////////////////////[source,console]--------------------------------------------------POST /server-metrics-follower/_ccr/pause_followPOST /server-metrics-follower/_closePOST /server-metrics-follower/_ccr/unfollow--------------------------------------------------// TEST[continued]//////////////////////////====[[ccr-getting-started-auto-follow]]==== Create an auto-follow pattern to replicate time series indicesYou use <<ccr-auto-follow,auto-follow patterns>> to automatically create newfollowers for rolling time series indices. Whenever the name of a new index onthe remote cluster matches the auto-follow pattern, a corresponding followerindex is added to the local cluster. Note that only indices created on theremote cluster after the auto-follow pattern is created will be auto-followed:existing indices on the remote cluster are ignored even if they match the pattern.An auto-follow pattern specifies the remote cluster you want to replicate from,and one or more index patterns that specify the rolling time series indices youwant to replicate.// tag::ccr-create-auto-follow-pattern-tag[]To create an auto-follow pattern from Stack Management in {kib}:. Select *Cross Cluster Replication* in the side navigation and choose the*Auto-follow patterns* tab.. Enter a name for the auto-follow pattern, such as `beats`.. Choose the remote cluster that contains the index you want to replicate,which in the example scenario is Cluster A.. Enter one or more index patterns that identify the indices you want toreplicate from the remote cluster. For example, enter`metricbeat-* packetbeat-*` to automatically create followers for {metricbeat} and {packetbeat} indices.. Enter *follower-* as the prefix to apply to the names of the follower indices soyou can more easily identify replicated indices.As new indices matching these patterns arecreated on the remote, {es} automatically replicates them to local follower indices.[role="screenshot"]image::images/auto-follow-patterns.png["The Auto-follow patterns page in {kib}"]// end::ccr-create-auto-follow-pattern-tag[][%collapsible%open].API example====Use the <<ccr-put-auto-follow-pattern,create auto-follow pattern API>> toconfigure auto-follow patterns.[source,console]----PUT /_ccr/auto_follow/beats{  "remote_cluster" : "leader",  "leader_index_patterns" :  [    "metricbeat-*", <1>    "packetbeat-*" <2>  ],  "follow_index_pattern" : "{{leader_index}}-copy" <3>}----// TEST[continued]<1> Automatically follow new {metricbeat} indices.<2> Automatically follow new {packetbeat} indices.<3> The name of the follower index is derived from the name of the leader index    by adding the suffix `-copy` to the name of the leader index.//////////////////////////[source,console-result]--------------------------------------------------{  "acknowledged" : true}--------------------------------------------------////////////////////////////////////////////////////[source,console]--------------------------------------------------DELETE /_ccr/auto_follow/beats--------------------------------------------------// TEST[continued]//////////////////////////====
 |