enh(database/redis): permission message, sentinel fix (#3320)

This commit is contained in:
qgarnier 2021-12-13 09:52:18 +01:00 committed by GitHub
parent b5fa560051
commit e64d799233
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 1 deletions

View File

@ -185,6 +185,7 @@ sub sentinels_get_master {
foreach my $addr (@{$self->{sentinel}}) { foreach my $addr (@{$self->{sentinel}}) {
my ($sentinel_host, $sentinel_port) = split(/:/, $addr); my ($sentinel_host, $sentinel_port) = split(/:/, $addr);
my $command_options = "-h '" . $sentinel_host . "' -p " . (defined($sentinel_port) ? $sentinel_port : 26379); my $command_options = "-h '" . $sentinel_host . "' -p " . (defined($sentinel_port) ? $sentinel_port : 26379);
$command_options .= ' --no-raw';
$command_options .= ' sentinel get-master-addr-by-name ' . $self->{service}; $command_options .= ' sentinel get-master-addr-by-name ' . $self->{service};
my ($stdout, $exit_code) = $self->execute_command( my ($stdout, $exit_code) = $self->execute_command(
command => 'redis-cli', command => 'redis-cli',
@ -193,7 +194,7 @@ sub sentinels_get_master {
); );
next if ($exit_code != 0); next if ($exit_code != 0);
$host = $1 if ($stdout =~ /1\) "(.*?)"/m); $host = $1 if ($stdout =~ /1\) "(.*?)"/m);
$port = $2 if ($stdout =~ /2\) "(\d+)"/m); $port = $1 if ($stdout =~ /2\) "(\d+)"/m);
last if (defined($port)); last if (defined($port));
} }
@ -222,6 +223,11 @@ sub get_info {
command_options => $command_options command_options => $command_options
); );
if ($stdout =~ /^NOPERM/m) {
$self->{output}->add_option_msg(short_msg => 'Permissions issue');
$self->{output}->option_exit();
}
my $items = {}; my $items = {};
foreach my $line (split /\n/, $stdout) { foreach my $line (split /\n/, $stdout) {
if ($line =~ /^(.*?):(.*)$/) { if ($line =~ /^(.*?):(.*)$/) {