Repair - a process that runs in the background and synchronizes the data between nodes.
nodetool repair on a single node, it acts as the repair master. Only the data contained in the master node, and its replications, will be repaired.
Typically, this subset of data is replicated on many nodes in the cluster, often all, and the repair process syncs between all the replicas, until the master data subset is in-sync.
To repair all of the data in the cluster, you need to run a repair on all of the nodes in the cluster, or let Scylla Manager do it for you.
Run the nodetool repair command regularly. If you delete data frequently, it should be more often than the value of
gc_grace_seconds (by default: 10 days), for example, every week. Use the nodetool repair -pr on each node in the cluster, sequentially.
Scylla nodetool repair command supports the following options:
--in-dcsyncs the repair master data subset between all nodes in one Data Center (DC). The DC must be the repair master DC.
this command leaves part of the data subset (all remaining DCs) out of sync.
For example:nodetool repair -dc US_DC nodetool repair --in-dc US_DC
--end-tokenexecutes a repair on the specified node/s starting with the first token and ending with the specified UUID token.
nodetool repair -et 90874935784 nodetool repair --end-token 90874935784
--in-hostssyncs the repair master data subset only between a list of nodes, using host ID or Address. The list must include the repair master.
this command leaves part of the data subset (on nodes that are not listed) out of sync.
nodetool repair -hosts 172.17.0.2,172.17.0.3,172.17.0.4 nodetool repair --in-hosts 172.17.0.2,172.17.0.3,172.17.0.4 nodetool repair --in-hosts cdc295d7-c076-4b07-af69-1385fefdb40b,2dbdf288-9e73-11ea-bb37-0242ac130002,3a5993f8-9e73-11ea-bb37-0242ac130002
--in-local-dcexecutes a repair on the nodes in the local datacenter only .
nodetool repair -local nodetool repair --in-local-dc
--partitioner-rangeexecutes a repair only on the primary replica returned by the partitioner.
nodetool repair -pr nodetool repair --partitioner-range
--start-tokenexecutes a repair on a range of node/s starting with the start token (the token specified).
nodetool repair -st 10474535988 nodetool repair --start-token
keyspaceexecutes a repair on a specific keyspace. The default is all keyspaces.
nodetool repair <my_keyspace>
tableexecutes a repair on a specific table or a list of space-delimited table names. The default is all tables.
nodetool repair <my_keyspace> <my_table>