0

我正在使用带有manifoldcf .5.1 的solr 4.0 alpha,我下载并构建了authority-example.jar 并放置在example/solr/lib 中,并将适当的行添加到solrconfig.xml。我注意到 authority-example.jar 是用 solr v3.2 jar 构建的,这与 solr4.0 兼容吗?如果我将所有旧罐子换成新罐子,我可以重建罐子吗?我该如何解决?请告知...错误是:

SEVERE: null:org.apache.solr.common.SolrException: Error loading class 'org.apac
he.solr.mcf.ManifoldCFSearchComponent'
        at org.apache.solr.core.SolrResourceLoader.findClass(SolrResourceLoader.
java:415)
        at org.apache.solr.core.SolrCore.createInstance(SolrCore.java:420)
        at org.apache.solr.core.SolrCore.createInitInstance(SolrCore.java:463)
        at org.apache.solr.core.SolrCore.initPlugins(SolrCore.java:1824)
        at org.apache.solr.core.SolrCore.initPlugins(SolrCore.java:1818)
        at org.apache.solr.core.SolrCore.initPlugins(SolrCore.java:1851)
        at org.apache.solr.core.SolrCore.loadSearchComponents(SolrCore.java:906)

        at org.apache.solr.core.SolrCore.<init>(SolrCore.java:572)
        at org.apache.solr.core.SolrCore.<init>(SolrCore.java:504)
        at org.apache.solr.core.CoreContainer.create(CoreContainer.java:816)
        at org.apache.solr.core.CoreContainer.load(CoreContainer.java:510)
        at org.apache.solr.core.CoreContainer.load(CoreContainer.java:333)
        at org.apache.solr.core.CoreContainer$Initializer.initialize(CoreContain
er.java:282)
        at org.apache.solr.servlet.SolrDispatchFilter.init(SolrDispatchFilter.ja
va:101)
        at org.eclipse.jetty.servlet.FilterHolder.doStart(FilterHolder.java:114)

        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.ja
va:754)
        at org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletC
ontextHandler.java:258)
        at org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.jav
a:1221)
        at org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandle
r.java:699)
        at org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:454
)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.deploy.bindings.StandardStarter.processBinding(Stan
dardStarter.java:36)
        at org.eclipse.jetty.deploy.AppLifeCycle.runBindings(AppLifeCycle.java:1
83)
        at org.eclipse.jetty.deploy.DeploymentManager.requestAppGoal(DeploymentM
anager.java:491)
        at org.eclipse.jetty.deploy.DeploymentManager.addApp(DeploymentManager.j
ava:138)
        at org.eclipse.jetty.deploy.providers.ScanningAppProvider.fileAdded(Scan
ningAppProvider.java:142)
        at org.eclipse.jetty.deploy.providers.ScanningAppProvider$1.fileAdded(Sc
anningAppProvider.java:53)
        at org.eclipse.jetty.util.Scanner.reportAddition(Scanner.java:604)
        at org.eclipse.jetty.util.Scanner.reportDifferences(Scanner.java:535)
        at org.eclipse.jetty.util.Scanner.scan(Scanner.java:398)
        at org.eclipse.jetty.util.Scanner.doStart(Scanner.java:332)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.deploy.providers.ScanningAppProvider.doStart(Scanni
ngAppProvider.java:118)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.deploy.DeploymentManager.startAppProvider(Deploymen
tManager.java:552)
        at org.eclipse.jetty.deploy.DeploymentManager.doStart(DeploymentManager.
java:227)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.util.component.AggregateLifeCycle.doStart(Aggregate
LifeCycle.java:63)
        at org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHand
ler.java:53)
        at org.eclipse.jetty.server.handler.HandlerWrapper.doStart(HandlerWrappe
r.java:91)
        at org.eclipse.jetty.server.Server.doStart(Server.java:263)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLife
Cycle.java:59)
        at org.eclipse.jetty.xml.XmlConfiguration$1.run(XmlConfiguration.java:12
15)
        at java.security.AccessController.doPrivileged(Native Method)
        at org.eclipse.jetty.xml.XmlConfiguration.main(XmlConfiguration.java:113
8)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
        at org.eclipse.jetty.start.Main.invokeMain(Main.java:457)
        at org.eclipse.jetty.start.Main.start(Main.java:602)
        at org.eclipse.jetty.start.Main.main(Main.java:82)
Caused by: java.lang.ClassNotFoundException: org.apache.solr.mcf.ManifoldCFSearc
hComponent
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at java.net.FactoryURLClassLoader.loadClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at java.lang.Class.forName0(Native Method)
        at java.lang.Class.forName(Unknown Source)
        at org.apache.solr.core.SolrResourceLoader.findClass(SolrResourceLoader.
java:399)
        ... 52 more
4

1 回答 1

0

好的,我想通了,但是这本书(ManifoldCF in Action)不清楚。我构建了 authority-example.jar 并将它与 apache-solr-mcf-4.0-SNAPSHOT.jar 及其依赖项一起放在 SOLR_HOME/lib 目录中。这解决了很多错误,例如上面的错误。下一个问题是在 solrconfi.xml 文件中放入什么。书上说把这个放进去:

<requestHandler name="search" class="solr.SearchHandler" default="true">
<arr name="last-components">
<str>manifoldCFSecurity</str>
</arr>
...
</requestHandler>

好吧,这行不通!要修复它,您需要采取胆量(last-components 和manifoldcfsecurity)并将它们放入requesthandlers /browse /select /query 等,然后相应地过滤查询结果!我很自然地认为,出于显而易见的原因,大多数请求处理程序(如果不是所有请求处理程序)都需要打开安全性。我还假设上面的请求处理程序必须是 name="/search" 才能工作,但我还没有尝试过。

于 2012-08-01T16:49:27.050 回答