Spring Data Elasticsearch 5.0.x修改数据后无法立即刷新解决方法示例
背景
在项目中用到了Spring Data ElasticSearch,最近更新到了最新版本5.0.x,在数据插入、修改、删除后,紧接着进行查询发现数据并未更新;
解决方法
研究后发现是新版本的spring data es默认的刷新策略是null,代码如下:
@Bean @ConditionalOnMissingBean(value = ElasticsearchOperations.class, name = "elasticsearchTemplate") @ConditionalOnBean(ElasticsearchClient.class) ElasticsearchTemplate elasticsearchTemplate(ElasticsearchClient client, ElasticsearchConverter converter) { return new ElasticsearchTemplate(client, converter); }
这里没有给ElasticsearchTemplate设置refreshPolicy属性,点进AbstractElasticsearchTemplate可以看到默认为null,而以前默认是立即刷新IMMEDIATE。
查看Spring官网发现
Refresh configuration
When configuring Spring Data Elasticsearch like described in Elasticsearch Clients by using ElasticsearchConfigurationSupport, AbstractElasticsearchConfiguration or AbstractReactiveElasticsearchConfiguration the refresh policy will be initialized to null. Previously the reactive code initialized this to IMMEDIATE, now reactive and non-reactive code show the same behaviour.
也就是说,对es数据库进行数据变更操作时,默认是按照索引自带的刷新策略(一般情况下是1s以后才会更新索引)
{ "settings": {}, "defaults": { "index": { "refresh_interval": "1s" } } }
如果想要在Spring data es中更新数据后立即刷新,那么需要如下配置覆盖掉Springboot的Auto Configuration:
@Configuration @EnableConfigurationProperties(ElasticsearchProperties.class) public class ElasticsearchConfig extends ElasticsearchConfiguration { private final ElasticsearchProperties properties; public ElasticsearchConfig(ElasticsearchProperties properties) { this.properties = properties; } @NotNull @Override public ClientConfiguration clientConfiguration() { List<String> uris = properties.getUris(); String[] uri = uris.toArray(new String[0]); return ClientConfiguration.builder() .connectedTo(uri) .withSocketTimeout(properties.getSocketTimeout()) .withConnectTimeout(properties.getConnectionTimeout()) .build(); } @NotNull @Bean(name = { "elasticsearchOperations", "elasticsearchTemplate" }) @Override public ElasticsearchOperations elasticsearchOperations(@NotNull ElasticsearchConverter elasticsearchConverter, @NotNull ElasticsearchClient elasticsearchClient) { ElasticsearchTemplate template = new ElasticsearchTemplate(elasticsearchClient, elasticsearchConverter); template.setRefreshPolicy(RefreshPolicy.IMMEDIATE); return template; } }
以上就是Spring Data Elasticsearch 5.0.x修改数据后无法立即刷新解决方法示例的详细内容,更多关于Spring Data Elasticsearch无法刷新的资料请关注脚本之家其它相关文章!
相关文章
Springboot项目中运用vue+ElementUI+echarts前后端交互实现动态圆环图(推荐)
今天给大家带来一篇教程关于Springboot项目中运用vue+ElementUI+echarts前后端交互实现动态圆环图的技能,包括环境配置及圆环图前端后端实现代码,感兴趣的朋友一起看看吧2021-06-06解决gateway报netty堆外内存溢出io.netty.util.internal.OutOfDirectMemor
这篇文章主要介绍了解决gateway报netty堆外内存溢出io.netty.util.internal.OutOfDirectMemoryError,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-12-12Atomikos + MybatisPlus解决多数据源事务一致性问题解决
在实际项目的开发过程中,我们经常会遇到在同一个项目或微服务中牵涉到使用两个或多个数据源的,本文主要介绍了Atomikos + MybatisPlus解决多数据源事务一致性问题解决,具有一定的参考价值,感兴趣的可以了解一下2024-07-07maven install报错中程序包xxx不存在的问题解决
本文主要介绍了maven install报错中程序包xxx不存在的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-05-05
最新评论