elasticsearch预加载数据到文件系统缓存

默认情况下,Elasticsearch搜索完全依赖于操作系统文件系统缓存来缓存I / O操作。可以设置index.store.preload,以便通知操作系统启动时将索引文件的内容预加载到内存中。此设置接受以逗号分隔的文件扩展名列表:扩展名在列表中的所有文件将在打开时预先加载。这可以有助于提高索引的搜索性能,特别是当主机操作系统重新启动时,因为这会导致文件系统缓存被删除。但是请注意,这可能会减慢索引的打开,因为它们只有在数据加载到物理内存之后才可用。

此设置量力而为,而且可能无法在所有的文件系统和主机操作系统上运行。

index.store.preload是一个静态设置,可以在config/elasticsearch.yml中设置:

index.store.preload: [ "nvd" "dvd" ]

或者在创建索引时设置:

PUT  /my_index
{
   "settings" : {
     "index.store.preload" : [ "nvd" "dvd" ]
   }
}

默认值为空数组,这意味着任何东西都不会被加载到文件系统缓存中。对于主动搜索的索引,您可能需要将其设置为[“nvd”,“dvd”],这将导致norms doc values被加载到物理内存中。

可以使用通配符来表示所有文件都应该预加载:index.store.preload:[“*”]。但是请注意,将所有文件加载到内存中,特别是stored fields 和 term vectors的文件通常是没有用的,因此更好的选择是尽可能将其设置为[“nvd”,“dvd”,“tim”,“doc” “,”dim“],它将预先加载norms, doc values, terms dictionaries, postings lists 和 points,这是搜索和聚合索引中最重要的部分。

请注意,对于大于主机主内存大小的索引,此设置可能是危险的,因为这会导致文件缓存系统在缓存大容量后被重新打开从而丢弃之前的缓存,从而使索引和搜索速度更慢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值