linux dns服务器怎么设置

linux dns服务器怎么设置,第1张

在linux系统中一般通过bind软件包来提供dns服务。

1、环境准备:

临时关闭selinux和iptables

#setenforce 0
#service iptables stop

2、查询相关软件包:

[root@localhost ~]# yum search bind
Loaded plugins: product-id, refresh-packagekit, subscription-manager
Updating Red Hat repositories
====================================================================================== N/S Matched: bind ======================================================================================
PackageKit-device-rebindi686 : Device rebind functionality for PackageKit
bindi686 : The Berkeley Internet Name Domain (BIND) DNS (Domain Name System) server
bind-chrooti686 : A chroot runtime environment for the ISC BIND DNS server, named(8)
bind-utilsi686 : Utilities for querying DNS name servers

其中各软件包的作用如下:

1)、bind: 提供域名服务的主要程序及相关文件。

2)、bind-chroot:为bind提供一个伪装的根目录以增强安全性。

3)、bind-utils:提供对DNS服务器测试的工具程序(如nslookup、dig等)。

3、安装BIND软件包

#yum install bind

4、配置DNS服务器:

1)、bind服务器端程序

主要执行程序:/usr/sbin/named

服务脚本:、etc/initd/named

默认监听端口:53

主配置文件: /etc/namedconf

保存DNS解析记录的数据文件: /var/named/chroot/var/named

2)、查询bind程序的配置文件列表

[root@localhost ~]# rpm -qc bind
/etc/logrotated/named
/etc/namedconf
/etc/namediscdlvkey
/etc/namedrfc1912zones
/etc/namedrootkey
/etc/rndcconf
/etc/rndckey
/etc/sysconfig/named
/var/named/namedca
/var/named/namedempty
/var/named/namedlocalhost
/var/named/namedloopback

3)、查看主配置文件namedconf

#vim /etc/namedconf

4)、主配置文件解析:

a、全局配置部分,默认的全局配置项如下:

options {
 11         listen-on port 53 { 127001; };                 //监听的端口和接口IP地址
 12         listen-on-v6 port 53 { ::1; };
 13         directory       "/var/named";                       //dns区域的数据文件默认存放位置
 14         dump-file       "/var/named/data/cache_dumpdb";
 15         statistics-file "/var/named/data/named_statstxt";
 16         memstatistics-file "/var/named/data/named_mem_statstxt";
 17         allow-query     { localhost; };                 //允许dns查询的客户机列表,any表示所有
 18         recursion yes;                                       //是否允许客户机进行递归查询
 19
 20         dnssec-enable yes;
 21         dnssec-validation yes;
 22         dnssec-lookaside auto;
 23
 24         / Path to ISC DLV key /
 25         bindkeys-file "/etc/namediscdlvkey";
 26 };

全局配置中还有如下选项:

     //将本域名服务器不能解析的条目转发给其它DNS服务器的IP地址
     forwarders {2021022468;12333;};

b、默认的区域配置项如下:

 35 zone "" IN {
 36         type hint;      //区域类型。hint为根区域;master为主区域; slave为辅助区域
 37         file "namedca";          //该区域对应的区域数据配置文件名
 38 };

区域配置中还有如下选项:

//允许下载区域数据库的从域名服务器IP地址
allow-transfer {189989023;};              
//允许动态更新的客户端IP地址(none表示全部禁止)
allow-update {none;};

添加如下区域配置:

zone “mycom” IN {
         type master;                      //主区域
         file “mycom”;                    //该区域对应的区域数据配置文件名
allow-transfer {1921681531;};           //允许下载区域数据库的从域名服务器IP地址
         allow-update {none;};
};
zone “153168192in-addrarpa” IN {       //表示针对IP192168153130反向解析
         type master;                      //主区域
         file “192168153myarpa”;       //该区域对应的区域数据配置文件名
};

5)、配置完了,可以执行如下命令对namedconf文件进行语法检查。

#named-checkconf

注意:倒序网络地址in-addrarpa 表示反向区域

主配置文件最后还有一行是:

//该文件包含/etc/namedrfc1912zones文件
include “/etc/namedrfc1912zones”

区域数据配置文件:

先看一下namedlocalhost的内容:

$TTL 1D             //time to live 生存时间
@       IN SOA  @ rnameinvalid (                    //”rnameinvalid”DNS区域地址
                                        0       ; serial      //更新序列号
                                        1D      ; refresh  //更新时间
                                        1H      ; retry      //重试延时
                                        1W      ; expire   //失效时间
                                        3H )    ; minimum          //无效地址解析记录的默认缓存时间
        NS      @              //name server 域名服务记录
        A       127001                   //address 只用在正向解析的区域数据文件中
        AAAA    ::1

新建2个对应的区域数据配置文件:

#touch mycom
#touch 192168153myarpa
#vim mycom
$TTL 86400
@ IN SOA mycom adminmycom (        //adminmycm为该区域管理员的邮箱地址
        200900201
        3H
        15M
        1W
        1D
)
@       IN      NS      ns1mycom           //当前域的DNS服务器地址
        IN      MX      10      mailmycom         //用于设置当前域的邮件服务器域名地址,数字10表示优先级别,数字越大优先级越低
ns1     IN      A       192168153130
mail    IN      A       192168153130

启动DNS服务

[root@localhost ~]# service named start

4、测试:

配置一台ftp服务器用于测试:

#service vsftpd start            //启动vsftpd服务当前网卡的配置:
eth0: 19216801/24
eth1: 192168153130/24[root@localhost named]# nslookup 192168153130
Server:               127001
Address:  127001#53
 
130153168192in-addrarpa         name = >1两个网络接口、一个内,一个外2NAT转换(内) *** 作步骤:1设置Linux内核支持ip数据包的转发:echo "1" > /proc/sys/net/ipv4/ip_forward2加载实现NAT功能必要的内核模块:modprobe ip_tablesmodprobe ip_nat_ftpmodprobe ip_nat_ircmodprobe ip_conntrackmodprobe ip_conntrack_ftpmodprobe ip_conntrack_irc3对iptables中的规则表进行初始化:iptables -Fiptables -Xiptables -Ziptables -F -t natiptables -X -t natiptables -Z -t nat4设置规则链的默认策略:

理解Runlevel
runlevel用来表示在init进程结束之后的系统状态,在系统的硬件中没有固定的信息来表示
0是关闭系统。
1是用来将系统转到单用户模式,单用户模式只能有系统管理员进入,在该模式下处理那些在有登录用户的情况下不能进行更改的文件。
2是允许系统进入多用户的模式,但并不支持文件共享,这种模式非常少应用。
3是最常用的运行模式,主要用来提供真正的多用户模式,也是多数服务器的缺省模式。
4一般不被系统使用。
5是有图形界面的多用户模式。
6是重新启动系统。/
###表示当前缺省运行级别为5(initdefault);
如果上面六种模式你都知道的话就编辑 vim /etc/inittab找到下面这一行id:5:initdefault:
将其更改为不同的运行模式。
你可以看看这篇文章或许对你有帮助

以架设WEB服务器为例:
1,架设linux环境的服务器运行环境,如PHP+MYSQL和支持静态网页的服务器。
2,添加对应的数据库,PHP网页。
3,用局域网的电脑打开对应的IP地址,浏览成功,WEB服务器建设成功。
4,如果要提供互联网服务,还需要申请固定IP地址,域名申请,域名备案,IDC备案,域名指向等相应工作。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/12617864.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2025-08-26
下一篇2025-08-26

发表评论

登录后才能评论

评论列表(0条)

    保存