ES更新问题 Failed to close the XContentBuilder异常

问题描述

使用RestHighLevelClient对文档进行局部更新的时候报错如下:

复制代码
Suppressed: java.lang.IllegalStateException: Failed to close the XContentBuilder
		at org.elasticsearch.common.xcontent.XContentBuilder.close(XContentBuilder.java:1011)
		at org.elasticsearch.common.xcontent.XContentHelper.toXContent(XContentHelper.java:362)
		... 8 more
	Caused by: java.io.IOException: Unclosed object or array found
		at org.elasticsearch.common.xcontent.json.JsonXContentGenerator.close(JsonXContentGenerator.java:469)
		at org.elasticsearch.common.xcontent.XContentBuilder.close(XContentBuilder.java:1009)
		... 9 more

相关代码如下:

复制代码
UpdateRequest request = new UpdateRequest("user","1001");
request.doc(XContentType.JSON, "sex","男");

UpdateResponse updateResponse = client.update(request, RequestOptions.DEFAULT);

分析排查问题过程

下面这是ES 7.9.3版本客户端局部更新的文档,每种写法都试过了,报错都一样的

Update API | Java REST Client [7.9] | Elastic

基本排除代码问题,怀疑是客户端版本bug

客户端升级到7.17.1,问题解决

后续发现

因为我一直在elasticsearch仓库找不到对应的issue和问题修复代码,我就继续查了下,无意中发现存在maven依赖冲突,将log4j-core的冲突排掉后,问题竟然也解决了。

所以应该不是7.9.3版本的bug,而是本地依赖冲突,日志相关功能影响到XcontentBuilder关闭,具体的等日后加深理解后再继续分析

相关推荐
专注代码七年5 分钟前
IDEA大幅度提升编译速度配置
java·ide·intellij-idea
max5006008 分钟前
嵌入用户idea到大模型并针对Verilog语言生成任务的微调实验报告
java·ide·intellij-idea
gb421528735 分钟前
Elasticsearch 搭建(亲测)
大数据·elasticsearch·jenkins
根哥的博客36 分钟前
ElasticSearch启用Xpack,配置ssl证书
elasticsearch·ssl
syty202039 分钟前
AST语法树应用于sql检查
java·开发语言·ast
Code blocks2 小时前
SpringBoot快速生成二维码
java·spring boot·后端
万笑佛2 小时前
java从word模板生成.doc和.wps文件
java
大厂码农老A2 小时前
P10老板一句‘搞不定就P0’,15分钟我用Arthas捞回1000万资损
java·前端·后端
nlog3n2 小时前
分布式任务事务框架设计与实现方案
java·分布式