Linux基于bind快速搭建内网DNS服务器主从模式
Posted 白-胖-子
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux基于bind快速搭建内网DNS服务器主从模式相关的知识,希望对你有一定的参考价值。
1. 目的
- 内网服务器通过设置内网DNS访问互联网
- 内网DNS服务器解析内部域名
2. 环境准备
- DNS服务器 10.0.0.88 可以正常访问互联网
- 内部服务器 10.0.0.181 设置DNS地址为10.0.0.88
3. 搭建主DNS正向解析服务器
3.1 安装bind软件和bind-unit工具
yum -y install bind bind-utils
3.2 修改配置文件
- sunmy.pro域 主DNS服务器10.0.0.181/24上实现
- sunmy.pro域 从DNS服务器10.0.0.182/24上实现
3.3 在主配置文件中设定从服务器
vim /etc/named.conf
#在options {段中找到并注释掉下面两行
// listen-on port 53 { 127.0.0.1; };
// allow-query { localhost; };
#同时在在options {段中添加从服务器
allow-transfer { 10.0.0.182; };
#只允许从服务器进行区域传输
3.4定义sunmy.pro主域区域文件
- 定义名为sunmy.pro的区域
- 并且指明了区域的配置文件
vim /etc/named.rfc1912.zones
#在文件末尾加上这段
zone "sunmy.pro" IN {
type master;
file "sunmy.pro.zone";
allow-update { none; };
};
3.5 添加DNS区域数据库文件,并写入内容
- 可以通过拷贝模板文件进行修改
[root@c7-181 ~]# ls /var/named/
data dynamic named.ca named.empty named.localhost named.loopback slaves
[root@c7-181 ~]# cp /var/named/named.empty /var/named/sunmy.pro.zone
[root@c7-181 ~]# vim /var/named/sunmy.pro.zone
- 直接写入以下内容
vim /var/named/sunmy.pro.zone
$TTL 1D
@ IN SOA master admin.sunmy.pro. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS master
NS slave
master A 10.0.0.181
slave A 10.0.0.182
www A 10.0.0.184
3.6 启动named服务并设为开机启动
chgrp named /var/named/sunmy.pro.zone
systemctl enable --now named #第一次启动服务
rndc reload #不是第一次启动服务
[root@c7-181 ~]# chgrp named /var/named/sunmy.pro.zone
[root@c7-181 ~]# systemctl enable --now named
Created symlink from /etc/systemd/system/multi-user.target.wants/named.service to /usr/lib/systemd/system/named.service.
[root@c7-181 ~]# rndc reload
server reload successful
3.7客户端设置DNS并测试
- 局域网内任意服务器修改DNS指向10.0.0.181,测试能否解析www.sunmy.pro
[root@C6-198 ~]# vim /etc/sysconfig/network-scripts/ifcfg-eth0
[root@C6-198 ~]# service network restart
Shutting down interface eth0: Device state: 3 (disconnected)
[ OK ]
Shutting down loopback interface: [ OK ]
Bringing up loopback interface: [ OK ]
Bringing up interface eth0: Active connection state: activated
Active connection path: /org/freedesktop/NetworkManager/ActiveConnection/9
[ OK ]
[root@C6-198 ~]# cat /etc/resolv.conf
# Generated by NetworkManager
nameserver 10.0.0.181
[root@C6-198 ~]# curl www.sunmy.pro
恭喜你!实验成功!<br>
最终目的是要实现在客户端10.0.0.198设置DNS为10.0.0.188的前提下<br>
客户端10.0.0.198可以访问到www.sunmy.pro WEB服务器10.0.0.184上的页面
4. 搭建从属DNS正向解析服务器
- sunmy.pro域从服务器实现主挂了从能用
C7 - 10.0.0.182
4.1 安装bind软件和bind-unit工具
yum -y install bind bind-utils
4.2 修改配置文件
- sunmy.pro域从DNS服务器在10.0.0.182/24上实现
vim /etc/named.conf
// listen-on port 53 { 127.0.0.1; };
// allow-query { localhost; };
#不允许其它主机进行区域传输
allow-transfer { none; };
4.3 定义区域文件并指定主服务器IP
zone "sunmy.pro" IN {
type slave;
masters { 10.0.0.181; };
file "slaves/sunmy.pro.slave";
}
4.4 启动named服务并设为开机启动
systemctl start named #第一次启动服务
rndc reload #不是第一次启动服务
[root@c7-182 ~]# ll /var/named/slaves/
total 4
-rw-r--r-- 1 named named 310 May 6 20:27 sunmy.pro.slave
4.5 停用主服务器,测试从服务器
- 客户端配两个DNS
DEVICE=eth0
NAME=eth0
BOOTPROTO=none
ONBOOT=yes
IPADDR=10.0.0.198
PREFIX=24
GATEWAY=10.0.0.2
#DNS1=114.114.114.114
#DNS2=223.6.6.6
#DNS1=10.0.0.188
DNS1=10.0.0.181
DNS2=10.0.0.182
- 主服务器停止named服务
[root@c7-181 ~]# systemctl stop named
4.6 使用dig命令测试www.sunmy.pro
[root@C6-198 ~]# dig www.sunmy.pro
; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.68.rc1.el6 <<>> www.sunmy.pro
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 15174
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 2
;; QUESTION SECTION:
;www.sunmy.pro. IN A
;; ANSWER SECTION:
www.sunmy.pro. 86400 IN A 10.0.0.184
;; AUTHORITY SECTION:
sunmy.pro. 86400 IN NS master.sunmy.pro.
sunmy.pro. 86400 IN NS slave.sunmy.pro.
;; ADDITIONAL SECTION:
master.sunmy.pro. 86400 IN A 10.0.0.181
slave.sunmy.pro. 86400 IN A 10.0.0.182
;; Query time: 3 msec
;; SERVER: 10.0.0.182#53(10.0.0.182)
;; WHEN: Fri May 7 04:42:53 2021
;; MSG SIZE rcvd: 120
从服务器已生效
以上是关于Linux基于bind快速搭建内网DNS服务器主从模式的主要内容,如果未能解决你的问题,请参考以下文章