From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

$Search::Elasticsearch::Role::CxnPool::Static::NoPing::VERSION = '6.80_01'; # TRIAL
$Search::Elasticsearch::Role::CxnPool::Static::NoPing::VERSION = '6.8001';use Moo::Role;
has 'max_retries' => ( is => 'lazy' );
has '_dead_cxns' => ( is => 'ro', default => sub { [] } );
#===================================
sub next_cxn {
#===================================
my $self = shift;
my $cxns = $self->cxns;
my $total = @$cxns;
my $dead = $self->_dead_cxns;
while ( $total-- ) {
my $cxn = $cxns->[ $self->next_cxn_num ];
return $cxn
if $cxn->is_live
|| $cxn->next_ping < time();
push @$dead, $cxn unless grep { $_ eq $cxn } @$dead;
}
if ( @$dead and $self->retries <= $self->max_retries ) {
$_->force_ping for @$dead;
return shift @$dead;
}
throw( "NoNodes", "No nodes are available: [" . $self->cxns_str . ']' );
}
#===================================
sub _build_max_retries { @{ shift->cxns } - 1 }
sub _max_retries { shift->max_retries + 1 }
#===================================
#===================================
sub BUILD {
#===================================
my $self = shift;
$self->set_cxns( @{ $self->seed_nodes } );
}
#===================================
sub should_mark_dead {
#===================================
my ( $self, $error ) = @_;
return $error->is( 'Cxn', 'Timeout' );
}
#===================================
after 'reset_retries' => sub {
#===================================
my $self = shift;
@{ $self->_dead_cxns } = ();
};
#===================================
sub schedule_check { }
#===================================
1;
# ABSTRACT: A CxnPool for connecting to a remote cluster without the ability to ping.
__END__
=pod
=encoding UTF-8
=head1 NAME
Search::Elasticsearch::Role::CxnPool::Static::NoPing - A CxnPool for connecting to a remote cluster without the ability to ping.
=head1 VERSION
version 6.80_01
=head1 AUTHOR
Enrico Zimuel <enrico.zimuel@elastic.co>
=head1 COPYRIGHT AND LICENSE
This software is Copyright (c) 2020 by Elasticsearch BV.
This is free software, licensed under:
The Apache License, Version 2.0, January 2004
=cut