apache solr 响应中的字段在应该是单数时是多值的

Fields in apache solr response are multivalued when they should be singular

我在使用 Apache Solr 时遇到问题,我收到的字段包含在 JSON 响应的列表中,但它们应该是单数的。这是 schema.xml 的摘录,给我一个问题的两个示例字段是 django_ctdjango_id:

  <fields>
    <!-- general -->
    <field name="id" type="string" indexed="true" stored="true" multiValued="false" required="true"/>
    <field name="django_ct" type="string" indexed="true" stored="true" multiValued="false"/>
    <field name="django_id" type="string" indexed="true" stored="true" multiValued="false"/>

这是一个如何将数据发布到 Solr 的示例:

<doc>
    <field name="id">search.productcategory.3</field>
    <field name="gender">M</field>
    <field name="name">OBQYHSOQLWOUEHRMPSDI</field>
    <field name="text">M\nOBQYHSOQLWOUEHRMPSDI</field>
    <field name="django_id">3</field>
    <field name="django_ct">search.productcategory</field>
</doc>

下面是存储在 solr 中的文件示例:

  "response": {
    "numFound": 1,
    "start": 0,
    "docs": [
      {
        "django_ct": [
          "search.productcategory"
        ],
        "name": [
          "Example"
        ],
        "text": [
          "Male\nExample"
        ],
        "id": "search.productcategory.2",
        "gender": [
          "Male"
        ],
        "django_id": [
          2
        ],
        "_version_": 1502081283634757600
      }
    ]
  }

是什么导致这些字段被包含在列表中?在架构中,这些字段的 multiValued 属性设置为 false。除了创建核心和替换 schema.xml 之外,其他一切都是开箱即用的。我正在使用 Haystack(一个 Django 插件)访问 Solr,代码期望接收这些字段的单个值,但完全被这个破坏了。追溯问题似乎是由于 Solr 的配置方式所致。

编辑:这是 solr.log 的完整内容,所有这些都是在启动服务器后记录的,运行 几个示例查询没有输出:

INFO  - 2015-05-27 08:38:12.563; [   ] org.eclipse.jetty.server.Server; jetty-8.1.10.v20130312
INFO  - 2015-05-27 08:38:12.586; [   ] org.eclipse.jetty.deploy.providers.ScanningAppProvider; Deployment monitor /Users/sampeka/solr-5.1.0/server/contexts at interval 0
INFO  - 2015-05-27 08:38:12.593; [   ] org.eclipse.jetty.deploy.DeploymentManager; Deployable added: /Users/sampeka/solr-5.1.0/server/contexts/solr-jetty-context.xml
INFO  - 2015-05-27 08:38:13.629; [   ] org.eclipse.jetty.webapp.StandardDescriptorProcessor; NO JSP Support for /solr, did not find org.apache.jasper.servlet.JspServlet
INFO  - 2015-05-27 08:38:13.682; [   ] org.apache.solr.servlet.SolrDispatchFilter; SolrDispatchFilter.init()WebAppClassLoader=1121453612@42d8062c

找到了问题的根源。问题是 solrconfig.xml 配置不正确。默认情况下,schemafactory class 设置为 ManagedIndexSchemaFactory,这会覆盖 schema.xml 的使用。通过将 schemaFactory 更改为 class ClassicIndexSchemaFactory 它会强制使用 schema.xml 并使模式通过 API 调用不可变。