BIND + LVS + Keepalived 搭建内网DNS集群-分区域响应结果,可做智能解析

本次配置的所有服务器均为虚拟机,操作系统为Centos 7.3。


服务器名称 IP地址
DNS客户端 所有私有地址
DNS-BIND-1 10.20.121.179
DNS-BIND-2 10.20.121.184
DNS-VIP 10.20.120.150
DNS-LVS-主 10.20.121.187
DNS-LVS-备 10.20.121.157
架构拓扑图片

本次部署的LVS是基于DR的工作模式,负载均衡调度方式使用了RR,客户端发起DNS请求是,LVS回轮询发送至每台服务器上。DNS服务器解析请求后直接返回给客户端。

在LVS(TUN)模式下,由于需要在LVS调度器与真实服务器之间创建隧道连接,这同样会增加服务器的负担。与LVS(TUN)类似,DR模式也叫直接路由模式,其体系结构如图4所示,该模式中LVS依然仅承担数据的入站请求以及根据算法选出合理的真实服务器,最终由后端真实服务器负责将响应数据包发送返回给客户端。与隧道模式不同的是,直接路由模式(DR模式)要求调度器与后端服务器必须在同一个局域网内,VIP地址需要在调度器与后端所有的服务器间共享,因为最终的真实服务器给客户端回应数据包时需要设置源IP为VIP地址,目标IP为客户端IP,这样客户端访问的是调度器的VIP地址,回应的源地址也依然是该VIP地址(真实服务器上的VIP),客户端是感觉不到后端服务器存在的。由于多台计算机都设置了同样一个VIP地址,所以在直接路由模式中要求调度器的VIP地址是对外可见的,客户端需要将请求数据包发送到调度器主机,而所有的真实服务器的VIP地址必须配置在Non-ARP的网络设备上,也就是该网络设备并不会向外广播自己的MAC及对应的IP地址,真实服务器的VIP对外界是不可见的,但真实服务器却可以接受目标地址VIP的网络请求,并在回应数据包时将源地址设置为该VIP地址。调度器根据算法在选出真实服务器后,在不修改数据报文的情况下,将数据帧的MAC地址修改为选出的真实服务器的MAC地址,通过交换机将该数据帧发给真实服务器。整个过程中,真实服务器的VIP不需要对外界可见。

引用图片,原文链接:https://blog.csdn.net/weixin_40470303/java/article/details/80541639

轮询调度(Round Robin 简称'RR')算法就是按依次循环的方式将请求调度到不同的服务器上,该算法最大的特点就是实现简单。轮询算法假设所有的服务器处理请求的能力都一样的,调度器会将所有的请求平均分配给每个真实服务器。
————————————————
版权声明:本文为CSDN博主「chenhuyang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_40470303/java/article/details/80541639

DNS集群搭建

在每台服务器上安装ntpdate,确保时间同步。

yum -y install ntpdate
echo "" >> /var/spool/cron/root
crontab -l > crontabtmp && echo "0 * * * * ntpdate cn.ntp.org.cn" >> crontabtmp  && crontab crontabtmp && rm -f crontabtmp 

安装BIND软件

yum安装bind-chroot,顾名思义这个是可指定chroot的bind,比较安全。

yum -y install bind-chroot bind-utils net-tools initscripts
systemctl enable named-chroot

bind-utils是bind软件提供的一组DNS工具包,里面有一些DNS相关的工具.主要有:dig,host,nslookup,nsupdate.使用这些工具可以进行域名解析和DNS调试工作.

编辑配置文件

这里开始主DNS的配置,下面是配置named.conf,默认安装的路径为/etc/named.conf

acl trusted {
        10.0.0.0/8;
        172.16.0.0/12;
        192.168.0.0/16;
};

