博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Elasticsearch中refresh和flush的区别是什么
阅读量:5903 次
发布时间:2019-06-19

本文共 1196 字,大约阅读时间需要 3 分钟。

hot3.png

在ES中, 要保证被索引的文档能够立即被搜索到, 有两种方法:_refresh 或者_flush。

那么二者的区别是什么呢?要搞懂这个问题, 就需要对ES中文档的索引过程有个了解。

我们知道ES的索引数据是写入到磁盘上的。但这个过程是分阶段实现的,因为IO的操作是比较费时的。

当一个文档进入ES的初期, 文档是被存储到内存里的,默认经过1s之后, 会被写入文件系统缓存,这样该文档就可以被搜索到了,注意,此时该索引数据被没有最终写入到磁盘上。如果你对这1s的时间间隔还不满意, 调用_refresh就可以立即实现内存->文件系统缓存, 从而使文档可以立即被搜索到。

所以refresh实现的是文档数据从内存到文件系统缓存的过程。

再来看flush,flush是用于translog的。

ES为了数据的安全, 在接受写入的文档的时候, 在写入内存buffer的同时, 会写一份translog日志,从而在出现程序故障/磁盘异常时, 保证数据的完整和安全。flush会触发lucene commit,并清空translog日志文件。 translog的flush是ES在后台自动执行的,默认情况下ES每隔5s会去检测要不要flush translog,默认条件是:每 30 分钟主动进行一次 flush,或者当 translog 文件大小大于 512MB主动进行一次 flush。对应的配置是index.translog.flush_threshold_period 和 index.translog.flush_threshold_size

需要指出的是, 从ES2.0开始,每次 index、bulk、delete、update 完成的时候,一定触发flush translog 到磁盘上,才给请求返回 200 OK。这个改变提高了数据安全性,但是会对写入的性能造成不小的影响。在写入效率优先的情况下,可以在 index template 里设置如下参数:"index.translog.durability":"async" 和 "index.translog.sync_interval":30s (默认是5s)。

参考:

1. http://stackoverflow.com/questions/19963406/refresh-vs-flush

2.https://www.elastic.co/guide/en/elasticsearch/reference/current/index-modules-translog.html

3. http://kibana.logstash.es/content/elasticsearch/principle/realtime.html

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/LucasZhu/blog/1542836

你可能感兴趣的文章
js操作图片
查看>>
深入屏幕像素概念
查看>>
彻底移除 IIS Response Header 版本信息
查看>>
linux下压缩与解压缩
查看>>
Laravel Response
查看>>
c语言中统计二进制位中1的个数的算法优化
查看>>
《C语言深度剖析》学习笔记四--指针
查看>>
awk命令的几个选项注释
查看>>
如何修改eclipse的默认工作空间
查看>>
cast return value to (void)
查看>>
简要总结我做过的一些项目
查看>>
用GLM库和GLSL编制最简单的三角形程序
查看>>
u-boot-201611 启动过程分析——基于smdk2410
查看>>
OpenCV图像的轮廓的匹配
查看>>
Windows更改临时文件夹
查看>>
Oracle 默认用户汇总
查看>>
mysql主从复制
查看>>
maven资源文件的相关配置
查看>>
Linux01-Linux启动流程及grub详解45
查看>>
Mac中使用Terminal启动Sublime Text 2
查看>>