我正在使用 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 中没有遇到这个问题。
谁知道如何完全合并这些片段?
谢谢大家!
最佳答案
不知道您的问题是否解决了。只是在这里发帖让其他人知道。
这应该是一个错误。你可以看到以下问题。使用空的 json 主体可以使其工作。 https://github.com/TravisTX/elasticsearch-head-chrome/issues/16
关于elasticsearch - 如何在 Elasticsearch 5 中强制合并段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43325431/