data:image/s3,"s3://crabby-images/6ab4c/6ab4c31506f7c90118f45b0b9fa298fb834ea24c" alt="elasticsearch单例模式连接 elasticsearch单例模式连接"
import java.net.InetAddress;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.transport.client.PreBuiltTransportClient;
/**
* ES连接类
* @author zxy
*
*/
public class ES_DbUtil {
public static TransportClient transportClient=null; //句柄
public static String esClusterName; //集群名
public static String esServerIps; //集群服务ip集合
public static Integer esServerPort; //Es集群端口
@SuppressWarnings({ "resource", "unchecked" })
public static TransportClient getTransPortClient(String esClusterNam,String esServerIp,Integer esServerPor){
//连接ES transportClient获得句柄
esClusterName = esClusterNam; // 集群名
esServerIps = esServerIp; // 集群服务ip
esServerPort = esServerPor; // Es集群端口
try {
if (transportClient == null) {
if (esServerIps == null || "".equals(esServerIps.trim()))
return null;
Settings esSetting = Settings.builder().put("client.transport.ignore_cluster_name", true)
.put("cluster.name", esClusterName) // 集群名
.put("client.transport.sniff", true) // 自动嗅探,把机器添加到列表
.put("client.transport.ping_timeout", "10s")
.build();
transportClient = new PreBuiltTransportClient(esSetting).addTransportAddress(
new InetSocketTransportAddress(InetAddress.getByName(esServerIps), esServerPort));
System.out.println("connectok");
return transportClient;
} else{
System.out.println("hell11");
return transportClient;
}
} catch (Exception e) {
e.printStackTrace();
if (transportClient != null)
transportClient.close();
System.out.println("hellk");
return null;
}
}
public static void clientClose() {
/* 关闭连接 */
if (null != transportClient) {
try {
transportClient.close();
} catch (Exception e) {
}
}
}
}