发布时间:2014-09-05 15:41:00作者:知识屋
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
//named.conf
options { //通用配置
listen-on port 53 { 127.0.0.1; };
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";
allow-query { localhost; };
recursion yes;
dnssec-enable yes;
dnssec-validation yes;
dnssec-lookaside auto;
/* 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
$TTL 3600
@ 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
$TTL 600
@ 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
$TTL 3600
@ 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 (chown root:namedzone_file)!!!
bind的daemon主要是named
bind服务器启动 /etc/init.d/named start
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
以上为完整的搭建流程!
linux一键安装web环境全攻略 在linux系统中怎么一键安装web环境方法
Linux网络基本网络配置方法介绍 如何配置Linux系统的网络方法
Linux下DNS服务器搭建详解 Linux下搭建DNS服务器和配置文件
对Linux进行详细的性能监控的方法 Linux 系统性能监控命令详解
linux系统root密码忘了怎么办 linux忘记root密码后找回密码的方法
Linux基本命令有哪些 Linux系统常用操作命令有哪些
Linux必学的网络操作命令 linux网络操作相关命令汇总
linux系统从入侵到提权的详细过程 linux入侵提权服务器方法技巧
linux系统怎么用命令切换用户登录 Linux切换用户的命令是什么
在linux中添加普通新用户登录 如何在Linux中添加一个新的用户
2012-07-10
CentOS 6.3安装(详细图解教程)
Linux怎么查看网卡驱动?Linux下查看网卡的驱动程序
centos修改主机名命令
Ubuntu或UbuntuKyKin14.04Unity桌面风格与Gnome桌面风格的切换
FEDORA 17中设置TIGERVNC远程访问
StartOS 5.0相关介绍,新型的Linux系统!
解决vSphere Client登录linux版vCenter失败
LINUX最新提权 Exploits Linux Kernel <= 2.6.37
nginx在网站中的7层转发功能