2.5 段合并

每个索引分为多个“写一次,读多次”的段 write once and read many times  segments

建立索引时,一个段写入磁盘以后就不能更新:被删除的文档的信息存储在一个单独的文件中

【段合并 segments merge】

多个段可以通过段合并合并在一起

当强制段合并或者Luncene决定合并时,这些小段就会由Lucene合并成为更大的段

合并时间

当强制段合并或者Lucene决定合并时,这些小段就会由Lucene合并成更大的daunt

为什么合并

  1. 合并时,不再需要的信息将被删除,例如,被删除的文档;
  2. 检索大段比检索存有相同数据的多个小段速度更快:一般情况下,搜索只需要将查询词与那些被编入索引的词相匹配,通过多个小段查找会比让一个大段直接提供结果慢且需要内存更多。

合并策略

tired 默认,合并尺寸大致相似的段,并考虑每个层tier允许的最大段数;

log_byte_size

log_doc

1.1节提到段及其不变性,指出Lucene库以及Elasticsearch中一旦数据被写入某些结构,就不 再改变。虽然这简化了一些东西,但是也引入了额外的工作,其中一个例子是删除。由于段是无 法改变的,因而有关删除的相关信息必须单独存储并动态应用到搜索过程中。这样做是为了从返 回结果中去除已删除的文件。另一个例子是文档无法修改(有些修改是可能的,例如修改数值型 doc值)。当然,我们可以说,Elasticsearch支持文档更新(请参阅1.4节)。然而在底层,实际上是 删除旧文档,再把更新内容的文档编入索引。

随着时间的推移和持续索引数据,越来越多的段被创建。因此,搜索性能可能会降低,而且 索引可能比原先大,因为它仍含有被删除的文件。这使得段合并有了用武之地。

2.5.1 段合并

段合并的处理过程是:底层的Lucene库获取若干段,并在这些段信息的基础上创建一个新的 段。由此产生的段拥有所有存储在原始段中的文档,除了被标记为删除的那些之外。合并操作之 后,源段将从磁盘上删除。这是因为段合并在CPU和I/O的使用方面代价是相当高的,关键是要 适当地控制这个过程被调用的时机和频率。

2.5.2 段合并的必要性

你可能会问为何要费心段合并。首先,构成索引的段越多,搜索速度越慢,需要使用的Lucene

内存也越多。其次,索引使用的磁盘空间和资源,例如文件描述符。如果从索引中删除许多文档, 直到合并发生,则这些文档只是被标记为已删除,而没有在物理上删除。因而,大多数占用了CPU 和内存的文档可能并不存在!好在Elasticsearch使用合理的默认值做段合并,这些默认值很可能 不再需要做任何更改。

2.5.3 合并策略

合并策略描述了应执行合并过程的时机。Elasticsearch允许配置以下三种不同的策略。

 tiered:这是默认合并策略,合并尺寸大致相似的段,并考虑到每个层(tier)允许的最
大段数量;
 log_byte_size:这个合并策略下,随着时间推移,将产生由索引大小的对数构成的索
引,其中存在着一些较大的段以及一些合并因子较小的段等;
 log_doc:这个策略类似于log_byte_size合并策略,但根据索引中的文档数而非段的
实际字节数来操作。

上述的每个策略都有自己的参数来定义行为以及可以覆盖的默认值。本书不做详细描述。如 果你想了解更多,请查看 Mastering ElasticSearch,或去 http://www.elasticsearch.org/guide/en/ elasticsearch/reference/current/index-modules-merge.html了解详情。

可使用index.merge.policy.type属性来设置想使用的合并策略,如下所示: index.merge.policy.type: tiered

值得一提的是,索引创建后将无法再对值进行修改。

2.5.4 合并调度器

合并调度器指示Elasticsearch合并过程的方式,有如下两种可能。

 并发合并调度器:这是默认的合并过程,在独立的线程中执行,定义好的线程数量可以
