bind 服务器搭建

本文详细介绍了在Linux上安装并配置BIND DNS服务器的过程,包括主要组件、配置文件及关键参数设置,以及如何测试服务器运行状态。
Linux上DNS上服务器只要是BIND,是伯克利大学开发的。下面是主要的安装以及配置,
yum install bind*
bind安装好之后主要的daemon是named,一般情况下会自动安装好bind-chroot,chroot的存在主要就是为了保护系统的安全性,就算bind被黑了,黑客也只能在chroot的目录里面活动,有点vsftpd里的味道,但是不相同。
bind通用配置文件/etc/named.conf
bind通过对每个域名和IP映射关系形成zone来工作,每个zone的配置文件在/var/named/下面,由于使用了chroot,bind会把 / 变更到 /var/named/chroot 下(默认yum安装好的情况),也就是说
/etc/named.conf <==> /var/named/chroot/etc/named.conf
/var/named/ <==> /var/named/chroot/var/named/
可以测试下,启动了bind-chroot之后,你对/etc/named.conf修改会同步到/var/named/chroot/etc/named.conf ,同样的也适用于/var/named/ 下的zone配置文件
下面介绍下named.conf
================================================================================

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//named.conf

options{ //通用配置
listen-on port53{127.0.0.1;};
listen-on-v6 port53{::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";
allow-query {localhost;};
recursion yes;

dnssec-enable yes;
dnssec-validation yes;
dnssec-lookasideauto;

/* Path to ISC DLV key */
bindkeys-file"/etc/named.iscdlv.key";

managed-keys-directory"/var/named/dynamic";
};

logging{
channel default_debug{
file"data/named.run";
severity dynamic;
};
};

zone"."IN{ //定义根域的zone,对应的 /var/named/named.ca 列出所有根域名服务器
type hint;
file"named.ca"; //可以在 /usr/share/doc/bind-9.8.2/sample/var/named/ 获取named.ca模板
};

zone"localhost"IN{ //定义“localhost”的zone,对应 /var/named/named.localhost
type master; //master 就是主DNS Server
file"named.localhost";
};

zone"0.0.127.in-addr.arpa"IN{
type master;
file"named.127.0.0";
};

include"/etc/named.root.key";

//以上可以是默认的基本配置,下面添加一个zone,域名是fire.net
zone"fire.net"IN{
type master;
file"fire.zone";
};

================================================================================

本地正向解析文件 /var/named/named.localhost

1
2
3
4
5
6
7
8
9
$TTL3600
@ IN SOA localhost.root.localhost.( ;@就是代表对应/etc/named.conf zone对应的名字 zone"xxx"
0 ;serial
1D ;refresh
1H ;retry
1W ;expire
3H) ;minimum
@ IN NS localhost. ;IN 代表一条资源记录(RR),NS=NameServer 代表DNS Server
localhost. IN A 127.0.0.1 ;A 是正向解析的标志,[hostname]IN A[IP]代表该主机对应该IP

本地反向解析文件 /var/named/named.127.0.0

1
2
3
4
5
6
7
8
9
$TTL600
@ IN SOA localhost.root.localhost.(
0 ;serial
1D ;refresh
1H ;retry
1W ;expire
3H) ;minimum
@ IN NS localhost.
1 IN PTR localhost. ;PTR为反向解析,与上面的 A 标志对应

上面是基本配置,可以作为模块,下面是/var/named/fire.zone的配置。

1
2
3
4
5
6
7
8
9
10
11
12
$TTL3600
@ IN SOA fire.net.root.localhost.(;
0 ;serial
1D ;refresh
1H ;retry
1W ;expire
3H) ;minimum
@ IN NS localhost. ;@ 就是 fire.net(zone指定),寻找fire.net则向主机(NS)localhost. 发出查询
localhost. IN A 127.0.0.1 ;NS对应的IP记录

www IN A 1.1.1.1 ;这里就是真正的主机名的解析,www自动扩展成 www.fire.net
FTP IN A 2.2.2.2 ;FTP.fire.net
注意:对于/var/named下面的zone配置文件,宿主都必须是 root:named(chownroot:namedzone_file)!!!
bind的daemon主要是named
  1. bind服务器启动 /etc/init.d/named start
  2. bind服务器停止 /etc/init.d/names stop
测试
vim /etc/resolv.conf
nameserver 127.0.0.1
[root@localhost named]# nslookup
> server
Default server: 127.0.0.1
Address: 127.0.0.1#53
> localhost
Server: 127.0.0.1
Address: 127.0.0.1#53
Name: localhost
Address: 127.0.0.1
> 127.0.0.1
Server: 127.0.0.1
Address: 127.0.0.1#53
1.0.0.127.in-addr.arpa name = localhost.
> www.fire.net
Server: 127.0.0.1
Address: 127.0.0.1#53
Name: www.fire.net
Address: 1.1.1.1
> FTP.fire.net
Server: 127.0.0.1
Address: 127.0.0.1#53
Name: FTP.fire.net
Address: 2.2.2.2
以上为完整的搭建流程!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值