From 8efb1c8f48d3c5a1bd25faa0d58b993f313fd965 Mon Sep 17 00:00:00 2001 From: sjing Date: Wed, 18 Dec 2013 01:35:15 -0500 Subject: [PATCH] Support dns master/slave configuration --- perl-xCAT/xCAT/Schema.pm | 2 +- perl-xCAT/xCAT/ServiceNodeUtils.pm | 2 + xCAT-server/lib/xcat/plugins/AAsn.pm | 26 ++++-- xCAT-server/lib/xcat/plugins/ddns.pm | 121 +++++++++++++++++++++++---- 4 files changed, 130 insertions(+), 21 deletions(-) mode change 100644 => 100755 perl-xCAT/xCAT/Schema.pm mode change 100644 => 100755 perl-xCAT/xCAT/ServiceNodeUtils.pm mode change 100644 => 100755 xCAT-server/lib/xcat/plugins/AAsn.pm mode change 100644 => 100755 xCAT-server/lib/xcat/plugins/ddns.pm diff --git a/perl-xCAT/xCAT/Schema.pm b/perl-xCAT/xCAT/Schema.pm old mode 100644 new mode 100755 index e68fc9ed3..0621748e3 --- a/perl-xCAT/xCAT/Schema.pm +++ b/perl-xCAT/xCAT/Schema.pm @@ -841,7 +841,7 @@ servicenode => { table_desc => 'List of all Service Nodes and services that will be set up on the Service Node.', descriptions => { node => 'The hostname of the service node as known by the Management Node.', - nameserver => 'Do we set up DNS on this service node? Valid values:yes or 1, no or 0. If yes, creates named.conf file with forwarding to the management node and starts named. If no or 0, it does not change the current state of the service. ', + nameserver => 'Do we set up DNS on this service node? Valid values: 2, 1, no or 0. If 2, creates named.conf as dns slave, using the management node as dns master, and starts named. If 1, creates named.conf file with forwarding to the management node and starts named. If no or 0, it does not change the current state of the service. ', dhcpserver => 'Do we set up DHCP on this service node? Not supported on AIX. Valid values:yes or 1, no or 0. If yes, runs makedhcp -n. If no or 0, it does not change the current state of the service. ', tftpserver => 'Do we set up TFTP on this service node? Not supported on AIX. Valid values:yes or 1, no or 0. If yes, configures and starts atftp. If no or 0, it does not change the current state of the service. ', nfsserver => 'Do we set up file services (HTTP,FTP,or NFS) on this service node? For AIX will only setup NFS, not HTTP or FTP. Valid values:yes or 1, no or 0.If no or 0, it does not change the current state of the service. ', diff --git a/perl-xCAT/xCAT/ServiceNodeUtils.pm b/perl-xCAT/xCAT/ServiceNodeUtils.pm old mode 100644 new mode 100755 index 28bf81a98..c76d8d910 --- a/perl-xCAT/xCAT/ServiceNodeUtils.pm +++ b/perl-xCAT/xCAT/ServiceNodeUtils.pm @@ -163,6 +163,8 @@ sub isServiceReq if (($value eq "1") || ($value eq "YES")) { $servicehash->{$service} = "1"; + } elsif ($value eq "2") { + $servicehash->{$service} = "2"; } else { $servicehash->{$service} = "0"; } diff --git a/xCAT-server/lib/xcat/plugins/AAsn.pm b/xCAT-server/lib/xcat/plugins/AAsn.pm old mode 100644 new mode 100755 index 01ada02c7..02f5bd649 --- a/xCAT-server/lib/xcat/plugins/AAsn.pm +++ b/xCAT-server/lib/xcat/plugins/AAsn.pm @@ -144,10 +144,10 @@ sub init_plugin } } - if ($servicelist->{"nameserver"} == 1) + if (($servicelist->{"nameserver"} == 1) || ($servicelist->{"nameserver"} == 2) ) { - &setup_DNS(); # setup DNS + &setup_DNS($servicelist); # setup DNS } if ($servicelist->{"nfsserver"} == 1) @@ -689,6 +689,7 @@ sub setup_FTP #----------------------------------------------------------------------------- sub setup_DNS { + my $srvclist = shift; my $XCATROOT = "/opt/xcat"; # default @@ -697,9 +698,24 @@ sub setup_DNS $XCATROOT = $ENV{'XCATROOT'}; } - # setup the named.conf file - system("$XCATROOT/sbin/makenamed.conf"); - + if ($srvclist->{"nameserver"} == 1) + { + # setup the named.conf file as dns forwarding/caching + system("$XCATROOT/sbin/makenamed.conf"); + } + else + { + # setup the named.conf file as dns slave + my $cmdref; + $cmdref->{command}->[0] = "makedns"; + $cmdref->{arg}->[0] = "-s"; + $cmdref->{cwd}->[0] = "/opt/xcat/sbin"; + no strict "refs"; + my $modname = "ddns"; + ${"xCAT_plugin::" . $modname . "::"}{process_request} + ->($cmdref, \&xCAT::Client::handle_response); + } + # turn DNS on my $distro = xCAT::Utils->osver(); diff --git a/xCAT-server/lib/xcat/plugins/ddns.pm b/xCAT-server/lib/xcat/plugins/ddns.pm old mode 100644 new mode 100755 index f48297562..9249d2ed5 --- a/xCAT-server/lib/xcat/plugins/ddns.pm +++ b/xCAT-server/lib/xcat/plugins/ddns.pm @@ -207,6 +207,7 @@ sub process_request { my $help; my $deletemode=0; my $external=0; + my $slave=0; if ($request->{arg}) { $hadargs=1; @ARGV=@{$request->{arg}}; @@ -218,6 +219,7 @@ sub process_request { 'n|new' => \$zapfiles, 'd|delete' => \$deletemode, 'e|external' => \$external, + 's|slave' => \$slave, 'h|help' => \$help, )) { #xCAT::SvrUtils::sendmsg([1,"TODO: makedns Usage message"], $callback); @@ -492,6 +494,16 @@ sub process_request { $ctx->{forwarders}=\@forwarders; } + my @slave_ips; + my $dns_slaves = get_dns_slave(); + if (scalar @$dns_slaves) { + foreach my $slave_hn (@$dns_slaves) { + my $slave_ip = xCAT::NetworkUtils->getipaddr($slave_hn); + push @slave_ips, $slave_ip; + } + $ctx->{slaves}=\@slave_ips; + } + $ctx->{zonestotouch}->{$ctx->{domain}}=1; foreach (@networks) { if ($_->{domain}) { @@ -568,8 +580,12 @@ sub process_request { $ctx->{zonesdir} = get_zonesdir(); chmod 0775, $ctx->{dbdir}; # assure dynamic dns can actually execute against the directory - update_namedconf($ctx); - update_zones($ctx); + update_namedconf($ctx, $slave); + + unless ($slave) + { + update_zones($ctx); + } if ($ctx->{restartneeded}) { xCAT::SvrUtils::sendmsg("Restarting $service", $callback); @@ -624,6 +640,11 @@ sub process_request { } } + if ($slave) + { + return; + } + # check if named is active before update dns records. if (xCAT::Utils->isAIX()) { @@ -839,6 +860,7 @@ sub update_zones { sub update_namedconf { my $ctx = shift; + my $slave = shift; my $namedlocation = get_conf(); my $nameconf; my @newnamed; @@ -868,6 +890,20 @@ sub update_namedconf { push @newnamed,"\t\t".$_.";\n"; } push @newnamed,"\t};\n"; + } elsif ($ctx->{slaves} and $line =~ /allow-transfer {/) { + push @newnamed,"\tallow-transfer \{\n"; + $skip=1; + foreach (@{$ctx->{slaves}}) { + push @newnamed,"\t\t".$_.";\n"; + } + push @newnamed,"\t};\n"; + } elsif ($ctx->{slaves} and $line =~ /also-notify {/) { + push @newnamed,"\talso-notify \{\n"; + $skip=1; + foreach (@{$ctx->{slaves}}) { + push @newnamed,"\t\t".$_.";\n"; + } + push @newnamed,"\t};\n"; } elsif ($skip) { if ($line =~ /};/) { $skip = 0; @@ -971,23 +1007,52 @@ sub update_namedconf { } push @newnamed,"\t};\n"; } + + if ($slave) { + push @newnamed,"\tallow-transfer { any; };\n"; + } else { + if ($ctx->{slaves}) { + push @newnamed,"\tnotify yes;\n"; + push @newnamed,"\tallow-transfer {\n"; + foreach (@{$ctx->{slaves}}) { + push @newnamed,"\t\t$_;\n"; + } + push @newnamed,"\t};\n"; + push @newnamed,"\talso-notify {\n"; + foreach (@{$ctx->{slaves}}) { + push @newnamed,"\t\t$_;\n"; + } + push @newnamed,"\t};\n"; + } + } push @newnamed,"};\n\n"; } - unless ($gotkey) { - unless ($ctx->{privkey}) { #need to generate one - $ctx->{privkey} = encode_base64(genpassword(32)); - chomp($ctx->{privkey}); - } - push @newnamed,"key xcat_key {\n","\talgorithm hmac-md5;\n","\tsecret \"".$ctx->{privkey}."\";\n","};\n\n"; - $ctx->{restartneeded}=1; + unless ($slave) { + unless ($gotkey) { + unless ($ctx->{privkey}) { #need to generate one + $ctx->{privkey} = encode_base64(genpassword(32)); + chomp($ctx->{privkey}); + } + push @newnamed,"key xcat_key {\n","\talgorithm hmac-md5;\n","\tsecret \"".$ctx->{privkey}."\";\n","};\n\n"; + $ctx->{restartneeded}=1; + } } + + my $cmd = "grep '^nameserver' /etc/resolv.conf | awk '{print $2}'"; + my @output=xCAT::Utils->runcmd($cmd, 0); my $zone; foreach $zone (keys %{$ctx->{zonestotouch}}) { if ($didzones{$zone}) { next; } $ctx->{restartneeded}=1; #have to add a zone, a restart will be needed - push @newnamed,"zone \"$zone\" in {\n","\ttype master;\n","\tallow-update {\n","\t\tkey xcat_key;\n"; - foreach (@{$ctx->{dnsupdaters}}) { - push @newnamed,"\t\t$_;\n"; + push @newnamed,"zone \"$zone\" in {\n"; + if ($slave) { + push @newnamed,"\ttype slave;\n"; + push @newnamed,"\tmasters { $output[0]; };\n"; + } else { + push @newnamed,"\ttype master;\n","\tallow-update {\n","\t\tkey xcat_key;\n"; + foreach (@{$ctx->{dnsupdaters}}) { + push @newnamed,"\t\t$_;\n"; + } } if ($zone =~ /IN-ADDR\.ARPA/) { my $net = $zone; @@ -1005,9 +1070,15 @@ sub update_namedconf { foreach $zone (keys %{$ctx->{adzones}}) { if ($didzones{$zone}) { next; } $ctx->{restartneeded}=1; #have to add a zone, a restart will be needed - push @newnamed,"zone \"$zone\" in {\n","\ttype master;\n","\tallow-update {\n","\t\tkey xcat_key;\n"; - foreach (@{$ctx->{adservers}}) { - push @newnamed,"\t\t$_;\n"; + push @newnamed,"zone \"$zone\" in {\n"; + if ($slave) { + push @newnamed,"\ttype slave;\n"; + push @newnamed,"\tmasters { $output[0]; };\n"; + } else { + push @newnamed,"\ttype master;\n","\tallow-update {\n","\t\tkey xcat_key;\n"; + foreach (@{$ctx->{adservers}}) { + push @newnamed,"\t\t$_;\n"; + } } my $zfilename = $zone; #$zfilename =~ s/\..*//; @@ -1298,4 +1369,24 @@ sub makedns_usage return 0; } +sub get_dns_slave +{ + # get all service nodes with servicenode.nameserver=2 + my @sns; + my @slaves; + my $sntab = xCAT::Table->new('servicenode'); + my @ents = $sntab->getAllAttribs('node', 'nameserver'); + + foreach my $sn (@ents) + { + if ($sn->{'nameserver'} == 2) + { + push @sns, $sn->{'node'}; + } + } + + @slaves = xCAT::NodeRange::noderange(join(',',@sns)); + return \@slaves; +} + 1;