记一次ES java 客户端 transport报错:
None of the configured nodes are available
put("client.transport.sniff", true) //自动嗅探整个集群的状态,把集群中其他ES节点的ip添加到本地的客户端列表中
ES集群部署在docker中,总共三台,docker中的三台虚拟机不在一个局域网内,代码中添加了自动嗅探功能,导致连接嗅探中获得的IP不能全部连接,就会报异常。将sniff注释掉即可。
附上代码:
private static final Logger log = LogManager.getLogger(ESClientSearch.class); private static TransportClient client = null; private static Settings build = null; static { build = Settings.builder() .put("cluster.name", "elasticsearch_release") //ES集群名称 // .put("client.transport.sniff", true) //自动嗅探整个集群的状态,把集群中其他ES节点的ip添加到本地的客户端列表中 虚拟机中不在一个局域网中 .build(); try { client = new PreBuiltTransportClient(build).addTransportAddress(new TransportAddress(InetAddress.getByName("10.10.10.104"),9300)); log.warn("elasticsearch集群连接成功"); } catch (UnknownHostException e) { e.printStackTrace(); } }