当前位置:首页 > Linux > 正文

Linux快速搭建DNS服务器配置指南

在Linux上架设DNS服务器通常使用BIND软件:安装BIND,编辑主配置文件 named.conf定义区域,创建正/反向解析的区域文件,最后启动 named服务并设置开机自启即可完成基础部署。

在Linux系统上架设DNS服务器(以BIND9为例)是一项提升网络管理效率和自主性的关键技能,以下为详细操作指南,所有步骤均基于主流Linux发行版(如Ubuntu/CentOS),确保安全性和可操作性:


核心原理与准备工作

  1. DNS作用
    将域名(如 www.example.com)解析为IP地址,实现互联网资源定位。
  2. 所需环境
    • Linux服务器(建议Ubuntu 20.04+或CentOS 7+)
    • root或sudo权限
    • 静态IP地址(例:168.1.10
    • 域名(需已注册,如 example.com

安装BIND9 DNS软件

# Ubuntu/Debian
sudo apt update && sudo apt install bind9 bind9-utils -y
# CentOS/RHEL
sudo yum install bind bind-utils -y

配置主DNS服务器

主配置文件修改

编辑 /etc/bind/named.conf.options

options {
    directory "/var/cache/bind";
    listen-on port 53 { 127.0.0.1; 192.168.1.10; }; # 监听本机和服务器IP
    allow-query { localhost; 192.168.1.0/24; };     # 允许查询的客户端网段
    recursion yes;                                   # 启用递归查询
    forwarders { 8.8.8.8; 8.8.4.4; };               # 上级DNS(如Google DNS)
};

定义正向解析区域

编辑 /etc/bind/named.conf.local

Linux快速搭建DNS服务器配置指南  第1张

zone "example.com" {
    type master;
    file "/etc/bind/zones/db.example.com";  # 区域文件路径
};

创建正向区域文件

新建 /etc/bind/zones/db.example.com

$TTL 86400
@       IN      SOA     ns1.example.com. admin.example.com. (
                          2025080101   ; 序列号 (格式:YYYYMMDDNN)
                          3600         ; 刷新时间
                          1800         ; 重试时间
                          604800       ; 过期时间
                          86400        ; 缓存TTL
)
@       IN      NS      ns1.example.com.
ns1     IN      A       192.168.1.10
www     IN      A       192.168.1.100
mail    IN      A       192.168.1.200

配置反向解析(可选)

/etc/bind/named.conf.local 添加:

zone "1.168.192.in-addr.arpa" {
    type master;
    file "/etc/bind/zones/db.192.168.1";
};

新建反向区域文件 /etc/bind/zones/db.192.168.1

$TTL 86400
@ IN SOA ns1.example.com. admin.example.com. ( 2025080101 3600 1800 604800 86400 )
@ IN NS ns1.example.com.
10 IN PTR ns1.example.com.   ; 192.168.1.10 -> ns1
100 IN PTR www.example.com.  ; 192.168.1.100 -> www

启动与验证服务

# 重启BIND并设置开机自启
sudo systemctl restart named
sudo systemctl enable named
# 检查配置语法
sudo named-checkconf
sudo named-checkzone example.com /etc/bind/zones/db.example.com
# 使用dig测试解析
dig @192.168.1.10 www.example.com
# 应返回 "192.168.1.100"

安全加固措施

  1. 限制区域传输
    在区域文件中添加:

    zone "example.com" {
        ...
        allow-transfer { 192.168.1.20; }; # 只允许从服务器IP同步
    };
  2. 禁用BIND版本泄露
    named.conf.options 添加:

    version "Not disclosed";
  3. 防火墙规则
    sudo ufw allow 53/tcp    # 区域传输需TCP
    sudo ufw allow 53/udp    # 查询用UDP

故障排查与维护

  • 日志查看tail -f /var/log/syslog | grep named
  • 测试工具
    nslookup www.example.com 192.168.1.10
    dig -x 192.168.1.100 @192.168.1.10
  • 更新记录后:递增区域文件序列号(SOA中的2025080101 → 2025080102)并重启BIND。

应用场景扩展

  • 内部网络管理:为局域网设备分配易记域名(如 printer.lan)。
  • 域名托管:自主管理企业域名解析,避免第三方服务商限制。
  • 高可用方案:部署从DNS服务器(Slave)实现负载均衡。

引用说明:本文配置参考ISC BIND官方文档(https://www.isc.org/bind/),并结合Linux man-pages及RFC 1035 DNS标准协议,安全建议遵循CIS Benchmarks for BIND最佳实践。

通过此指南,您可快速部署符合生产环境标准的DNS服务器,实际部署时需根据网络拓扑调整IP和域名,并定期更新软件以修复破绽。

0