PS:兩個服務器起好后最好兩個服務都重啟一下


主服務器配置




#!/bin/bash
#DNS主從同步——主服務器

rpm -q bind
if [ $? -ne" />

Shell腳本實戰之DNS主從同步腳本實例

 更新時間:2020-01-15 16:01:50   作者:佚名   我要評論(0)

DNS主從同步腳本實例


PS:兩個服務器起好后最好兩個服務都重啟一下


主服務器配置




#!/bin/bash
#DNS主從同步——主服務器

rpm -q bind
if [ $? -ne

DNS主從同步腳本實例

PS:兩個服務器起好后最好兩個服務都重啟一下

主服務器配置

#!/bin/bash
#DNS主從同步——主服務器

rpm -q bind
if [ $? -ne 0 ];then
  yum install bind -y
  systemctl start named
fi
#判斷DNS服務是否安裝

read -p "請輸入主服務器地址:" zhu
read -p "請輸入從服務器地址:" cong
read -p "域名(請帶后綴):" yu
quanju="/etc/named.conf"
quyu="/etc/named.rfc1912.zones"
[ ! -e $quanju.bak ] && cp $quanju $quanju.bak
sed -i -e "13s/127.0.0.1/$zhu/" -e '21s/localhost/any/' $quanju
[ ! -e $quyu.bak ] && cp $quyu $quyu.bak
#備份全局、區域配置文件

grep "$yu" $quyu &> /dev/null
while [ $? -ne 0 ];do
 sed -i "18azone \"$yu\" IN {\n type master\;\n file \"$yu.dns\"\;\n allow-   transfer { $cong\; }\;\n}\;\n" $quyu
 peizhi="/var/named/$yu.dns"
cp -p /var/named/named.localhost $peizhi
done
#判斷域名是否存在,如果不存在進行添加

sed -i -e '2d' -e "[email protected]    IN SOA "$yu"\. admin\."$yu"\. (" /var/named/$yu.dns
sed -i '8d' /var/named/$yu.dns
sed -i '$d' /var/named/$yu.dns
sed -i -e "7a\   NS   $yu." -e "/A/s/127.0.0.1/$zhu/" /var/named/$yu.dns
#修改區域文件

while [ 1 -ge 0 ];do
read -p "請輸入自定義指針(例:www IN A 8.8.8.8)" zhen
 echo $zhen >> /var/named/$yu.dns
 read -p "是否繼續添加(y/n)" a
if [ $a != "y" ];then
 break
fi
done
#循環

systemctl stop firewalld.service
setenforce 0
systemctl restart named
jieguo=`systemctl status named | grep "active" &>/dev/null`
if [ $? -eq 0 ];then
 echo "服務啟動"
else
 echo "啟動失敗"
fi
#判斷服務是否能正常啟動

sed -i -e '3d' -e "2anameserver $zhu" /etc/resolv.conf
#用于自檢

從服務器配置

#!/bin/bash
#DNS主從同步——從服務器

rpm -q bind
if [ $? -ne 0 ];then
  yum install bind -y
fi
#判斷DNS服務是否安裝

read -p "請輸入主服務器地址:" zhu
read -p "請輸入從服務器地址:" cong
read -p "域名(請帶后綴):" yu
quanju="/etc/named.conf"
quyu="/etc/named.rfc1912.zones"
[ ! -e $quanju.bak ] && cp $quanju $quanju.bak
sed -i -e "13s/127.0.0.1/$cong/" -e '21s/localhost/any/' $quanju
[ ! -e $quyu.bak ] && cp $quyu $quyu.bak
#備份全局、區域配置文件

grep "$yu" $quyu &> /dev/null
while [ $? -ne 0 ];do
 sed -i "18azone \"$yu\" IN {\n type slave\;\n file \"slaves\/$yu.dns\"\;\n  masters { $zhu\; }\;\n}\;\n" $quyu
done
#判斷域名是否存在,如果不存在進行添加

systemctl restart named
systemctl stop firewalld.service
setenforce 0
jieguo=`systemctl status named | grep "active" &>/dev/null`
if [ $? -eq 0 ];then
 echo "服務啟動"
else
 echo "啟動失敗"
fi
#判斷服務是否能正常啟動

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

  • CentOS下編寫shell腳本來監控MySQL主從復制的教程
  • Shell腳本實現監控MySQL主從同步
  • shell腳本監控mysql主從狀態
  • shell監控腳本實例—監控mysql主從復制

相關文章

  • Shell腳本實戰之DNS主從同步腳本實例

    Shell腳本實戰之DNS主從同步腳本實例

    DNS主從同步腳本實例 PS:兩個服務器起好后最好兩個服務都重啟一下 主服務器配置 #!/bin/bash #DNS主從同步——主服務器 rpm -q bind if [ $? -ne
    2020-01-15
  • shell之分離解析腳本的實現方法

    shell之分離解析腳本的實現方法

    分離解析腳本 在運行腳本之前,需要VM虛擬機,Centos7,兩臺主機一臺win10 -1 作為廣域網的主機, 一臺win10 -2作為區域網的主機。 之前我的博客有教程 #!/bin/ba
    2020-01-15
  • shell之正向解析腳本的實現方法

    shell之正向解析腳本的實現方法

    正向解析腳本 #!/bin/bash yum install bind -y //安裝解析工具包 //修改主配置文件 sed -i '13s/127.0.0.1/192.168.17.156/' /etc/named.conf //把解析主配
    2020-01-15
  • 淺談用Go構建不可變的數據結構的方法

    淺談用Go構建不可變的數據結構的方法

    共享狀態是比較容易理解和使用的,但是可能產生隱晦以至于很難追蹤的 bugs。尤其是在我們的數據結構只有部分是通過引用傳遞的。切片就是這么一個很好的例子。后續我
    2020-01-15
  • Go 防止 goroutine 泄露的方法

    Go 防止 goroutine 泄露的方法

    概述 Go 的并發模型與其他語言不同,雖說它簡化了并發程序的開發難度,但如果不了解使用方法,常常會遇到 goroutine 泄露的問題。雖然 goroutine 是輕量級的線程,占
    2020-01-15
  • Go實現雙向鏈表的示例代碼

    Go實現雙向鏈表的示例代碼

    本文介紹什么是鏈表,常見的鏈表有哪些,然后介紹鏈表這種數據結構會在哪些地方可以用到,以及 Redis 隊列是底層的實現,通過一個小實例來演示 Redis 隊列有哪些功能
    2020-01-15
  • golang中之strconv包的具體使用方法

    golang中之strconv包的具體使用方法

    在編程過程中,我們常常需要用到字符串與其它類型的轉換,strconv包可以幫我們實現此功能。 1.string -> int 使用方法:func Atoi(s string) (i int, err error)
    2020-01-15
  • golang實現對docker容器心跳監控功能

    golang實現對docker容器心跳監控功能

    自己寫的go程序放到線上本來編譯成二進制扔上去就行啦,但是懷著一顆docker的心,最終還是將它放到docker容器中運行起來了,運行起來也ok,一個最小容器64M,統一管
    2020-01-15
  • golang之數據校驗的實現代碼示例

    golang之數據校驗的實現代碼示例

    目前大都是使用 validator 安裝 go get gopkg.in/go-playground/validator.v9 原理 當然只能通過反射來實現了,之前寫過一篇反射的文章 golang之反射和斷言
    2020-01-15
  • golang協程池設計詳解

    golang協程池設計詳解

    Why Pool go自從出生就身帶“高并發”的標簽,其并發編程就是由groutine實現的,因其消耗資源低,性能高效,開發成本低的特性而被廣泛應用到各種場景,例如服務端開
    2020-01-15

最新評論

买宝宝用品赚钱吗