You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
118 lines
4.6 KiB
118 lines
4.6 KiB
/**
|
|
* EmbeddedSolrConnector
|
|
* Copyright 2012 by Michael Peter Christen
|
|
* First released 21.06.2012 at http://yacy.net
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program in the file lgpl21.txt
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
|
|
package net.yacy.search.solr;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
|
|
import javax.xml.parsers.ParserConfigurationException;
|
|
|
|
import net.yacy.cora.services.federated.solr.AbstractSolrConnector;
|
|
import net.yacy.cora.services.federated.solr.SolrConnector;
|
|
import net.yacy.cora.services.federated.solr.SolrDoc;
|
|
import net.yacy.kelondro.logging.Log;
|
|
import net.yacy.search.index.SolrField;
|
|
|
|
import org.apache.solr.client.solrj.embedded.EmbeddedSolrServer;
|
|
import org.apache.solr.common.SolrDocument;
|
|
import org.apache.solr.common.SolrDocumentList;
|
|
import org.apache.solr.core.CoreContainer;
|
|
import org.xml.sax.SAXException;
|
|
|
|
import com.google.common.io.Files;
|
|
|
|
public class EmbeddedSolrConnector extends AbstractSolrConnector implements SolrConnector {
|
|
|
|
private final CoreContainer core;
|
|
private final static String[] confFiles = {"solrconfig.xml", "schema.xml", "stopwords.txt", "synonyms.txt", "protwords.txt", "currency.xml", "elevate.xml", "lang/"};
|
|
//private final static String[] confFiles = {"solrconfig.xml", "schema.xml", "stopwords.txt", "synonyms.txt", "protwords.txt", "currency.xml", "elevate.xml", "lang/"};
|
|
|
|
public EmbeddedSolrConnector(File storagePath, File solr_config) throws IOException {
|
|
super();
|
|
// copy the solrconfig.xml to the storage path
|
|
File conf = new File(storagePath, "conf");
|
|
conf.mkdirs();
|
|
File source, target;
|
|
for (String cf: confFiles) {
|
|
source = new File(solr_config, cf);
|
|
if (source.isDirectory()) {
|
|
target = new File(conf, cf);
|
|
target.mkdirs();
|
|
for (String cfl: source.list()) {
|
|
Files.copy(new File(source, cfl), new File(target, cfl));
|
|
}
|
|
} else {
|
|
target = new File(conf, cf);
|
|
target.getParentFile().mkdirs();
|
|
Files.copy(source, target);
|
|
}
|
|
}
|
|
try {
|
|
this.core = new CoreContainer(storagePath.getAbsolutePath(), new File(solr_config, "solr.xml"));
|
|
} catch (ParserConfigurationException e) {
|
|
throw new IOException(e.getMessage(), e);
|
|
} catch (SAXException e) {
|
|
throw new IOException(e.getMessage(), e);
|
|
}
|
|
super.init(new EmbeddedSolrServer(this.core, "collection1"));
|
|
}
|
|
|
|
@Override
|
|
public void close() {
|
|
super.close();
|
|
this.core.shutdown();
|
|
}
|
|
|
|
public static void main(String[] args) {
|
|
File solr_config = new File("defaults/solr");
|
|
File storage = new File("DATA/INDEX/webportal/SEGMENTS/text/solr/");
|
|
storage.mkdirs();
|
|
try {
|
|
EmbeddedSolrConnector solr = new EmbeddedSolrConnector(storage, solr_config);
|
|
SolrDoc solrdoc = new SolrDoc();
|
|
solrdoc.addSolr(SolrField.id, "ABCD0000abcd");
|
|
solrdoc.addSolr(SolrField.title, "Lorem ipsum");
|
|
solrdoc.addSolr(SolrField.text_t, "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.");
|
|
solr.add(solrdoc);
|
|
SolrDocumentList searchresult = solr.get(SolrField.text_t.name() + ":tempor", 0, 10);
|
|
for (SolrDocument d: searchresult) {
|
|
System.out.println(d.toString());
|
|
}
|
|
solr.close();
|
|
/*
|
|
JettySolrRunner solrJetty = new JettySolrRunner("/solr", 8091, storage.getAbsolutePath());
|
|
try {
|
|
solrJetty.start();
|
|
String url = "http://localhost:" + solrJetty.getLocalPort() + "/solr";
|
|
SolrServer server = new HttpSolrServer(url);
|
|
} catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
*/
|
|
} catch (IOException e) {
|
|
Log.logException(e);
|
|
}
|
|
|
|
}
|
|
|
|
}
|