2013-08-28 19:24:34 -04:00
|
|
|
[[client]]
|
|
|
|
== Client
|
|
|
|
|
2014-05-12 22:07:46 -04:00
|
|
|
You can use the *Java client* in multiple ways:
|
2013-08-28 19:24:34 -04:00
|
|
|
|
2015-06-24 17:27:19 -04:00
|
|
|
* Perform standard <<java-docs-index,index>>, <<java-docs-get,get>>,
|
|
|
|
<<java-docs-delete,delete>> and <<java-search,search>> operations on an
|
2013-08-28 19:24:34 -04:00
|
|
|
existing cluster
|
|
|
|
* Perform administrative tasks on a running cluster
|
|
|
|
|
|
|
|
Obtaining an elasticsearch `Client` is simple. The most common way to
|
2016-02-15 11:31:58 -05:00
|
|
|
get a client is by creating a <<transport-client,`TransportClient`>>
|
2013-08-28 19:24:34 -04:00
|
|
|
that connects to a cluster.
|
|
|
|
|
2016-03-10 08:09:04 -05:00
|
|
|
[IMPORTANT]
|
|
|
|
==============================
|
|
|
|
|
|
|
|
The client must have the same major version (e.g. `2.x`, or `5.x`) as the
|
|
|
|
nodes in the cluster. Clients may connect to clusters which have a different
|
|
|
|
minor version (e.g. `2.3.x`) but it is possible that new funcionality may not
|
|
|
|
be supported. Ideally, the client should have the same version as the
|
|
|
|
cluster.
|
|
|
|
|
|
|
|
==============================
|
2013-08-28 19:24:34 -04:00
|
|
|
|
2013-09-03 10:15:07 -04:00
|
|
|
|
2013-09-25 12:17:40 -04:00
|
|
|
[[transport-client]]
|
2013-08-28 19:24:34 -04:00
|
|
|
=== Transport Client
|
|
|
|
|
2015-07-30 22:46:42 -04:00
|
|
|
The `TransportClient` connects remotely to an Elasticsearch cluster
|
2013-08-28 19:24:34 -04:00
|
|
|
using the transport module. It does not join the cluster, but simply
|
|
|
|
gets one or more initial transport addresses and communicates with them
|
|
|
|
in round robin fashion on each action (though most actions will probably
|
|
|
|
be "two hop" operations).
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
|
|
|
// on startup
|
|
|
|
|
2015-05-04 10:23:08 -04:00
|
|
|
Client client = TransportClient.builder().build()
|
2015-08-24 09:13:13 -04:00
|
|
|
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host1"), 9300))
|
|
|
|
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host2"), 9300));
|
2013-08-28 19:24:34 -04:00
|
|
|
|
|
|
|
// on shutdown
|
|
|
|
|
|
|
|
client.close();
|
|
|
|
--------------------------------------------------
|
|
|
|
|
2014-05-12 22:07:46 -04:00
|
|
|
Note that you have to set the cluster name if you use one different than
|
2013-08-28 19:24:34 -04:00
|
|
|
"elasticsearch":
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
2015-06-24 01:53:32 -04:00
|
|
|
Settings settings = Settings.settingsBuilder()
|
2013-08-28 19:24:34 -04:00
|
|
|
.put("cluster.name", "myClusterName").build();
|
2015-05-04 10:23:08 -04:00
|
|
|
Client client = TransportClient.builder().settings(settings).build();
|
2013-08-28 19:24:34 -04:00
|
|
|
//Add transport addresses and do something with the client...
|
|
|
|
--------------------------------------------------
|
|
|
|
|
2014-12-17 06:29:01 -05:00
|
|
|
The client allows sniffing the rest of the cluster, which adds data nodes
|
|
|
|
into its list of machines to use. In this case, note that the IP addresses
|
2013-08-28 19:24:34 -04:00
|
|
|
used will be the ones that the other nodes were started with (the
|
|
|
|
"publish" address). In order to enable it, set the
|
|
|
|
`client.transport.sniff` to `true`:
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
2015-06-24 01:53:32 -04:00
|
|
|
Settings settings = Settings.settingsBuilder()
|
2013-08-28 19:24:34 -04:00
|
|
|
.put("client.transport.sniff", true).build();
|
2015-05-04 10:23:08 -04:00
|
|
|
TransportClient client = TransportClient.builder().settings(settings).build();
|
2013-08-28 19:24:34 -04:00
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
Other transport client level settings include:
|
|
|
|
|
|
|
|
[cols="<,<",options="header",]
|
|
|
|
|=======================================================================
|
|
|
|
|Parameter |Description
|
|
|
|
|`client.transport.ignore_cluster_name` |Set to `true` to ignore cluster
|
|
|
|
name validation of connected nodes. (since 0.19.4)
|
|
|
|
|
|
|
|
|`client.transport.ping_timeout` |The time to wait for a ping response
|
|
|
|
from a node. Defaults to `5s`.
|
|
|
|
|
|
|
|
|`client.transport.nodes_sampler_interval` |How often to sample / ping
|
|
|
|
the nodes listed and connected. Defaults to `5s`.
|
|
|
|
|=======================================================================
|
2016-02-15 11:31:58 -05:00
|
|
|
|
|
|
|
|
|
|
|
[[client-connected-to-client-node]]
|
|
|
|
=== Connecting a Client to a Client Node
|
|
|
|
|
|
|
|
You can start locally a {ref}/modules-node.html#client-node[Client Node] and then simply create
|
|
|
|
a <<transport-client,`TransportClient`>> in your application which connects to this Client Node.
|
|
|
|
|
|
|
|
This way, the client node will be able to load whatever plugin you need (think about discovery plugins for example).
|