0
我想索引一些xml文件到Solr 6.2.1使用他們的DataImportHandler。Apache Solr DataImportHandler失敗試圖索引
<lib dir="${solr.install.dir:../../../..}/contrib/dataimporthandler/lib/" regex=".*\.jar" />
<lib dir="${solr.install.dir:../../../..}/dist/" regex="solr-dataimporthandler-.*\.jar" />
<requestHandler name="/dataimport" class="org.apache.solr.handler.dataimport.DataImportHandler" startup="lazy">
<lst name="default">
<str name="config">data-config.xml</str>
</lst>
</requestHandler>
然後我寫了數據-config.xml中,放入相同的路徑solrconfig.xml中:爲此我已經加入所需的進口,這RequestHandler到solrconfig.xml中
:
<dataConfig>
<dataSource type="FileDataSource" encoding="UTF-8"/>
<document>
<entity name="pickupdir"
processor="FileListEntityProcessor"
dataSource="null"
baseDir="/vagrant/TREC8all/Adhoc/"
recursive="true"
fileName="^[\w\d-]+\.xml$" />
<entity name="trec8_simple"
processor="XPathEntityProcessor"
stream="true"
datasource="pickupdir"
url="${pickupdir.fileAbsolutePath}"
forEach="/DOCS/DOC">
<field column="id" xpath="/DOCS/DOC/DOCNO"/>
<field column="header" xpath="/DOCS/DOC/HEADER"/>
<field column="text" xpath="/DOCS/DOC/TEXT"/>
</entity>
</document>
</dataConfig>
這應該使ImportHandler通過他們根據XPath的目錄和索引所有的XML文件遞歸迭代。
當我打電話這樣的requestHandler:(我正在運行在一個流浪漢框,而不是本地SOLR)是
http://192.168.155.156:8983/solr/trec8/dataimport?command=full-import&entity=trec8_simple
我得到這個例外在solr.log:
ERROR (Thread-14) [ x:trec8] o.a.s.h.d.DataImporter Full Import failed:java.lang.NullPointerException
at org.apache.solr.handler.dataimport.DataImporter.createPropertyWriter(DataImporter.java:325)
at org.apache.solr.handler.dataimport.DataImporter.doFullImport(DataImporter.java:412)
at org.apache.solr.handler.dataimport.DataImporter.runCmd(DataImporter.java:475)
at org.apache.solr.handler.dataimport.DataImporter.lambda$runAsync$0(DataImporter.java:458)
at java.lang.Thread.run(Thread.java:745)
林假定這應該是DataImportHandler源:
我很難弄清楚是什麼導致這個異常以及它是什麼意思。如果有人能幫助我,那會很好。謝謝!
編輯: 我認爲這與DataImportHandler無法找到data-config.xml有關。當我刪除它會拋出完全相同的異常