我刚刚安装了 Solr,我现在正在尝试学习如何使用它。我想使用Solr Cell和langid功能,所以我按照链接的教程进行操作。Solr Cell 可以工作,但我什么也做不了。
在solrconfig.xml
,我有这个:
<updateRequestProcessorChain name="langid">
<processor class="org.apache.solr.update.processor.LangDetectLanguageIdentifierUpdateProcessorFactory">
<str name="langid.fl">text,title,subject,description</str>
<str name="langid.langField">language_s</str>
<str name="langid.fallback">en</str>
<bool name="langid.map">true</bool>
</processor>
<processor class="solr.LogUpdateProcessorFactory" />
<processor class="solr.RunUpdateProcessorFactory" />
</updateRequestProcessorChain>
(我也尝试过 Tika),我使用
curl "http://localhost:8983/solr/update/extract?literal.id=test&commit=true" -F "myfile=@test.xml"
但是当我查询时,text:[* TO *]
把我的文件还给我,但text_en:[* TO *]
没有;language_s
,即使我声明它是已存储的,也顽固地不存在;*:word
即使有也没有找到任何东西,"words"
所以它没有被阻止;我在日志中找不到任何东西。我最好的猜测是,langid 没有运行,我不知道为什么。
编辑:找到答案:阅读更多文档:p
由于 langid 被配置为更新请求处理器链,它需要被选中(它不是自动的)。所以,这有效:
curl "http://localhost:8983/solr/update/extract?literal.id=test&commit=true&update.chain=langid" -F "myfile=@test.xml"