我自己写了一个分词器插件,并用maven成功编译了它。并且 elasticsearch 在安装后运行良好。但是当我尝试使用它来分割句子时,我收到以下错误消息:
java.lang.NoClassDefFoundError: com/github/kevinsawicki/http/HttpRequest
at org.elasticsearch.thulac.MyTokenizer.thulacSeg(MyTokenizer.java:32)
at org.elasticsearch.thulac.MyTokenizer.<init>(MyTokenizer.java:64)
at org.elasticsearch.thulac.MyAnalyzer.createComponents(MyAnalyzer.java:12)
at org.apache.lucene.analysis.AnalyzerWrapper.createComponents(AnalyzerWrapper.java:113)
at org.apache.lucene.analysis.Analyzer.tokenStream(Analyzer.java:182)
at org.elasticsearch.action.admin.indices.analyze.TransportAnalyzeAction.shardOperation(TransportAnalyzeAction.java:230)
at org.elasticsearch.action.admin.indices.analyze.TransportAnalyzeAction.shardOperation(TransportAnalyzeAction.java:60)
at org.elasticsearch.action.support.single.custom.TransportSingleCustomOperationAction$AsyncSingleAction$1.run(TransportSingleCustomOperationAction.java:161)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:724)
我使用 kevinsawicki/http-request。是因为我没有将 http-request jar 放入 elasticsearch java 路径吗?如有必要,我应该把它放在哪里?
谢谢。
是的,你需要将jar文件提供给elasticsearch的lib文件夹。
哪里?这取决于 elasticsearch 的安装位置。例如,使用find / -type d -name elasticsearch
查找目录。在 Centos 上它是 /usr/share/elasticsearch/
,其中包含一个lib
子文件夹。或更舒适:
- 在 Debian 系统上,您可以使用
dpkg -L elasticsearch
和 - 在基于 rpm 的系统(如 Centos、RedHat、Suse 等)上,您可以使用
rpm -ql elasticsearch
来查找。
尝试在此lib
文件夹中部署代码和所有依赖库。