首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Solar索引大型文档导致异常

使用Solar索引大型文档导致异常
EN

Stack Overflow用户
提问于 2017-10-12 17:20:31
回答 1查看 98关注 0票数 1

我正在尝试使用pysolr将文档添加到Solr (5.3.2)中。我生成了一个简单的JSON对象,其中包含一个大文本和一些元数据(日期、作者...)然后我尝试将其添加到Solr中。我的问题是,超过一定的大小,Solr将无法对文档进行索引,并返回以下错误:

代码语言:javascript
复制
Solr responded with an error (HTTP 400): [Reason: Exception writing document id e2699f18-ab5f-47f6-a450-60db5621879c to the index; possible analysis error.]

字段长度似乎真的有一个硬编码的限制,但我找不到它。

通过使用python,我发现:

代码语言:javascript
复制
default_obj['content'] = content[:13260]

将工作得很好,同时

代码语言:javascript
复制
default_obj['content'] = content[:13261]

将导致错误。

在我的schema.xml中,content字段被定义为一个普通的type="text_general“字段。

编辑:这里是schema.xml的定义

代码语言:javascript
复制
<field name="content" type="text_general" indexed="true" stored="true" multiValued="true"/>


<fieldType name="text_general" class="solr.TextField" positionIncrementGap="100">
  <analyzer type="index">
    <tokenizer class="solr.StandardTokenizerFactory"/>
    <filter class="solr.LowerCaseFilterFactory"/>
  </analyzer>
  <analyzer type="query">
    <tokenizer class="solr.StandardTokenizerFactory"/>
    <filter class="solr.LowerCaseFilterFactory"/>
  </analyzer>
</fieldType>

我尝试过通过Solr的web管理界面手动添加内容,但遇到了完全相同的问题。

EN

回答 1

Stack Overflow用户

发布于 2017-10-12 21:07:17

您最有可能面临单令牌方面的硬限制,即等于32766。您不能更改这个限制,但是您可以更改行为,并使用一些Tokenizer将文档中的原始文本拆分为单独的标记。

例如,您可以尝试WhitespaceTokenizer,它将在多个术语/标记中分隔您的大字段,并且您的文档将被安全地索引。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46705866

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档