options {
        listen-on port 53 { 10.20.121.179;10.20.120.150; };
        listen-on-v6 port 53 { none; };
        directory       "/var/named";
        dump-file       "/var/named/data/cache_dump.db";
        statistics-file "/var/named/data/named_stats.txt";
        memstatistics-file "/var/named/data/named_mem_stats.txt";
        recursing-file  "/var/named/data/named.recursing";
        secroots-file   "/var/named/data/named.secroots";
        allow-query     { trusted; };
        allow-recursion    { trusted; };
        forward first;
        forwarders    {
                218.1.1.1;
                218.2.2.2;
                114.114.114.114;
                223.5.5.5;
                223.6.6.6;
                8.8.8.8;
        };
        recursion yes;
        dnssec-enable no;
        dnssec-validation no;
        bindkeys-file "/etc/named.root.key";
        managed-keys-directory "/var/named/dynamic";
        pid-file "/run/named/named.pid";
        session-keyfile "/run/named/session.key";
};
logging {
        channel default_debug {
                file "data/named.run";
                severity dynamic;
        };
};

zone "." IN {
        type hint;
        file "named.ca";
};
zone "test.cn" IN {
    type master; 
    file "/etc/named/test.cn.zone";
    allow-update { none; };
    allow-transfer { 10.20.121.184; };
    notify yes;
};
zone "test-fw.cn" IN {
        type forward;
        forwarders { 10.20.120.34; };
};
include "/etc/named.rfc1912.zones";
include "/etc/named.root.key";

配置区域数据文件

cat /etc/named/test.cn.zone
$TTL 1D
@       IN SOA  dns1.test.cn.  admin.test.cn. (
                                        202007031649      ; serial #这里每次修改解析关系时,需要修改。保证数值比从服务器的数值要大
                                        1D      ; refresh
                                        1H      ; retry
                                        1W      ; expire
                                        3H )    ; minimum
           NS   dns1.test.cn.
           NS   dns2.test.cn.
dns1    IN A    10.20.121.179
dns2    IN A    10.20.121.184

从DNS服务器搭建和配置

从DNS服务器安装与主DNS安装方法一样,只是在配置文件上有些改动,且不需要配置区域数据文件。

zone "test.cn" IN {
    type slave;  #从服务器只需要将这里改为slave
    masters { 10.20.121.179; };
    file "slaves/test.cn.zone"; #配置区域数据文件存放目录
    allow-transfer{ none; }; #禁止为其他从服务器同步数据
};

LVS + keepalived

加载ip_vs内核模块

modprobe ip_vs

安装ntp,ipvsadm,编译环境等

yum -y install ntpdate ipvsadm wget gcc gcc-c++ make popt-devel kernel-devel openssl-devel libnl3-devel

安装keepalived

curl -O https://www.keepalived.org/software/keepalived-2.1.3.tar.gz
tar -zxf keepalived-2.1.3.tar.gz
cd keepalived-2.1.3
./configure
make && make install

创建keepalived开机启动

