solr在升级到8.8后对部分更新抛出错误

kq0g1dla  于 2021-10-10  发布在  Java
关注(0)|答案(1)|浏览(708)

我正在做一个简单的部分更新场景,它使用solr的6.x和7.x版本。将solr和solrj升级到8.8后,我得到以下异常:

2021-02-23 14:57:58.201 ERROR (qtp-459670553-28) [   x:core1] o.a.s.h.RequestHandlerBase org.apache.solr.common.SolrException: TransactionLog doesn't know how to serialize class org.apache.lucene.document.LazyDocument$LazyField; try implementing ObjectResolver?
    at org.apache.solr.update.TransactionLog$1.resolve(TransactionLog.java:100)
    at org.apache.solr.common.util.JavaBinCodec.writeVal(JavaBinCodec.java:266)
    at org.apache.solr.common.util.JavaBinCodec$BinEntryWriter.put(JavaBinCodec.java:441)
    at org.apache.solr.common.ConditionalKeyMapWriter$EntryWriterWrapper.put(ConditionalKeyMapWriter.java:44)
    at org.apache.solr.common.MapWriter$EntryWriter.putNoEx(MapWriter.java:101)
    at org.apache.solr.common.MapWriter$EntryWriter.lambda$getBiConsumer$0(MapWriter.java:161)
    at org.apache.solr.common.MapWriter$EntryWriter$$Lambda$548/0000000000000000.accept(Unknown Source)
    at org.apache.solr.common.SolrInputDocument.lambda$writeMap$0(SolrInputDocument.java:59)
    at org.apache.solr.common.SolrInputDocument$$Lambda$549/0000000000000000.accept(Unknown Source)
    .....

solrj代码与这里提供的示例非常相似,在升级之前就已经工作了。操作为“添加”,其中包含一个简单的整数字段,用于提供id的文档。
注意,这与前面关于stackoverflow的问题不同,因为我传递的是简单的整数字段,在solr/lucene端,它被替换为 org.apache.lucene.document.LazyDocument$LazyField .

jdzmm42g

jdzmm42g1#

似乎是solr中的一个bughttps://issues.apache.org/jira/browse/solr-13034 将在solr 8(8.9)的下一版本中修复。
在发布之前,解决方法是设置 <enableLazyFieldLoading>false</enableLazyFieldLoading> 在solrconfig.xml中

相关问题