elasticsearch java client

本文介绍了Elasticsearch集群的配置方法,包括在同一局域网内的自动发现及不同局域网的手动配置。同时详细说明了客户端连接集群的多种方式,如直接指定多个节点地址或启用sniff模式。

1.集群名相同,且机器处于同一局域网同一网段,es会自动去发现其他的节点。
2.集群不在同一局域网同一网段时,只需要在 elasticsearch.yml 中配置目标机器和端口即可
discovery.zen.ping.unicast.hosts: ["10.127.0.1","10.127.0.2:9300"]
也需要保障集群名称相同。

客户端连接集群时多节点配置:

Client client = TransportClient.builder().build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("10.127.0.1"), 9300))
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("10.127.0.2"), 9300));

或者

client.transport.sniff为true来使客户端去嗅探整个集群的状态,把集群中其它机器的ip地址加到客户端中。
这样做的好处是一般你不用手动设置集群里所有集群的ip到连接客户端,它会自动帮你添加,并且自动发现新加入集群的机器。

Settings settings = Settings.settingsBuilder()
    .put("cluster.name", "elasticsearch")
    .put("client.transport.sniff", true).build();
Client client = TransportClient.builder().settings(settings).build()
    .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("10.127.0.1"), 9300));

 

第二种没太明白,假设我启动我停了其中的某一个,程序会报错,没有在addTransportAddress定义的并不会自动切换到另一个节点上去

转载于:https://www.cnblogs.com/gavinYang/p/11199627.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值