cp keepalived/etc/init.d/keepalived /etc/init.d/  #keepalived执行文件在源码包中
cp keepalived/etc/sysconfig/keepalived /etc/sysconfig/keepalived
cp bin/* /usr/bin/
systemctl enable keepalived

拷贝配置文件至默认目录,因为上面的编译安装时configure是默认配置,所以需要将配置文件拷贝至默认目录中/etc/keepalived/

mkdir /etc/keepalived/
cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/

编辑配置文件

! Configuration File for keepalived

global_defs {
   router_id LVS_DR01
   vrrp_skip_check_adv_addr
   vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        10.20.120.150
    }
}

virtual_server 10.20.120.150 53 {
    delay_loop 6             
    lb_algo rr            
    lb_kind DR              
    protocol UDP          
 
    real_server 10.20.121.179 53 {
        weight 1  
        TCP_CHECK {           
        connect_timeout 3
        retry 3
        delay_before_retry 3
        }
    }
 
    real_server 10.20.121.184 53 {
        weight 1
        TCP_CHECK {
        connect_port 53
            connect_timeout 3
            retry 3
            delay_before_retry 3
        }
    }
}

备服务器安装配置与主服务器基本一样,只是配置文件中需要简单修改下

! Configuration File for keepalived

global_defs {
   router_id LVS_DR02
   vrrp_skip_check_adv_addr
   vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        10.20.120.150
    }
}

virtual_server 10.20.120.150 53 {
    delay_loop 6             
    lb_algo rr            
    lb_kind DR              
    protocol UDP          
 
    real_server 10.20.121.179 53 {
        weight 1  
        TCP_CHECK {           
        connect_timeout 3
        retry 3
        delay_before_retry 3
        }
    }
 
    real_server 10.20.121.184 53 {
        weight 1
        TCP_CHECK {
        connect_port 53
            connect_timeout 3
            retry 3
            delay_before_retry 3
        }
    }
}

DNS服务器配置

在每台机器的/etc/init.d/目录中创建一个lvsrs文件,如下:

cat /etc/init.d/lvsrs
#!/bin/sh
# chkconfig:   2345 90 10
# description: LVS DirectorServer
VIP=10.20.120.150
. /etc/rc.d/init.d/functions
case "$1" in
start)
  echo "start LVS of DirectorServer"
        /sbin/ifconfig lo:0 $VIP broadcast $VIP netmask 255.255.255.255 up
        echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
        echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
        echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
        echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
;;
stop)
        /sbin/ifconfig lo:0 down
        echo "close LVS  DirectorServer"
        echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
        echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
        echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
        echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
;;
*)
echo "Usage:$0 {start|stop}"
exit 1
esac

给予文件可执行权限

chmod +x /etc/init.d/lvsrs

将脚本设置为开机启动

systemctl enable lvsrs
systemctl start lvsrs

按照不同IP来源返回不同IP(BIND9+版本的Views功能)

采用key认证方式配置主从DNS服务

#使用Bind自带工具ddns-confgen生成key文件。
ddns-confgen -a hmac-md5

生成如下一段字符串

key "key-file" {
        algorithm hmac-md5;
        secret "zB3aHy***********HQQ==";
};

需要配置几个区域就生成几次。

最终配置文件

主:

acl dnsserver {
    10.20.121.184;
    10.20.121.179;
};
acl lan {
        10.0.0.0/8;
        172.16.0.0/12;
        192.168.0.0/16;
};
acl wan {
    !"lan";
    any;
};

options {
        listen-on port 53 { 10.20.121.179;10.20.120.150; };
        listen-on-v6 port 53 { none; };
        directory       "/var/named";
        dump-file       "/var/named/data/cache_dump.db";
        statistics-file "/var/named/data/named_stats.txt";
        memstatistics-file "/var/named/data/named_mem_stats.txt";
        recursing-file  "/var/named/data/named.recursing";
        secroots-file   "/var/named/data/named.secroots";
        allow-query     { any; };
        allow-recursion    { lan; };
        forward first;
        forwarders    {
        202.101.172.35;
                114.114.114.114;
                223.5.5.5;
                223.6.6.6;
                8.8.8.8;
        };
        recursion yes;

        dnssec-enable no;
        dnssec-validation no;
        bindkeys-file "/etc/named.root.key";
        managed-keys-directory "/var/named/dynamic";
        pid-file "/run/named/named.pid";
        session-keyfile "/run/named/session.key";
};
logging {
        channel default_debug {
                file "data/named.run";
                severity dynamic;
        };
};

key "key-lan" {
    algorithm hmac-md5;
    secret "zB3aHy**********rIHQQ==";
};
key "key-wan" {
    algorithm hmac-md5;
    secret "w1U**********FSh9SQ==";
};
key "key-none" {
    algorithm hmac-md5;
    secret "Whs+3iql**********wrfA==";
};

masters "dnsserver" {
    10.20.121.184;
    10.20.121.179;
};


view "lan" {
    match-clients {
        key key-lan;
        "lan";
    };
    server 10.20.121.179 {keys key-lan;}; 
    allow-transfer { key key-lan; };
    allow-notify {  "dnsserver"; };
    also-notify { "dnsserver"; };
    zone    "." IN {
        type    hint;
        file    "named.ca";
    };
    include "/etc/named.rfc1912.lan.zones";
    include "/etc/named.root.key";
};
view "wan" {
    match-clients {
        key key-wan;
        "wan";
    };
    server 10.20.121.179 {keys key-wan;}; 
        allow-transfer { key key-wan; };
    allow-notify {  "dnsserver"; };
    also-notify { "dnsserver"; };
    zone    "." IN {
        type    hint;
        file    "named.ca";
    };
    include "/etc/named.rfc1912.zones";
    include "/etc/named.root.key";
};

主机文件 :/etc/named.rfc1912.lan.zones

cat /etc/named.rfc1912.lan.zones
zone "test-1.com" IN {
        type master;
        file "dns/test-1.dns";
    allow-update { none; };
    notify yes;
};

主机文件 :/etc/named.rfc1912.zones

cat /etc/named.rfc1912.lan.zones
zone "test-1.com" IN {
        type master;
        file "test-1.dns";
    allow-update { none; };
    notify yes;
};

备:

acl dnsserver {
    10.20.121.184;
    10.20.121.179;
};
acl lan {
        10.0.0.0/8;
        172.16.0.0/12;
        192.168.0.0/16;
};
acl wan {
    !"lan";
    any;
};
options {
        listen-on port 53 { 10.20.121.184;10.20.120.150; };
        listen-on-v6 port 53 { none; };
        directory       "/var/named";
        dump-file       "/var/named/data/cache_dump.db";
        statistics-file "/var/named/data/named_stats.txt";
        memstatistics-file "/var/named/data/named_mem_stats.txt";
        recursing-file  "/var/named/data/named.recursing";
        secroots-file   "/var/named/data/named.secroots";
        allow-query     { any; };
        allow-recursion    { lan; };
        forward first;
        forwarders    {
        202.101.172.35;
                114.114.114.114;
                223.5.5.5;
                223.6.6.6;
                8.8.8.8;
        };
        recursion yes;
        dnssec-enable no;
        dnssec-validation no;
        bindkeys-file "/etc/named.root.key";
        managed-keys-directory "/var/named/dynamic";
        pid-file "/run/named/named.pid";
        session-keyfile "/run/named/session.key";
        max-cache-ttl 60;
        max-cache-size 10240M;
        max-ncache-ttl 60;
        cleaning-interval 15;
};
logging {
        channel default_debug {
                file "data/named.run";
                severity dynamic;
        };
        channel query_log {
                file "/var/run/named/query.log" versions 55 size 100m;
                severity dynamic;
                print-time yes;
                print-category yes;
        };
        category queries { query_log;};
        category default { null;};

};
key "key-lan" {
        algorithm hmac-md5;
        secret "zB3aHyt6r6aOaJ/I9rIHQQ==";
};
key "key-wan" {
        algorithm hmac-md5;
        secret "w1UhtLdOGREhSYimFSh9SQ==";
};
key "key-none" {
        algorithm hmac-md5;
        secret "Whs+3iqlwShOapXRW8wrfA==";
};


view "lan" {
        match-clients {
                "lan";
        };
    server 10.20.121.179 {keys key-lan;};
        zone    "."     IN {
                type    hint;
                file    "named.ca";
        };
        include "/etc/named.rfc1912.lan.zones";
        include "/etc/named.root.key";
};
view "wan" {
        match-clients {
                "wan";
        };
    server 10.20.121.179 {keys key-wan;};
        zone    "."     IN {
                type    hint;
                file    "named.ca";
        };
        include "/etc/named.rfc1912.zones";
        include "/etc/named.root.key";
};

备机文件 :/etc/named.rfc1912.lan.zones

cat /etc/named.rfc1912.lan.zones
zone "test-1.cn" IN {
        type slave;
    masters { 10.20.121.179; };
    masterfile-format text;
    file "slaves/lan_test-1.dns";
    allow-transfer{ none; };
};

备机文件 :/etc/named.rfc1912.zones

cat /etc/named.rfc1912.lan.zones
zone "test-1.cn" IN {
        type slave;
    masters { 10.20.121.179; };
    masterfile-format text;
    file "slaves/test-1.dns";
    allow-transfer{ none; };
};

配置DNS集群只需要克隆备机,然后把named.conf的监听ip地址重新配置即可。
新DNS Server上线后,在lvs的文件内添加新IP,重启就上线完成了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343