成语大全网 - 汉语词典 - Elastic Search优化

Elastic Search优化

设置系统的最大打开文件数,可以调大到32k以上,且集群每个节点都要操作;

修改Elastic Search的JVM的内存大小;

锁定物理地址,避免内存交换,提高性能;

分片过多会导致打开的文件比较多,增加节点之间的通讯代价,影响性能;分片数太少会导致单个分片索引过大,检索速度变慢,一般10个左右比较合适,不易超过30个,每个分片数据应该在20G左右,即分片数 = 数据总量 / 20G;

副本增加可以提高检索能力,但是也增加了副本同步数据的压力,增加磁盘空间,一般设置2-3个副本集合;

Segment越多,占用的segment memory就会越多,性能反而降低。索引量不大时,可以设置Segment为1,另外可以调整segment merge的配置参数来提高性能,如max_thread_count和单个segment的最大容量等;

因为只删除type不会释放空间。

索引处于open状态,索引库的Segment就会占用过内存空间,close后会释放内存空间,不释放磁盘空间;

删除后的数据记录不是立刻清除磁盘数据,而是导入到了.del文件中,这部分数据仍然参与检索,在检索过程中再判断是否删除,然后再过滤。因此清除已经删除的数据记录会提高检索效率;

等到数据导入完成后,再恢复副本数量,避免了导入数据时,又要同步副本的性能压力;

Index默认会有一个_all字段,默认把所有字段的数据copy到_all字段里,方便了query,却增加了索引时间和索引大小;

Elastic Search的默认log级别是trace,当慢查询操作500ms时,就会打印日志,造成了集群负载,影响性能。可以将log级别调整为info;

Elastic Search默认检索只会返回ID,然后根据这个ID去倒排索引你中取每个field数据,当开启时,Elastic Search可以根据ID直接检索对应source JSON的field,不再需要倒排索引;

默认情况下,index刷新间隔为1秒,即数据写入1秒后就可以被query到,每次刷新都会产生新的Lucene段,进而导致频繁的Segment merge行为。

针对中文查询搜索,一定要安装ik分词,有ik_max_word和ik_smart,极大的提高的查询性能和准确度,否则就会逐个中文字进行匹配,耗费性能。

在插入文档时,ES查看该字段有没有定义analyzer,如果定义了就用定义的,否则使用ES默认的;

在搜索文档时,ES会先去看字段有没有定义search_analyzer,如果没有定义,就去看有没有analyzer,再没有定义就使用否则使用ES默认的。

针对中文分词,一般创建index时指定analyzer = ik_max_word,search_analyzer = ik_smark。

根据业务增量需求,可以基于日期模板来创建索引,然后通过roll over API滚动索引。

采取冷热分离机制,热数据存储到SSD,提高检索效率;冷数据定期进行shrink操作,以缩减存储;

采取curator进行索引的生命周期管理。

写入前关闭refresh_interval设置为-1,禁用刷新机制。

Elastic Search为避免深分页带来的性能问题(可参考: /p/f25c19d73b8f ),Elastic Search禁止查询10000条以后的数据(可配置)。Elastic Search提供了scroll游标来解决深分页问题,即初始化查询时将所有符合条件的搜索结果缓存起来,然后遍历缓存里面的数据。避免每次搜索都必须重新排序的问题,但是初始化之后,对索引的数据更改不会同步到缓存中,即不对游标遍历结果有影响。

针对term index,仅仅使用数据的一部分前缀与term dictionary的block之间的映射关系,再结合FST(Finite State Transducers)的压缩技术,可以使term index缓存到内存中;

针对ID使用Frame Of Reference压缩;