當前位置: 首頁>>代碼示例>>Java>>正文


Java HttpSolrClient類代碼示例

本文整理匯總了Java中org.apache.solr.client.solrj.impl.HttpSolrClient的典型用法代碼示例。如果您正苦於以下問題:Java HttpSolrClient類的具體用法?Java HttpSolrClient怎麽用?Java HttpSolrClient使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


HttpSolrClient類屬於org.apache.solr.client.solrj.impl包,在下文中一共展示了HttpSolrClient類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: createNewSolrClient

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
protected static HttpSolrClient createNewSolrClient(final String core) {
	try {
		URL url = jetty.getBaseUrl();

		// For debugging in Charles:
		// - set the proxy port to 8888
		// - enable transparent proxying
		// - enable Map Remote and map 127.0.0.1:8888 to 127.0.0.1:8080
		url = new URL(url.getProtocol(), url.getHost(), url.getPort(), url.getFile() + "/" + core);

		ModifiableSolrParams params = new ModifiableSolrParams();
		params.add(HttpClientUtil.PROP_CONNECTION_TIMEOUT, Integer.toString(DEFAULT_CONNECTION_TIMEOUT));

		return new HttpSolrClient.Builder(url.toString()).
				withHttpClient(HttpClientUtil.createClient(params)).build();
	} catch(Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:ICIJ,項目名稱:extract,代碼行數:20,代碼來源:SolrJettyTestBase.java

示例2: getHttpSolrClients

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 *
 * @param cloudSolrClient
 * @return
 * @throws SolrServerException
 * @throws IOException
 */
private List<HttpSolrClient> getHttpSolrClients(CloudSolrClient cloudSolrClient) throws SolrServerException, IOException {
    List<HttpSolrClient> solrClients = new ArrayList<>();

    for (String baseUrl : getBaseUrls(cloudSolrClient)) {
        NoOpResponseParser responseParser = new NoOpResponseParser();
        responseParser.setWriterType("json");

        HttpSolrClient.Builder builder = new HttpSolrClient.Builder();
        builder.withBaseSolrUrl(baseUrl);

        HttpSolrClient httpSolrClient = builder.build();
        httpSolrClient.setParser(responseParser);

        solrClients.add(httpSolrClient);
    }

    return solrClients;
}
 
開發者ID:mosuka,項目名稱:solr-exporter,代碼行數:26,代碼來源:SolrCollector.java

示例3: indexMap

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public void indexMap(String id, Map<String, List<String>> objectMap)
   throws IOException, SolrServerException {
    SolrInputDocument document = new SolrInputDocument();
    document.addField("id", id);
    for (String key : objectMap.keySet()) {
        Object value = objectMap.get(key);
        if (value != null) {
            // System.err.printf("%s: class: %s\n", key, value.getClass());
            document.addField(key + "_ss", value);
        }
    }

    try {
        UpdateResponse response = solr.add(document);
        // solr.commit();
    } catch (HttpSolrClient.RemoteSolrException ex) {
        System.err.printf("document: %s", document);
        System.err.printf("Commit exception: %s\n", ex.getMessage());
    }
}
 
開發者ID:pkiraly,項目名稱:metadata-qa-marc,代碼行數:21,代碼來源:MarcSolrClient.java

示例4: getCores

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 * Get target cores via CoreAdminAPI.
 *
 * @param httpSolrClient
 * @return
 */
public static List<String> getCores(HttpSolrClient httpSolrClient) throws SolrServerException, IOException {
    List<String> cores = new ArrayList<>();

    NoOpResponseParser responseParser = new NoOpResponseParser();
    responseParser.setWriterType("json");

    httpSolrClient.setParser(responseParser);

    CoreAdminRequest coreAdminRequest = new CoreAdminRequest();
    coreAdminRequest.setAction(CoreAdminParams.CoreAdminAction.STATUS);
    coreAdminRequest.setIndexInfoNeeded(false);

    NamedList<Object> coreAdminResponse = httpSolrClient.request(coreAdminRequest);

    JsonNode statusJsonNode = om.readTree((String) coreAdminResponse.get("response")).get("status");

    for (Iterator<JsonNode> i = statusJsonNode.iterator(); i.hasNext(); ) {
        String core = i.next().get("name").textValue();
        if (!cores.contains(core)) {
            cores.add(core);
        }
    }

    return cores;
}
 
開發者ID:mosuka,項目名稱:solr-exporter,代碼行數:32,代碼來源:SolrCollector.java

示例5: indexDuplumKey

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public void indexDuplumKey(String id, Map<String, Object> objectMap)
        throws IOException, SolrServerException {
    SolrInputDocument document = new SolrInputDocument();
    document.addField("id", id);
    for (String key : objectMap.keySet()) {
        Object value = objectMap.get(key);
        if (value != null) {
            // System.err.printf("%s: class: %s\n", key, value.getClass());
            document.addField(key + "_ss", value);
        }
    }

    try {
        UpdateResponse response = solr.add(document);
        // solr.commit();
    } catch (HttpSolrClient.RemoteSolrException ex) {
        System.err.printf("document: %s", document);
        System.err.printf("Commit exception: %s\n", ex.getMessage());
    }
}
 
開發者ID:pkiraly,項目名稱:metadata-qa-marc,代碼行數:21,代碼來源:MarcSolrClient.java

示例6: main

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 * Main entry point. 
 * 
 * @param args the command line arguments.
 * @throws IOException in case of I/O failure.
 */
public static void main(String[] args) throws IOException, SolrServerException {
	
	// This is the list of documents we will send to Solr
	List<SolrInputDocument> books = new ArrayList<SolrInputDocument>();
	
	// Populate the list
	books.add(newBook("1", "Apache Solr Essentials", "Andrea Gazzarini"));
	books.add(newBook("2", "Apache Solr FullText Search Server", "John White"));
	books.add(newBook("3", "Enterprise Search with Apache Solr", "Martin Green"));	
	
	// Creates the Solr remote proxy
	try (SolrClient client = new HttpSolrClient.Builder("http://127.0.0.1:8983/solr/ex1").build()) {
		
		// Indexes data
		client.add(books);
		
		// Commits
		client.commit();
	} 
}
 
開發者ID:agazzarini,項目名稱:as-full-text-search-server,代碼行數:27,代碼來源:SampleIndexer.java

示例7: createNewSolrClient

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public SolrClient createNewSolrClient(final String index) {
	if (jetty != null) {
		try {
			// setup the client...
			String url = jetty.getBaseUrl().toString() + "/" + index;
			HttpSolrClient client = getHttpSolrClient(url);
			client.setConnectionTimeout(DEFAULT_CONNECTION_TIMEOUT);
			client.setDefaultMaxConnectionsPerHost(100);
			client.setMaxTotalConnections(100);
			return client;
		} catch (Exception ex) {
			throw new RuntimeException(ex);
		}
	} else {
		return new EmbeddedSolrServer(h.getCoreContainer(), index);
	}
}
 
開發者ID:agazzarini,項目名稱:as-full-text-search-server,代碼行數:18,代碼來源:BaseIntegrationTest.java

示例8: doFeed

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public void doFeed() throws Exception {
    this.server = new ConcurrentUpdateSolrClient(serverUrl,queueSize,threads);
    if(threads==1 && queueSize == 1) {
        this.server = new HttpSolrClient(serverUrl);
    }

    if(deleteIndex) {
        System.out.println("Delete the index.");
        server.deleteByQuery("*:*");
    }

    parse();
    server.commit();
    server.optimize();
    server.close();
}
 
開發者ID:tblsoft,項目名稱:solr-cmd-utils,代碼行數:17,代碼來源:SolrFeeder.java

示例9: connect

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 * Verbindung zum Solr-Server herstellen
 */
private void connect() {

    solrClient = new HttpSolrClient.Builder(Configuration.SOLR_SERVER_URL + Configuration.SOLR_CORE_NAME).build();

    // Verbindung zum Solr-Server prüfen
    try {
        SolrPing ping = new SolrPing();
        ping.setBasicAuthCredentials(Configuration.USERNAME, Configuration.PASSWORD);
        SolrPingResponse pingResponse = ping.process(solrClient);
        if (pingResponse.getStatus() != 0) {
            System.out.println("Es gab einen unerwarteten Fehler beim Ping auf den Solr-Server (Status-Code ist " + pingResponse.getStatus() + ")");
        }
        else {
            System.out.println("Ping zum Solr-Server war erfolgreich und dauerte " + pingResponse.getQTime() + " ms");
        }
    } catch (SolrServerException|IOException e) {
        // do something reasonable
        System.err.println(e);
    }
}
 
開發者ID:saschaszott,項目名稱:suma-tech,代碼行數:24,代碼來源:SolrSearcher.java

示例10: main

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public static void main(String[] args) throws IOException, FitsConfigurationException, NoSuchAlgorithmException {

        if (args.length < 2) {
            System.out.println("You need to add the path to the FITS directory, the URI of your Solr server, and the path to the directory to index.");
        } else {
            Fits fits = new Fits(args[0]);
            String urlString = args[1];
            SolrClient solr = new HttpSolrClient.Builder(urlString).build();
            DupeChecker dupeChecker = new DupeChecker(solr);
            FitsVisitor fv = new FitsVisitor(fits,solr,dupeChecker);

            Path startingDir = Paths.get(args[2]);
            walkFileTree(startingDir, fv);
        }

    }
 
開發者ID:little9,項目名稱:SolrFits,代碼行數:17,代碼來源:Main.java

示例11: examineFile

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
void examineFile(File file) throws FitsException, IOException, SolrServerException, XMLStreamException {
    System.out.println("Adding " + file.getName());
    FitsOutput fitsOutput = fits.examine(file);
    fitsOutput.addStandardCombinedFormat();

    SolrInputDocument solrDoc = new SolrInputDocument();

    this.indexFitsFileInfo(fitsOutput, solrDoc);
    this.indexFitsIdentities(fitsOutput, solrDoc);
    this.indexTechMetadata(fitsOutput, solrDoc);

    Document fitsXml = fitsOutput.getFitsXml();
    this.indexFitsXml(fitsXml, solrDoc);

    try {
        UpdateResponse response = solr.add(solrDoc);
        solr.commit();
    } catch (HttpSolrClient.RemoteSolrException e) {
        e.printStackTrace();
    }

}
 
開發者ID:little9,項目名稱:SolrFits,代碼行數:23,代碼來源:FitsExaminer.java

示例12: createSolrSpewer

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 * Create a new {@link SolrSpewer} by parsing the given options.
 *
 * @param options the options to parse
 * @return A new spewer configured according to the given parameters.
 */
private static SolrSpewer createSolrSpewer(final Options<String> options, final FieldNames fields) {
	final Extractor.EmbedHandling handling = options.ifPresent("embedHandling", o -> o.parse().asEnum(Extractor
			.EmbedHandling::parse)).orElse(Extractor.EmbedHandling.getDefault());

	// Calling #close on the SolrSpewer later on automatically closes the HTTP client.
	final SolrClient solrClient = new HttpSolrClient.Builder(options.get("indexAddress").value().orElse
			("http://127.0.0.1:8983/solr/"))
			.withHttpClient(createHttpClient(options))
			.build();

	if (Extractor.EmbedHandling.SPAWN == handling) {
		return new MergingSolrSpewer(solrClient, fields);
	}

	return new SolrSpewer(solrClient, fields);
}
 
開發者ID:ICIJ,項目名稱:extract,代碼行數:23,代碼來源:SpewerFactory.java

示例13: commitDocumentChanges

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
private void commitDocumentChanges(String collectionName, Collection<SolrInputDocument> documents) throws SolrServerException, IOException {
    if (documents.size() == 0) return;

    try {
        solrClient.request(newUpdateRequest().add(documents), collectionName);
    } catch (HttpSolrClient.RemoteSolrException rse) {
        logger.error("Unable to save documents to Solr as one of the shape objects stored were not compatible with Solr.", rse);
        logger.error("Details in failed document batch: ");
        for (SolrInputDocument d : documents) {
            Collection<String> fieldNames = d.getFieldNames();
            for (String name : fieldNames) {
                logger.error(name + ":" + d.getFieldValue(name).toString());
            }
        }

        throw rse;
    }
}
 
開發者ID:apache,項目名稱:incubator-atlas,代碼行數:19,代碼來源:Solr5Index.java

示例14: main

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
public static void main(String[] args) {
    SolrClient solr = new HttpSolrClient.Builder().withBaseSolrUrl("http://localhost:8983/solr/chronix/").build();

    //Define a group by function for the time series records
    Function<GenericTimeSeries<Long, Double>, String> groupBy = ts -> ts.getAttribute("name") + "-" + ts.getAttribute("host");

    //Define a reduce function for the grouped time series records. We use the average.
    BinaryOperator<GenericTimeSeries<Long, Double>> reduce = (ts1, ts2) -> merge(ts1, ts2, (y1, y2) -> (y1 + y2) / 2);

    //Instantiate a Chronix Client
    ChronixClient<GenericTimeSeries<Long, Double>, SolrClient, SolrQuery> chronix = new ChronixClient<>(
            new GenericTimeSeriesConverter(), new ChronixSolrStorage<>(200, groupBy, reduce));

    //We want the maximum of all time series that metric matches *load*.
    SolrQuery query = new SolrQuery("name:*Load*");
    query.setParam("cf", "metric{max}");

    //The result is a Java Stream. We simply collect the result into a list.
    List<GenericTimeSeries<Long, Double>> maxTS = chronix.stream(solr, query).collect(Collectors.toList());

    //Just print it out.
    LOGGER.info("Result for query {} is: {}", query, maxTS);
}
 
開發者ID:ChronixDB,項目名稱:chronix.examples,代碼行數:24,代碼來源:ChronixClientExampleWithGenericTimeSeries.java

示例15: init

import org.apache.solr.client.solrj.impl.HttpSolrClient; //導入依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
public void init(Map<String, Object> conf) throws ConfigException {
    String solrApiUrl = null;
    String collectionName = null;
    if (conf != null) {
        solrApiUrl = (String) conf.get(SOLR_API_URL_KEY);
        collectionName = (String) conf.get(COLLECTION_NAME);
        if (collectionName == null) {
            collectionName = DEFAULT_COLLECTION_NAME;
        }
    }

    if (solrApiUrl == null || collectionName == null) {
        throw new ConfigException("'solrApiUrl' must be presented in configuration.");
    }

    if ((boolean) conf.getOrDefault(SECURED_CLUSTER, false)) {
        HttpClientUtil.addConfigurer(new Krb5HttpClientConfigurer());
    }
    solr = new HttpSolrClient.Builder(solrApiUrl + "/" + collectionName).build();
}
 
開發者ID:hortonworks,項目名稱:streamline,代碼行數:25,代碼來源:AmbariInfraWithStormLogSearch.java


注:本文中的org.apache.solr.client.solrj.impl.HttpSolrClient類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。