我正在使用Elasticsearch 5.2.2,我希望在进行密集的索引操作后完全合并索引的各个部分。
我使用以下rest API来合并所有细分:
http://localhost:9200/my_index/_forcemerge
(我还尝试在POST请求中添加 max_num_segments = 1 。)
ES回复:
{
"_shards": {
"total": 16,
"successful": 16,
"failed": 0
}
}
请注意,my_index由16个分片组成。
但是当我要求节点统计信息(http://localhost:9200/_nodes/stats)时,它会回复:
segments: {
count: 64,
[...]
}
所以似乎所有分片都被分成4段(64/16 = 4)。事实上," ls"在数据目录上确认每个分片有4个段:
~# ls /var/lib/elasticsearch/nodes/0/indices/ym_5_99nQrmvTlR_2vicDA/0/index/
_0.cfe _0.cfs _0.si _1.cfe _1.cfs _1.si _2.cfe _2.cfs _2.si _5.cfe _5.cfs _5.si segments_6 write.lock
没有并发合并正在运行(http://localhost:9200/_nodes/stats):
merges: {
current: 0,
[...]
}
所有force_merge请求都已完成(http://localhost:9200/_nodes/stats):
force_merge: {
threads: 1,
queue: 0,
active: 0,
rejected: 0,
largest: 1,
completed: 3
}
ES 2.2没有这个问题。
谁知道如何完全合并这些细分?
谢谢大家!
答案 0 :(得分:1)
我不确定您的问题是否解决。只需在此处发布以告知其他人。
这应该是一个错误。您可以看到以下问题。使用空的json主体可以使其正常工作。 https://github.com/TravisTX/elasticsearch-head-chrome/issues/16