Centos7 从0开始搭建DNS服务器

linux实训的一个小作业,用了两台虚拟机,一台服务端,一台客户端。

服务端搭建(ip:192.168.191.150)

一、安装bind

默认已经配置yum,没配置的配置的找一下网络源教程,很简单。

[root@localhost ~]# yum install -y bind

二、配置文件 

启动named服务 设置开机自启动

[root@localhost ~]# systemctl start named


[root@localhost ~]# systemctl status named

[root@localhost ~]# systemctl enable named

 Active状态就是运行了


配置DNS文件

[root@localhost named]# vim /etc/named.conf

修改标红两行 保存退出

options {
        listen-on port 53 { any; };
        listen-on-v6 port 53 { ::1; };
        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; };
 

[root@localhost etc]# vim /etc/named.rfc1912.zones 

增加以下内容后保存(有改动的地方照抄修改):

zone "moon.name" IN {
        type master;
        file "moon.name.zone";
        allow-update{ none; };
};

确认一下修改 没有输出就是没问题 

 [root@localhost named]# named-checkconf

复制配置文件(方便改) 

 [root@localhost etc]# cd /var/named

[root@localhost named]# cp -p named.localhost moon.name.zone

 修改并保存

[root@localhost named]# vim moon.name.zone 


$TTL 1D
@       IN SOA  @ rname.invalid. (
                                        0       ; serial
                                        1D      ; refresh
                                        1H      ; retry
                                        1W      ; expire
                                        3H )    ; minimum
                NS      @
                A       192.168.191.150
www     IN      A       192.168.191.151
www     IN      A       192.168.191.152
 

确认一下修改是否正常

[root@localhost named]# named-checkzone moon.name moon.name.zone
zone moon.name/IN: loaded serial 0
OK

配置网卡 

[root@localhost named]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.191.150  netmask 255.255.255.0  broadcast 192.168.191.255

        inet6 fe80::aa3a:6536:e924:1a9f  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:ef:05:1b  txqueuelen 1000  (Ethernet)
        RX packets 39787  bytes 22209241 (21.1 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 45380  bytes 13050735 (12.4 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 89877  bytes 7100473 (6.7 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 89877  bytes 7100473 (6.7 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:dd:eb:ed  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

不同机子可能不同,我这个是 ens33,不同下面命令中直接替换就行。

[root@localhost named]# vim /etc/sysconfig/network-scripts/ifcfg-ens33 

 加一行

DNS1=192.168.191.150

IPADDR=192.168.191.150

 修改

BOOTPROTO=static

 三、本机测试

[root@localhost ~]# nslookup moon.name
Server:         192.168.191.150
Address:        192.168.191.150#53

Name:   moon.name
Address: 192.168.191.150


或者


 [root@localhost ~]# ping moon.name
PING moon.name (192.168.191.150) 56(84) bytes of data.
64 bytes from localhost.localdomain (192.168.191.150): icmp_seq=1 ttl=64 time=0.007 ms
64 bytes from localhost.localdomain (192.168.191.150): icmp_seq=2 ttl=64 time=0.134 ms
64 bytes from localhost.localdomain (192.168.191.150): icmp_seq=3 ttl=64 time=0.027 ms
^C
--- moon.name ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2000ms
rtt min/avg/max/mdev = 0.007/0.056/0.134/0.055 ms

能ping通,ip没错就是ok了

关闭防火墙,让客户端能正常访问

 [root@localhost ~]# systemctl stop firewalld

客户端 (ip: 192.168.191.130)

[root@localmoon named]# vim /etc/sysconfig/network-scripts/ifcfg-ens33

加一行保存退出

 DNS1=192.168.191.150

测试 

[root@localmoon named]# nslookup moon.name
Server:         192.168.191.150
Address:        192.168.191.150#53

Name:   moon.name
Address: 192.168.191.150


或者



[root@localmoon named]# ping moon.name
PING moon.name (192.168.191.150) 56(84) bytes of data.
64 bytes from 192.168.191.150 (192.168.191.150): icmp_seq=1 ttl=64 time=0.117 ms
64 bytes from 192.168.191.150 (192.168.191.150): icmp_seq=2 ttl=64 time=0.179 ms
64 bytes from 192.168.191.150 (192.168.191.150): icmp_seq=3 ttl=64 time=0.243 ms
^C
--- moon.name ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2001ms
rtt min/avg/max/mdev = 0.117/0.179/0.243/0.053 ms

The End 


 发现一个很有意思的现象:

当我搭建两台DNS服务器(192.168.191.150和192.168.191.130),在150的服务器解析moon.name,当两台DNS服务器都开启时,将客户端DNS1设置为130,DNS2设置为150,会解析不出moon.name。但是DNS1设置150就可以正常解析了,也就是说当DNS1服务器能够正常访问的时候不会再去DNS2服务器解析?

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在CentOS 7上搭建DNS服务器,你可以按照以下步骤进行操作: 1. 安装BIND软件包: 在终端中执行以下命令来安装BIND软件包: ``` sudo yum install bind bind-utils ``` 2. 配置主配置文件: 编辑`/etc/named.conf`文件,该文件是BIND的主配置文件。你可以使用任何文本编辑器打开该文件,并进行以下配置: ```bash options { listen-on port 53 { any; }; listen-on-v6 port 53 { any; }; 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"; allow-query { any; }; recursion yes; }; zone "example.com" IN { type master; file "/var/named/example.com.zone"; allow-update { none; }; }; ``` 这里使用了一个名为"example.com"的示例域名,你可以根据需要修改为你自己的域名。 3. 创建区域文件: 创建一个区域文件来存储DNS记录。在终端中执行以下命令来创建该文件: ```bash sudo nano /var/named/example.com.zone ``` 在打开的文件中,添加以下示例配置: ```bash $TTL 86400 @ IN SOA ns1.example.com. root.example.com. ( 2018010101 ; Serial 3600 ; Refresh 1800 ; Retry 604800 ; Expire 86400 ) ; Minimum @ IN NS ns1.example.com. @ IN A 192.168.1.100 ns1 IN A 192.168.1.100 www IN A 192.168.1.101 ``` 4. 设置文件权限和SELinux策略: 执行以下命令来设置文件权限: ```bash sudo chown named:named /var/named/example.com.zone ``` 执行以下命令来设置SELinux策略: ```bash sudo restorecon -v /var/named/example.com.zone ``` 5. 启动和配置BIND服务: 启动BIND服务并将其设置为开机自启动: ```bash sudo systemctl enable named sudo systemctl start named ``` 6. 配置防火墙规则: 如果系统上启用了防火墙,你需要打开DNS服务器的相关端口。执行以下命令来配置防火墙规则: ```bash sudo firewall-cmd --permanent --add-service=dns sudo firewall-cmd --reload ``` 现在,你已经在CentOS 7上成功搭建DNS服务器。你可以根据自己的需求添加更多的记录到区域文件中,并在客户端上配置DNS服务器地址来使用它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值