并行合并。
 串行合并调度器:这一合并过程在调用线程(即执行索引的线程)中执行。合并进程会
一直阻塞线程直到合并完成。

调度器可使用index.merge.scheduler.type参数设置。若要使用串行合并调度器,需把参 数值设为serial;若要使用并发调度器,则需把参数值设为concurrent。例如下面的调度程序: index.merge.scheduler.type: concurrent

2.5.5 合并因子

每种合并策略都有好几种设置,我们已经说过在这里不一一介绍,但是合并因子是个例外,

它指定了索引过程中段合并的频率。合并因子较小时,搜索的速度更快,占用的内存也更少,但 索引的速度会减慢;合并因子较大时,则索引速度加快,这是因为发生的合并较少,但搜索的速 度变慢,占用的内存也会变大。对于log_byte_size和 log_doc合并策略,可以通过index. merge.policy.merge_factor参数来设置合并因子。

index.merge.policy.merge_factor: 10

上述例子将合并因子的值设置成10,10也是默认值。建议在批量索引时设置更高的merge_ factor属性值,普通的索引维护则设置较低的属性值。

2.5.6 调节

之前提到过,合并可能需要很多的服务器资源。合并过程通常与其他操作并行执行,所以理 论上不会产生太大的影响。在实践中,磁盘I/O操作的数量可能非常大,以致严重影响了整体性 能。这时,调节(throttling)可以改善此情况。事实上,此功能既可用于限制合并的速度,也可 以用于使用数据存储的所有操作。可以在Elasticsearch的配置文件中对调节进行设置(elasticsearch.yml文件),也可以动态使用设置API来设置(请参阅8.7.2节)。调整调节的设置有两个:type 和value。

为了设置调节类型,设置indices.store.throttle.type属性值为下列值之一。

 none:该值定义不打开调节。

 merge:该值定义调节仅在合并过程中有效。

 all:该值定义调节在所有数据存储活动中有效。

第二个属性,indices.store.throttle.max_bytes_per_sec,描述了调节限制I/O操作 的数量。顾名思义,该属性告诉我们每秒可以处理的字节数量。来看看以下配置:

这个例子中,我们限制合并操作为每秒10 MB。默认情况下,Elasticsearch使用merge调节类 型,max_bytes_per_sec属性设置值为20 mb。这意味着所有的合并操作都限于每秒20 MB。

为了执行批量请求,Elasticsearch提供了_bulk端点,形式可以是/_bulk,也可以是/index_ name/_bulk,甚至是/index_name/type_name/_bulk。第二种和第三种形式定义了索引名称 和类型名称的默认值。可以在请求的信息行中省略这些属性,Elasticsearch将使用默认值。

