GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
Search::Elasticsearch::CxnPool::Sniff(3) User Contributed Perl Documentation Search::Elasticsearch::CxnPool::Sniff(3)

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()".

For HTTP Cxn classes, this module will also dynamically detect the "max_content_length" which the nodes in the cluster will accept.

This class does Search::Elasticsearch::Role::CxnPool::Sniff and Search::Elasticsearch::Role::Is_Sync.

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.

  • "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

    $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.

    $cxn_pool->schedule_check

Forces a sniff before the next Cxn is returned, to updated the list of healthy nodes in the cluster.

    $bool = $cxn_pool->sniff

Sniffs the cluster and returns "true" if the sniff was successful.

From Search::Elasticsearch::Role::CxnPool::Sniff
  • schedule_check()
  • parse_sniff()
  • should_accept_node()

From Search::Elasticsearch::Role::CxnPool

  • 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
2017-11-14 perl v5.32.1

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.