elastic search的document在正常情况下更新是没什么问题的,但是如果刚好在ttl到期的同时去更新这个document,会有什么问题呢?
这两天刚好遇到了这个情况,报如下异常:
Caused by: org.elasticsearch.ElasticsearchIllegalArgumentException: TTL value must be > 0. Illegal value provided [-29996]
可以看到报错信息为,要求ttl>0,但是实际ttl值<0,但是实际上这整个索引表的ttl都是在创建索引的mapping时候设置的,为15d
为了更深刻的了解此问题,笔者做了实验,在测试环境新建了一个es索引表,并设置整表数据过期时间为5m,然后新加一个document,设置其过期时间为10m,在10m即将快到期的时候,更新该文档,刚好到10m的时候,果然报错了,报错信息如下图:
大概过了3s左右,仍然执行相同的更新命令,此时又能更新正常了,如下图:
但是此时原来的整个document已经没有了,留下的是你这次update的document,只有你update的字段才有值。
更多推荐
es中doucment失效的同时更新可能出现的问题
发布评论