接着上一节的
使用java客户端,去es中根据文档的id,获取整个文档
package com.es.demo;
import java.net.InetAddress;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import com.fasterxml.jackson.databind.ObjectMapper;
/**
* 搜索指定文档
*
* @author Beck
* @date 2018年2月6日
*/
public class TestES2 {
private static final String HOST = "127.0.0.1";
private static final int PORT = 9300;
private static final ObjectMapper MAPPER = new ObjectMapper();
private TransportClient client = null;
// 搜索单个文档,根据id
@Test
public void getSingleDocument(){
GetResponse response = client.prepareGet("eshop", "product", "AWFlwM2XrUhLs_HfwSw1")
.setOperationThreaded(false)
.get();
// 打印结果
String id = response.getId();
String sourceAsString = response.getSourceAsString();
System.out.println(id);
System.out.println(sourceAsString);
}
// 获取客户端
@Before
public void getClient() throws Exception{
client = TransportClient.builder()
.build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(HOST), PORT));
}
// 关闭客户端
@After
public void closeClient(){
if (this.client != null){
this.client.close();
}
}
}