transport java_elasticsearch Java API 客户端(TransportClient )

TransportClient 使用传输模块来远程连接一个elasticsearch集群;

区别与 node client模式,transportClient是不会加入集群中的。

// on startup

Client client = new TransportClient()

.addTransportAddress(new InetSocketTransportAddress("host1", 9300))

.addTransportAddress(new InetSocketTransportAddress("host2", 9300));

// on shutdown

client.close();

或者你可以指定一个集群的名称:

Settings settings = ImmutableSettings.settingsBuilder()

.put("cluster.name", "myClusterName").build();

Client client = new TransportClient(settings);

或者使用配置文件的方式(参考nodeClient方式)定义集群的名称。

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

Settings settings = ImmutableSettings.settingsBuilder()

.put("client.transport.sniff", true).build();

TransportClient client = new TransportClient(settings);

但是至少添加一个InetSocketTransportAddress,否则会出现异常:org.elasticsearch.client.transport.NoNodeAvailableException: No node

available。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值