使用SolrJ建立索引时,HttpSolrServer可用,EmbeddedSolrServer报错:Error opening new searcher,Caused by: Lock obtain timed out: NativeFSLock。
出现以上问题的原因是无法获取锁。查阅了很多资料都说在solrconfig文件中加上<unlockOnStartup> true </unlockOnStartup>,但是没有用。最后发现是程序启动的时候SolrDispatchFilter初始化了CoreContainer(项目沿用了solr自带的管理界面),导致EmbeddedSolrServer不能load CoreContainer。
解决方法:
1、修改web.xml文件中过滤器SolrRequestFilter的class为org.common.servlet.SolrDispatchFilter。(这个类需要自己创建)
2、在solr官网上下载solr源代码,找到org.common.servlet.SolrDispatchFilter。复制java文件代码。
3、在org.common.servlet包下创建org.common.servlet.SolrDispatchFilter类,将复制的代码拷贝进来(注意修改package)。
4、同上复制BaseSolrFilter类至org.common.servlet包下。
5、org.common.servlet.SolrDispatchFilter中几个语句会报错,是因为那几个类不在当前包下,安装eclipse的提示直接导入这些包就行了。
6、为org.common.servlet.SolrDispatchFilte类添加静态域和静态方法。静态域为:
public static CoreContainer indexCoreContainer;
静态方法为:
public static CoreContainer getIndexCores() { return indexCoreContainer; }
并在已有createCoreContainer()方法中为静态域赋值:
protected CoreContainer createCoreContainer() { SolrResourceLoader loader = new SolrResourceLoader(SolrResourceLoader.locateSolrHome()); ConfigSolr config = loadConfigSolr(loader); CoreContainer cores = new CoreContainer(loader, config); cores.load(); indexCoreContainer=cores; return cores; }
7、调用,完成。
CoreContainer container = SolrDispatchFilter.getIndexCores(); EmbeddedSolrServer solr = new EmbeddedSolrServer( container, "fulltext" );