From bc6fddc9d5b7cc92ec6b0074ee9ab19ee999d675 Mon Sep 17 00:00:00 2001 From: qupeng Date: Fri, 22 May 2020 14:46:06 +0800 Subject: [PATCH 1/4] update tikv-ctl doc Signed-off-by: qupeng --- tikv-control.md | 23 +++++++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/tikv-control.md b/tikv-control.md index 55a52e9a08e9..555c7ba48dd7 100644 --- a/tikv-control.md +++ b/tikv-control.md @@ -8,7 +8,7 @@ aliases: ['/docs-cn/dev/reference/tools/tikv-control/'] TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 TiKV 集群。 -编译 TiKV 的同时也会编译 tikv-ctl 命令。如果通过 Ansible 部署集群,则对应的 `tidb-ansible/resources/bin` 目录下会存在 `tikv-ctl` 二进制文件。如果使用二进制文件部署集群,bin 目录下会包含 `tikv-ctl` 文件及 `tidb-server`、`pd-server`、以及 `tikv-server` 等其他文件。 +编译 TiKV 的同时也会编译 tikv-ctl 命令。如果通过 Ansible 部署集群,则对应的 `tidb-ansible/resources/bin` 目录下会存在 `tikv-ctl` 二进制文件。 ## 通用参数 @@ -192,9 +192,11 @@ success! `compact-cluster` 命令可以对整个 TiKV 集群进行手动 compact。该命令参数的含义和使用与 `compact` 命令一样。 -### 设置一个 Region 为 tombstone +### 设置一个 Region 副本为 tombstone -`tombstone` 命令常用于没有开启 sync-log,因为机器掉电导致 Raft 状态机丢失部分写入的情况。它可以在一个 TiKV 实例上将一些 Region 设置为 Tombstone 状态,从而在重启时跳过这些 Region。这些 Region 应该在其他 TiKV 上有足够多的健康的副本以便能够继续通过 Raft 机制进行读写。 +`tombstone` 命令常用于没有开启 sync-log,因为机器掉电导致 Raft 状态机丢失部分写入的情况。它可以在一个 TiKV 实例上将一些 Region 的副本设置为 Tombstone 状态,从而在重启时跳过这些 Region,避免因为这些 Region 的副本的 Raft 状态机损坏而无法启动服务。这些 Region 应该在其他 TiKV 上有足够多的健康的副本以便能够继续通过 Raft 机制进行读写。 + +一般情况下,我们可以先在 PD 上将 Region 的副本通过 remove-peer 命令删除掉: {{< copyable "" >}} @@ -202,6 +204,8 @@ success! pd-ctl>> operator add remove-peer ``` +然后再用 tikv-ctl 在那个 TiKV 实例上将 Region 的副本标记为 tombstone 以便跳过启动时对他的健康检查: + {{< copyable "shell-regular" >}} ```shell @@ -212,10 +216,21 @@ tikv-ctl --db /path/to/tikv/db tombstone -p 127.0.0.1:2379 -r success! ``` +但是有些情况下,当不能方便地从 PD 上移除这个副本时,可以指定 tikv-ctl 的 --force 选项来强制设置它为 tombstone: + +```shell +tikv-ctl --db /path/to/tikv/db tombstone -p 127.0.0.1:2379 -r , --force +``` + +``` +success! +``` + + > **注意:** > > - **该命令只支持本地模式** -> - `-p` 选项的参数指定 PD 的 endpoints,无需 `http` 前缀。指定 PD 的 endpoints 是为了询问 PD 是否可以安全切换至 Tombstone 状态。因此,在将 PD 置为 Tombstone 之前往往还需要在 `pd-ctl` 中把该 Region 在机器上的对应 Peer 拿掉。 +> - `-p` 选项的参数指定 PD 的 endpoints,无需 `http` 前缀。指定 PD 的 endpoints 是为了询问 PD 是否可以安全切换至 Tombstone 状态。 ### 向 TiKV 发出 consistency-check 请求 From 23f5b52ecaaf5dc6dadf2f550fde53b722eafe43 Mon Sep 17 00:00:00 2001 From: qupeng Date: Mon, 25 May 2020 15:38:42 +0800 Subject: [PATCH 2/4] address comments Signed-off-by: qupeng --- tikv-control.md | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/tikv-control.md b/tikv-control.md index 555c7ba48dd7..8c9ffb0f2bb3 100644 --- a/tikv-control.md +++ b/tikv-control.md @@ -6,9 +6,28 @@ aliases: ['/docs-cn/dev/reference/tools/tikv-control/'] # TiKV Control 使用说明 -TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 TiKV 集群。 +TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 TiKV 集群。它的安装位置 -编译 TiKV 的同时也会编译 tikv-ctl 命令。如果通过 Ansible 部署集群,则对应的 `tidb-ansible/resources/bin` 目录下会存在 `tikv-ctl` 二进制文件。 +* 对于 ansible 部署的集群,在 ansible 目录下的 `resources/bin` 子目录下; +* 对于 tiup 部署的集群,在 `~/.tiup/components/ctl/{VERSION}/` 下。 + +[tiup](https://github.com/pingcap-incubator/tiuptiup) 是晚于 `tidb-ansible` 推出的部署工具,使用方式更加简化,`tikv-ctl` 也集成在了 `tiup` 命令中。可以这样调用 `tikv-ctl` 工具: + +``` +$ tiup ctl tikv +Starting component `ctl`: ~/.tiup/components/ctl/v4.0.0-rc.2/ctl tikv +TiKV Control (tikv-ctl) +Release Version: 4.0.0-rc.2 +Edition: Community +Git Commit Hash: 2fdb2804bf8ffaab4b18c4996970e19906296497 +Git Commit Branch: heads/refs/tags/v4.0.0-rc.2 +UTC Build Time: 2020-05-15 11:58:49 +Rust Version: rustc 1.42.0-nightly (0de96d37f 2019-12-19) +Enable Features: jemalloc portable sse protobuf-codec +Profile: dist_release +``` + +在这后面再接上相应的参数与子命令即可。 ## 通用参数 @@ -192,11 +211,11 @@ success! `compact-cluster` 命令可以对整个 TiKV 集群进行手动 compact。该命令参数的含义和使用与 `compact` 命令一样。 -### 设置一个 Region 副本为 tombstone +### 设置一个 Region 副本为 tombstone 状态 `tombstone` 命令常用于没有开启 sync-log,因为机器掉电导致 Raft 状态机丢失部分写入的情况。它可以在一个 TiKV 实例上将一些 Region 的副本设置为 Tombstone 状态,从而在重启时跳过这些 Region,避免因为这些 Region 的副本的 Raft 状态机损坏而无法启动服务。这些 Region 应该在其他 TiKV 上有足够多的健康的副本以便能够继续通过 Raft 机制进行读写。 -一般情况下,我们可以先在 PD 上将 Region 的副本通过 remove-peer 命令删除掉: +一般情况下,可以先在 PD 上将 Region 的副本通过 `remove-peer` 命令删除掉: {{< copyable "" >}} @@ -216,7 +235,9 @@ tikv-ctl --db /path/to/tikv/db tombstone -p 127.0.0.1:2379 -r success! ``` -但是有些情况下,当不能方便地从 PD 上移除这个副本时,可以指定 tikv-ctl 的 --force 选项来强制设置它为 tombstone: +但是有些情况下,当不能方便地从 PD 上移除这个副本时,可以指定 tikv-ctl 的 `--force` 选项来强制设置它为 tombstone: + +{{< copyable "shell-regular" >}} ```shell tikv-ctl --db /path/to/tikv/db tombstone -p 127.0.0.1:2379 -r , --force From 3f61763a7a11dcc46e1c4f1e78cb98c92327feef Mon Sep 17 00:00:00 2001 From: qupeng Date: Tue, 26 May 2020 13:50:08 +0800 Subject: [PATCH 3/4] fix lint Signed-off-by: qupeng --- tikv-control.md | 1 - 1 file changed, 1 deletion(-) diff --git a/tikv-control.md b/tikv-control.md index 8c9ffb0f2bb3..7e8212999b94 100644 --- a/tikv-control.md +++ b/tikv-control.md @@ -247,7 +247,6 @@ tikv-ctl --db /path/to/tikv/db tombstone -p 127.0.0.1:2379 -r , **注意:** > > - **该命令只支持本地模式** From f95afcfb43da397a2eed63ca09d5d6bf94559d44 Mon Sep 17 00:00:00 2001 From: lilin90 Date: Tue, 26 May 2020 14:24:14 +0800 Subject: [PATCH 4/4] Update wording and format --- tikv-control.md | 44 +++++++++++++++++++++++++++----------------- 1 file changed, 27 insertions(+), 17 deletions(-) diff --git a/tikv-control.md b/tikv-control.md index 7e8212999b94..596d1e32d14a 100644 --- a/tikv-control.md +++ b/tikv-control.md @@ -6,15 +6,20 @@ aliases: ['/docs-cn/dev/reference/tools/tikv-control/'] # TiKV Control 使用说明 -TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 TiKV 集群。它的安装位置 +TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 TiKV 集群。它的安装目录如下: -* 对于 ansible 部署的集群,在 ansible 目录下的 `resources/bin` 子目录下; -* 对于 tiup 部署的集群,在 `~/.tiup/components/ctl/{VERSION}/` 下。 +* 如果是使用 TiDB Ansible 部署的集群,在 `ansible` 目录下的 `resources/bin` 子目录下。 +* 如果是使用 TiUP 部署的集群,在 `~/.tiup/components/ctl/{VERSION}/` 目录下。 -[tiup](https://github.com/pingcap-incubator/tiuptiup) 是晚于 `tidb-ansible` 推出的部署工具,使用方式更加简化,`tikv-ctl` 也集成在了 `tiup` 命令中。可以这样调用 `tikv-ctl` 工具: +[TiUP](https://github.com/pingcap-incubator/tiuptiup) 是晚于 `tidb-ansible` 推出的部署工具,使用方式更加简化,`tikv-ctl` 也集成在了 `tiup` 命令中。执行以下命令,即可调用 `tikv-ctl` 工具: + +{{< copyable "shell-regular" >}} + +```bash +tiup ctl tikv +``` ``` -$ tiup ctl tikv Starting component `ctl`: ~/.tiup/components/ctl/v4.0.0-rc.2/ctl tikv TiKV Control (tikv-ctl) Release Version: 4.0.0-rc.2 @@ -27,7 +32,7 @@ Enable Features: jemalloc portable sse protobuf-codec Profile: dist_release ``` -在这后面再接上相应的参数与子命令即可。 +你可以在 `tiup ctl tikv` 后面再接上相应的参数与子命令。 ## 通用参数 @@ -91,7 +96,7 @@ AAFF `raft` 子命令可以查看 Raft 状态机在某一时刻的状态。状态信息包括 **RegionLocalState**、**RaftLocalState** 和 **RegionApplyState** 三个结构体,及某一条 log 对应的 Entries。 -您可以使用 `region` 和 `log` 两个子命令分别查询以上信息。两条子命令都同时支持远程模式和本地模式。它们的用法及输出内容如下所示: +你可以使用 `region` 和 `log` 两个子命令分别查询以上信息。两条子命令都同时支持远程模式和本地模式。其用法及输出内容如下所示: {{< copyable "shell-regular" >}} @@ -111,7 +116,7 @@ apply state: Some(applied_index: 314617 truncated_state {index: 313474 term: 151 ### 查看 Region 的大小 -`size` 命令可以查看 Region 的大小: +使用 `size` 命令可以查看 Region 的大小: {{< copyable "shell-regular" >}} @@ -146,7 +151,7 @@ key: zmDB:29\000\000\377\000\374\000\000\000\000\000\000\377\000H\000\000\000\00 ### 查看给定 key 的 MVCC -与上个命令类似,`mvcc` 命令可以查看给定 key 的 MVCC: +与 `scan` 命令类似,`mvcc` 命令可以查看给定 key 的 MVCC: {{< copyable "shell-regular" >}} @@ -195,7 +200,11 @@ middle_key_by_approximate_size: ### 手动 compact 单个 TiKV 的数据 -`compact` 命令可以对单个 TiKV 进行手动 compact。如果指定 `--from` 和 `--to` 选项,那么它们的参数也是 escaped raw key 形式的。`--host` 参数可以指定要 compact 的 TiKV,`-d` 参数可以指定要 compact 的 RocksDB,有 `kv` 和 `raft` 参数值可以选。`--threads` 参数可以指定 compact 的并发数,默认值是 8。一般来说,并发数越大, compact 的速度越快,但是也会对服务造成影响,所以需要根据情况选择合适的并发数。 +`compact` 命令可以对单个 TiKV 进行手动 compact。如果指定 `--from` 和 `--to` 选项,那么它们的参数也是 escaped raw key 形式的。 + +- `--host` 参数可以指定要 compact 的 TiKV。 +- `-d` 参数可以指定要 compact 的 RocksDB,有 `kv` 和 `raft` 参数值可以选。 +- `--threads` 参数可以指定 compact 的并发数,默认值是 8。一般来说,并发数越大,compact 的速度越快,但是也会对服务造成影响,所以需要根据情况选择合适的并发数。 {{< copyable "shell-regular" >}} @@ -303,7 +312,7 @@ all regions are healthy ### 查看 Region 属性 -本地查看部署在 `/path/to/tikv` 的 tikv 上面 Region 2 的 properties 信息: +本地查看部署在 `/path/to/tikv` 的 TiKV 上面 Region 2 的 properties 信息: {{< copyable "shell-regular" >}} @@ -311,7 +320,7 @@ all regions are healthy tikv-ctl --db /path/to/tikv/data/db region-properties -r 2 ``` -在线查看运行在 `127.0.0.1:20160` 的 tikv 上面 Region 2 的 properties 信息: +在线查看运行在 `127.0.0.1:20160` 的 TiKV 上面 Region 2 的 properties 信息: {{< copyable "shell-regular" >}} @@ -405,7 +414,8 @@ tikv-ctl --db /path/to/tikv/db unsafe-recover remove-fail-stores -s 4,5 --all-re `recover-mvcc` 命令用于 MVCC 数据损坏导致 TiKV 无法正常运行的情况。为了从不同种类的不一致情况中恢复,该命令会交叉检查 3 个 CF ("default", "write", "lock")。 -`-r` 选项可以通过 `region_id` 指定包含的 Region,`-p` 选项可以指定 PD 的 endpoints。 +- `-r` 选项可以通过 `region_id` 指定包含的 Region。 +- `-p` 选项可以指定 PD 的 endpoints。 {{< copyable "shell-regular" >}} @@ -425,11 +435,11 @@ success! ### Ldb 命令 -ldb 命令行工具提供多种数据访问以及数据库管理命令。下方列出了一些示例用法。详细信息请在运行 `tikv-ctl ldb` 命令时查看帮助消息或查阅 RocksDB 文档。 +`ldb` 命令行工具提供多种数据访问以及数据库管理命令。下方列出了一些示例用法。详细信息请在运行 `tikv-ctl ldb` 命令时查看帮助消息或查阅 RocksDB 文档。 -数据访问序列示例如下。 +数据访问序列的示例如下: -用 HEX 格式 dump 现有 RocksDB 数据: +用 HEX 格式 dump 现有 RocksDB 数据: {{< copyable "shell-regular" >}} @@ -437,7 +447,7 @@ ldb 命令行工具提供多种数据访问以及数据库管理命令。下方 tikv-ctl ldb --hex --db=/tmp/db dump ``` -dump 现有 RocksDB 的声明: +Dump 现有 RocksDB 的声明: {{< copyable "shell-regular" >}}