Плагин Grails с возможностью поиска ClassNotFoundException: org.apache.lucene.analysis.Analyzer$TokenStreamComponents

Я использую плагин с возможностью поиска 0.6.9 с Grails 2.4.4 и на моей машине для разработки (Windows/IntelliJ IDEA) все работает отлично. Однако при развертывании его на моем Tomcat в Linux возникает следующая ошибка:

    ...

    2014-12-01 10:20:46,066 [localhost-startStop-1] ERROR StackTrace  - Full Stack Trace:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'grails.plugin.searchable.SearchableController': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'searchableService': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'compass': FactoryBean threw exception on object creation; nested exception is java.lang.NoClassDefFoundError: org/apache/lucene/analysis/Analyzer$TokenStreamComponents
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    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:744)
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'searchableService': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'compass': FactoryBean threw exception on object creation; nested exception is java.lang.NoClassDefFoundError: org/apache/lucene/analysis/Analyzer$TokenStreamComponents
    ... 5 more
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'compass': FactoryBean threw exception on object creation; nested exception is java.lang.NoClassDefFoundError: org/apache/lucene/analysis/Analyzer$TokenStreamComponents
    ... 5 more
Caused by: java.lang.NoClassDefFoundError: org/apache/lucene/analysis/Analyzer$TokenStreamComponents
    at org.compass.core.lucene.engine.analyzer.CoreAnalyzerBuilderDelegate.buildAnalyzer(CoreAnalyzerBuilderDelegate.java:47)
    at org.compass.core.lucene.engine.analyzer.DefaultLuceneAnalyzerFactory.createAnalyzer(DefaultLuceneAnalyzerFactory.java:81)
    at org.compass.core.lucene.engine.analyzer.LuceneAnalyzerManager.buildAnalyzer(LuceneAnalyzerManager.java:225)
    at org.compass.core.lucene.engine.analyzer.LuceneAnalyzerManager.buildAnalyzers(LuceneAnalyzerManager.java:133)
    at org.compass.core.lucene.engine.analyzer.LuceneAnalyzerManager.<init>(LuceneAnalyzerManager.java:67)
    at org.compass.core.lucene.engine.LuceneSearchEngineFactory.<init>(LuceneSearchEngineFactory.java:119)
    at org.compass.core.impl.DefaultCompass.<init>(DefaultCompass.java:124)
    at org.compass.core.impl.DefaultCompass.<init>(DefaultCompass.java:117)
    at org.compass.core.config.CompassConfiguration.buildCompass(CompassConfiguration.java:288)
    at grails.plugin.searchable.internal.compass.spring.SearchableCompassFactoryBean.buildCompass(SearchableCompassFactoryBean.java:95)
    at grails.plugin.searchable.internal.compass.spring.SearchableCompassFactoryBean.getObject(SearchableCompassFactoryBean.java:58)
    at grails.plugin.searchable.internal.compass.spring.SearchableCompassFactoryBean.getObject(SearchableCompassFactoryBean.java:41)
    ... 5 more
Caused by: java.lang.ClassNotFoundException: org.apache.lucene.analysis.Analyzer$TokenStreamComponents
    ... 17 more

Кажется, что класс org.apache.lucene.analysis.Analyzer не содержит TokenStreamComponents в lucene 2.4.1 (который является зависимостью для поиска 0.6.9). Но, как я уже писал, он отлично работает на моей машине для разработки.

PS: на линуксе файл war создается хадсоном.

ОБНОВИТЬ:

На моей dev-машине он тоже не запускается как война, а запускается app-app. Я понятия не имею, почему он пытается использовать метод, который отсутствует при запуске в качестве файла войны.

Заранее благодарны за Вашу помощь.

1 ответ

Решение

РЕШИТЬ:

К сожалению, решение было простым: у меня также был установлен плагин Jasper, и он загружал lucene 4.5.1 в качестве зависимости. Исключая это с

compile (":jasper:1.10.0") {
            excludes 'org.apache.lucene:lucene-core:4.5.1'
            excludes 'org.apache.lucene:lucene-analyzers-common:4.5.1'
            excludes 'org.apache.lucene:lucene-queryparser:4.5.1'
        }

все работает как положено.

Другие вопросы по тегам