段合并 segments merge 被删除的文档的删除时间的更多相关文章

  1. 【Elasticsearch】查询并删除匹配文档之_delete_by_query

    思路:先查询确认,后精准删除 假设我想删除title是"小明今晚真的不加班"这条记录,先查看一下现有的记录: (不加班不好吗?为什么要删除呢?) tips:可以使用match_ph ...

  2. (三)Lucene之删除更新文档以及luke的基本使用

    一.demo 本例中采用单元测试,故在pom.xml中引入junit jar包 1.1 前提: public class IndexTest { /** *数据准备 */ private String ...

  3. 批量删除wps文档里的回车符的方法!WPS使用技巧分享!

    有时候整理文档的时候,如果是从网上复制的文字,可能会因为复制而产生很多的回车符.怎样能批量去掉这些个回车符呢,下面马上告诉你批量删除wps文档里的回车符的方法!WPS使用技巧分享! 想要批量删除批量删 ...

  4. MongoDB 教程(七):插入文档、更新文档、删除文档

    MongoDB 插入文档 文档的数据结构和JSON基本一样. 所有存储在集合中的数据都是BSON格式 —— BSON是一种类json的二进制形式的存储格式,简称Binary JSON. MongoDB ...

  5. es删除文档或者删除索引

    es删除文档或者删除索引 学习了:https://www.imooc.com/video/15771 删除文档: DELETE http://127.0.0.1:9200/people/man/1 删 ...

  6. Java 添加、读取、删除PPT文档属性

    文档属性是一些描述性的信息,它未包含在文件的实际内容中,但提供了有关文件的信息,可用来帮助查找和整理文件.以下示例中将介绍通过Java程序来添加PPT文档属性.读取.删除PPT文档中已有属性的方法. ...

  7. C# 添加、读取、删除Excel文档属性

    在文档属性中,可以设置诸多关于文档的信息,如创建时间.作者.单位.类别.关键词.备注等摘要信息以及一些自定义的文档属性.下面将通过C#程序来演示如何设置,同时对文档内的已有信息,也可以实现读取或删除等 ...

  8. MongoDB(五):更新文档、删除文档

    1. 更新文档 MongoDB的uptade()和save()方法用于将集合中的文档更新.update()方法更新现有文档中的值,而save()方法是传递文档数据替换现有文档.从3.2版本开始,Mon ...

  9. Java 添加、读取、删除Excel文档属性

    在文档属性中,可以设置诸多关于文档的信息,如创建时间.作者.单位.类别.关键词.备注等摘要信息以及一些自定义的文档属性.下面将通过Java程序来演示如何设置,同时对文档内的已有信息,也可以实现读取和删 ...

随机推荐

  1. JavaScript对象深复制

    1.原理 使用JSON,当然需要JSON安全的格式,JSON安全请参考:http://www.cnblogs.com/mengfangui/p/8257269.html 2.示例 <!DOCTY ...

  2. A.0 B.1 C.2 D.3

    17. 以下哪个不是广告平台? A.Admob B.Domob C.InMobi D.TalkingData 错误 应该选择:D.TalkingData 10. 哪个不是免费的工具? A.Xcode  ...

  3. 关于部分Android手机安装apk,无法获取正常的logo

    最近出现过类似的问题,主要出现是在,MediaPad X1 7.0和MediaPad M1 8.0. 发布应用的时候明明配置好了图标的,但是始终找不到原因,郁闷了好几个小时,也浪费了好几个小时. 如果 ...

  4. 批量杀进程 ps awk grep

    ps aux |grep lt-newindexclient |grep -v grep |awk grep -v 反向输出,即过滤掉带有grep的输出. xargs:传递参数

  5. EMQ ---100万线连接测试说明

    注解 EMQ 2.0 消息服务器默认设置,允许最大客户端连接是512,因为大部分操作系统 ‘ulimit -n’ 限制为1024. EMQ 消息服务器1.1.3版本,连接压力测试到130万线,8核心/ ...

  6. UDP与TCP报文格式,字段意义

    UDP报文 1.UDP有两个字段:数据字段和首部字段. 首部字段 首部字段很简单,只有8个字节,由4个字段组成,每个字段的长度都是两个字节.   1)源端口:源端口号.在需要对方回信时选用.不需要时可 ...

  7. ASP.NET MVC Razor 输出没有编码的HTML字符串

    Razor引擎之前要输出一段没有编码的字符串,只要@加变量名就可以了,Razor却不能这样,感觉是有点麻烦. 在Razor Beta 2以前的版本可以: @(new HtmlString(mystri ...

  8. 【Java】取当前.class文件的编译位置

    本文与<[C++]求当前exe的执行路径>(点击打开链接)为姊妹篇.C++在win下生成的执行文件是.exe.Java生成的执行文件是.class然后自己主动扔到Java虚拟机中执行.主要 ...

  9. C++在线编译器

    主要有3个,且它们都支持C++11 http://gcc.godbolt.org/ http://coliru.stacked-crooked.com/ http://ideone.com/ 第一个网 ...

  10. 181. Flip Bits【easy】

    181. Flip Bits[easy] Determine the number of bits required to flip if you want to convert integer n  ...