Search::Elasticsearch::CxnPool::Sniff - A CxnPool for connecting to a local cluster with a dynamic node list
version 6.00
$e = Search::Elasticsearch->new( cxn_pool => 'Sniff', nodes => [ 'search1:9200', 'search2:9200' ], );
The Sniff connection pool should be used when you do have direct access to the Elasticsearch cluster, eg when your web servers and Elasticsearch servers are on the same network. The nodes that you specify are used to discover the cluster, which is then sniffed to find the current list of live nodes that the cluster knows about.
This sniff process is repeated regularly, or whenever a node fails, to update the list of healthy nodes. So if you add more nodes to your cluster, they will be auto-discovered during a sniff.
If all sniffed nodes fail, then it falls back to sniffing the original seed nodes that you specified in new().
new()
For HTTP Cxn classes, this module will also dynamically detect the max_content_length which the nodes in the cluster will accept.
max_content_length
This class does Search::Elasticsearch::Role::CxnPool::Sniff and Search::Elasticsearch::Role::Is_Sync.
nodes
The list of nodes to use to discover the cluster. Can accept a single node, multiple nodes, and defaults to localhost:9200 if no nodes are specified. See "node" in Search::Elasticsearch::Role::Cxn for details of the node specification.
localhost:9200
"request_timeout" in Search::Elasticsearch::Role::Cxn
"sniff_timeout" in Search::Elasticsearch::Role::Cxn
"sniff_request_timeout" in Search::Elasticsearch::Role::Cxn
From Search::Elasticsearch::Role::CxnPool::Sniff
sniff_interval
sniff_max_content_length
From Search::Elasticsearch::Role::CxnPool
randomize_cxns
next_cxn()
$cxn = $cxn_pool->next_cxn
Returns the next available live node (in round robin fashion), or throws a NoNodes error if no nodes can be sniffed from the cluster.
NoNodes
schedule_check()
$cxn_pool->schedule_check
Forces a sniff before the next Cxn is returned, to updated the list of healthy nodes in the cluster.
sniff()
$bool = $cxn_pool->sniff
Sniffs the cluster and returns true if the sniff was successful.
true
parse_sniff()
should_accept_node()
cxn_factory()
logger()
serializer()
current_cxn_num()
cxns()
seed_nodes()
next_cxn_num()
set_cxns()
request_ok()
request_failed()
should_retry()
should_mark_dead()
cxns_str()
cxns_seeds_str()
retries()
reset_retries()
Clinton Gormley <drtech@cpan.org>
This software is Copyright (c) 2017 by Elasticsearch BV.
This is free software, licensed under:
The Apache License, Version 2.0, January 2004
To install Search::Elasticsearch, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Search::Elasticsearch
CPAN shell
perl -MCPAN -e shell install Search::Elasticsearch
For more information on module installation, please visit the detailed CPAN module installation guide.