阻塞和异步客户端
编辑阻塞和异步客户端
编辑API 客户端有两种类型:阻塞和异步。异步客户端上的所有方法都返回标准的 CompletableFuture
。
根据您的需要,可以同时使用这两种类型,它们共享同一个传输对象。
ElasticsearchTransport transport = ... // Synchronous blocking client ElasticsearchClient client = new ElasticsearchClient(transport); if (client.exists(b -> b.index("products").id("foo")).value()) { logger.info("product exists"); } // Asynchronous non-blocking client ElasticsearchAsyncClient asyncClient = new ElasticsearchAsyncClient(transport); asyncClient .exists(b -> b.index("products").id("foo")) .whenComplete((response, exception) -> { if (exception != null) { logger.error("Failed to index", exception); } else { logger.info("Product exists"); } });
虽然我们不会深入探讨 Java 中的异步编程,但请记住处理异步任务的失败。很容易忽略它们,导致错误被忽视。
上面示例的源代码可以在 Java API 客户端测试中找到。