记一次ES java 客户端 transport报错: None of the configured nodes are available

记一次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();
        }
    }

 

你可能感兴趣的:(ES)