Skip to content

Commit 3f1f8f8

Browse files
committed
Cleanup list for asciidoctor
It was a little jumbled.
1 parent 0cfac10 commit 3f1f8f8

File tree

1 file changed

+6
-13
lines changed

1 file changed

+6
-13
lines changed

040_Distributed_CRUD/15_Create_index_delete.asciidoc

Lines changed: 6 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -20,32 +20,25 @@ image::images/elas_0402.png["新建、索引和删除单个文档"]
2020

2121
有一些可选的请求参数允许您影响这个过程,可能以数据安全为代价提升性能。这些选项很少使用,因为Elasticsearch已经很快,但是为了完整起见,在这里阐述如下:
2222

23-
--
24-
2523
`consistency`::
2624
+
27-
--
2825
consistency,即一致性。在默认设置下,即使仅仅是在试图执行一个_写_操作之前,主分片都会要求((("consistency request parameter")))((("quorum"))) 必须要有 _规定数量(quorum)_(或者换种说法,也即必须要有大多数)的分片副本处于活跃可用状态,才会去执行_写_操作(其中分片副本可以是主分片或者副本分片)。这是为了避免在发生网络分区故障(network partition)的时候进行_写_操作,进而导致数据不一致。_规定数量_即:
29-
26+
+
3027
int( (primary + number_of_replicas) / 2 ) + 1
31-
28+
+
3229
`consistency` 参数的值可以设为 `one` (只要主分片状态 ok 就允许执行_写_操作),`all`(必须要主分片和所有副本分片的状态没问题才允许执行_写_操作), 或 `quorum` 。默认值为 `quorum` , 即大多数的分片副本状态没问题就允许执行_写_操作。
33-
30+
+
3431
注意,_规定数量_ 的计算公式中 `number_of_replicas` 指的是在索引设置中的设定副本分片数,而不是指当前处理活动状态的副本分片数。如果你的索引设置中指定了当前索引拥有三个副本分片,那规定数量的计算结果即:
35-
32+
+
3633
int( (primary + 3 replicas) / 2 ) + 1 = 3
37-
34+
+
3835
如果此时你只启动两个节点,那么处于活跃状态的分片副本数量就达不到规定数量,也因此您将无法索引和删除任何文档。
3936

40-
--
41-
4237
`timeout`::
43-
38+
+
4439
如果没有足够的副本分片会发生什么? Elasticsearch会等待,希望更多的分片出现。默认情况下,它最多等待1分钟。
4540
如果你需要,你可以使用 `timeout` 参数((("timeout parameter"))) 使它更早终止: `100` 100毫秒,`30s` 是30秒。
4641

47-
--
48-
4942
[NOTE]
5043
===================================================
5144
新索引默认有 `1` 个副本分片,这意味着为满足 `规定数量` _应该_ 需要两个活动的分片副本。

0 commit comments

Comments
 (0)