千家信息网

Elasticsearch refresh 和 fresh 特性梳理

发表于:2024-11-18 作者:千家信息网编辑
千家信息网最后更新 2024年11月18日,refresh数据从index buffer中进入filesystem cache的过程)translog中的操作记录并不会被清除,当数据从filesystem cache中被写入磁盘之后才会将tra
千家信息网最后更新 2024年11月18日Elasticsearch refresh 和 fresh 特性梳理

refresh

数据从index buffer中进入filesystem cache的过程)translog中的操作记录并不会被清除,当数据从filesystem cache中被写入磁盘之后才会将translog中清空。

手动执行refresh:

调用_refresh就可以立即实现内存->文件系统缓存, 从而使文档可以立即被搜索到。#单个indexPOST /twitter/_refresh#多个indexPOST /index01,index02/_refresh#全部indexPOST /_refresh

参考图

fresh

从filesystem cache写入磁盘的过程就是flush。

手动执行fresh:

#单个indexPOST /twitter/_fresh#多个indexPOST /index01,index02/_fresh#全部indexPOST /_fresh

触发fresh的条件

1:es的各个shard会每个30分钟进行一次flush操作;2:或者当 translog 文件大小大于512MB主动进行一次 flush;3:每次 index、bulk、delete、update 完成的时候,触发flush translog 到磁盘上;

核心配置项:

1:index.translog.flush_threshold_ops:当发生多少次操作时进行一次flush。默认是 unlimited。2:index.translog.flush_threshold_size:当translog的大小达到此值时会进行一次flush操作。默认是512mb。3:index.translog.flush_threshold_period:在指定的时间间隔内如果没有进行flush操作,会进行一次强制flush操作。默认是30m。4:index.translog.interval:多少时间间隔内会检查一次translog,来进行一次flush操作。
0