elastic使用lucene建立索引的步骤中,需要文件系统缓存需要同步到磁盘上。(多个segment->commit文件来维护)
当建立历史数据时,并不要求太高的实时性时,可以减小(默认1s)自动刷新时间。
curl -XPOST http://127.0.0.1:9300/logstash-2016.12.19/_settings -d ‘{"refresh_interval":"10s"}‘
如需关闭
curl -XPOST http://127.0.0.1:9300/logstash-2016.12.19/_settings -d ‘{"refresh_interval":"-1"}‘
translog保证索引的一致性。elastic中的update,insert等写操作完成,一定会触发translog到磁盘上,然后再返回200。这个过程会损失一点性能。
如果不考虑这些,希望性能优先,可以在index template中设置 index.translog.durability:async
lucene的思路就是开新文件。默认1s就有一个文件产生。ES会不断在后台merge segment。
时间: 2024-11-10 07:08:47