mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-09-02 07:35:26 +00:00
- Stop can now use rndc, when passed the --use-rndc option.
- Slightly restructured code to eliminate duplication. - No longer waits five seconds for a server to die, if it dies promptly.
This commit is contained in:
@@ -15,7 +15,7 @@
|
|||||||
# NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
|
# NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
|
||||||
# WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
# WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
# $Id: stop.pl,v 1.3 2001/03/01 02:35:13 gson Exp $
|
# $Id: stop.pl,v 1.4 2001/03/08 02:34:01 neild Exp $
|
||||||
|
|
||||||
# Framework for stopping test servers
|
# Framework for stopping test servers
|
||||||
# Based on the type of server specified, signal the server to stop, wait
|
# Based on the type of server specified, signal the server to stop, wait
|
||||||
@@ -26,41 +26,43 @@ use strict;
|
|||||||
use Cwd 'abs_path';
|
use Cwd 'abs_path';
|
||||||
|
|
||||||
# Option handling
|
# Option handling
|
||||||
# test [server]
|
# [--use-rndc] test [server]
|
||||||
#
|
#
|
||||||
# test - name of the test directory
|
# test - name of the test directory
|
||||||
# server - name of the server directory
|
# server - name of the server directory
|
||||||
|
|
||||||
my $usage = "usage: $0 test-directory [server-directory]";
|
my $usage = "usage: $0 [--use-rndc] test-directory [server-directory]";
|
||||||
|
my $use_rndc;
|
||||||
|
|
||||||
|
while (@ARGV && $ARGV[0] =~ /^-/) {
|
||||||
|
my $opt = shift @ARGV;
|
||||||
|
if ($opt eq '--use-rndc') {
|
||||||
|
$use_rndc = 1;
|
||||||
|
} else {
|
||||||
|
die "$usage\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
my $test = $ARGV[0];
|
my $test = $ARGV[0];
|
||||||
my $server = $ARGV[1];
|
my $server = $ARGV[1];
|
||||||
|
|
||||||
my $errors = 0;
|
my $errors = 0;
|
||||||
|
|
||||||
if (!$test) {
|
die "$usage\n" unless defined($test);
|
||||||
print "$usage\n";
|
die "No test directory: \"$test\"\n" unless (-d $test);
|
||||||
}
|
die "No server directory: \"$server\"\n" if (defined($server) && !-d $server);
|
||||||
if (!-d $test) {
|
|
||||||
print "No test directory: \"$test\"\n";
|
|
||||||
}
|
|
||||||
if ($server && !-d $server) {
|
|
||||||
print "No server directory: \"$test\"\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
# Global variables
|
# Global variables
|
||||||
my $testdir = abs_path("$test");
|
my $testdir = abs_path($test);
|
||||||
|
my @servers;
|
||||||
|
|
||||||
# Stop the server(s)
|
|
||||||
|
|
||||||
if ($server) {
|
# Determine which servers need to be stopped.
|
||||||
&stop_server($server);
|
if (defined $server) {
|
||||||
if ($server !~ /^ans/) {
|
@servers = ($server);
|
||||||
sleep 5;
|
|
||||||
&kill_server($server);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
# Determine which servers need to be stopped for this test.
|
local *DIR;
|
||||||
opendir DIR, $testdir;
|
opendir DIR, $testdir or die "$testdir: $!\n";
|
||||||
my @files = sort readdir DIR;
|
my @files = sort readdir DIR;
|
||||||
closedir DIR;
|
closedir DIR;
|
||||||
|
|
||||||
@@ -68,25 +70,41 @@ if ($server) {
|
|||||||
my @lwresd = grep /^lwresd[0-9]*$/, @files;
|
my @lwresd = grep /^lwresd[0-9]*$/, @files;
|
||||||
my @ans = grep /^ans[0-9]*$/, @files;
|
my @ans = grep /^ans[0-9]*$/, @files;
|
||||||
|
|
||||||
# Stop the servers we found.
|
push @servers, @ns, @lwresd, @ans;
|
||||||
foreach (@ns, @lwresd, @ans) {
|
}
|
||||||
&stop_server($_);
|
|
||||||
}
|
|
||||||
sleep 5;
|
# Stop the server(s), pass 1: rndc.
|
||||||
foreach (@ns, @lwresd) {
|
if ($use_rndc) {
|
||||||
&kill_server($_);
|
foreach my $server (grep /^ns/, @servers) {
|
||||||
|
stop_rndc($server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wait_for_servers(5, grep /^ns/, @servers);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Pass 2: SIGTERM
|
||||||
|
foreach my $server (@servers) {
|
||||||
|
stop_signal($server, "TERM");
|
||||||
|
}
|
||||||
|
wait_for_servers(5, @servers);
|
||||||
|
|
||||||
|
|
||||||
|
# Pass 3: SIGKILL
|
||||||
|
foreach my $server (@servers) {
|
||||||
|
stop_signal($server, "KILL");
|
||||||
}
|
}
|
||||||
|
|
||||||
exit($errors ? 1 : 0);
|
exit($errors ? 1 : 0);
|
||||||
|
|
||||||
# Subroutines
|
# Subroutines
|
||||||
|
|
||||||
sub stop_server {
|
# Return the full path to a given server's PID file.
|
||||||
my $server = shift;
|
sub server_pid_file {
|
||||||
|
my($server) = @_;
|
||||||
|
|
||||||
my $pid_file;
|
my $pid_file;
|
||||||
|
|
||||||
if ($server =~ /^ns/) {
|
if ($server =~ /^ns/) {
|
||||||
$pid_file = "named.pid";
|
$pid_file = "named.pid";
|
||||||
} elsif ($server =~ /^lwresd/) {
|
} elsif ($server =~ /^lwresd/) {
|
||||||
@@ -97,44 +115,71 @@ sub stop_server {
|
|||||||
print "I:Unknown server type $server\n";
|
print "I:Unknown server type $server\n";
|
||||||
exit 1;
|
exit 1;
|
||||||
}
|
}
|
||||||
|
$pid_file = "$testdir/$server/$pid_file";
|
||||||
# print "I:stopping server $server\n";
|
|
||||||
|
|
||||||
chdir "$testdir/$server";
|
|
||||||
|
|
||||||
if (-f $pid_file) {
|
|
||||||
my $result = kill 'TERM', `cat $pid_file`;
|
|
||||||
if ($result != 1) {
|
|
||||||
print "I:$server died before a SIGTERM was sent\n";
|
|
||||||
unlink $pid_file;
|
|
||||||
$errors++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub kill_server {
|
# Read a PID.
|
||||||
my $server = shift;
|
sub read_pid {
|
||||||
|
my($pid_file) = @_;
|
||||||
|
|
||||||
my $pid_file;
|
local *FH;
|
||||||
|
my $result = open FH, "< $pid_file";
|
||||||
if ($server =~ /^ns/) {
|
if (!$result) {
|
||||||
$pid_file = "named.pid";
|
print "I:$pid_file: $!\n";
|
||||||
} elsif ($server =~ /^lwresd/) {
|
|
||||||
$pid_file = "lwresd.pid";
|
|
||||||
} else {
|
|
||||||
print "I:Unknown server type $server\n";
|
|
||||||
exit 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
chdir "$testdir/$server";
|
|
||||||
|
|
||||||
if (-f $pid_file) {
|
|
||||||
print "I:$server didn't die when sent a SIGTERM\n";
|
|
||||||
my $result = kill 'KILL', `cat $pid_file`;
|
|
||||||
if ($result != 1) {
|
|
||||||
print "I:$server died before a SIGKILL was sent\n";
|
|
||||||
$errors++;
|
|
||||||
}
|
|
||||||
unlink $pid_file;
|
unlink $pid_file;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $pid = <FH>;
|
||||||
|
chomp($pid);
|
||||||
|
return $pid;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Stop a named process with rndc.
|
||||||
|
sub stop_rndc {
|
||||||
|
my($server) = @_;
|
||||||
|
|
||||||
|
return unless ($server =~ /^ns(\d+)$/);
|
||||||
|
my $ip = "10.53.0.$1";
|
||||||
|
|
||||||
|
# Ugly, but should work.
|
||||||
|
system("$ENV{RNDC} -c $testdir/../common/rndc.conf -s $ip -p 9953 stop | sed 's/^/I:$server /'");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Stop a server by sending a signal to it.
|
||||||
|
sub stop_signal {
|
||||||
|
my($server, $sig) = @_;
|
||||||
|
|
||||||
|
my $pid_file = server_pid_file($server);
|
||||||
|
return unless -f $pid_file;
|
||||||
|
|
||||||
|
my $pid = read_pid($pid_file);
|
||||||
|
return unless defined($pid);
|
||||||
|
|
||||||
|
print "I:$server didn't die when sent a SIGTERM\n" if ($sig eq 'KILL');
|
||||||
|
|
||||||
|
my $result = kill $sig, $pid;
|
||||||
|
if (!$result) {
|
||||||
|
print "I:$server died before a SIG$sig was sent\n";
|
||||||
|
unlink $pid_file;
|
||||||
|
$errors++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub wait_for_servers {
|
||||||
|
my($timeout, @servers) = @_;
|
||||||
|
|
||||||
|
my @pid_files = grep { defined($_) }
|
||||||
|
map { server_pid_file($_) } @servers;
|
||||||
|
|
||||||
|
while ($timeout > 0 && @pid_files > 0) {
|
||||||
|
@pid_files = grep { -f $_ } @pid_files;
|
||||||
|
sleep 1 if (@pid_files > 0);
|
||||||
|
$timeout--;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user