总结之:CentOS6.5 DNS服务BIND配置、正反向解析、主从及压力测试(1)

简介:

前言:

了解named
   如果说我们安装的rpm包不符合我们的要求怎么办、比如说我们想起用named的线程模式、比如说我想让他禁用IPv6、比如说我们想启用某种特性、而rpm在编译时没有提供、那这时我们只能去手动编译安装了,那如何去编译安装named:


   编译安装named有一个麻烦之处、所有的配置文件你都得自己去建立、像/var/named/这个目录、编译安装时连这个目录都不会存在、得自己去创建这个目录、里面的各种配置文件、区域文件、像根的、localhost的、以及localhost的反向的、都得手动去做、连我们service启动脚本都没、所以不到万不得以最好别去编译他、因为很麻烦、但对于我们学习来讲、我们应该是变得法的去折腾自己、活着就是折腾嘛、那我们各种方法都去摸索一遍、将来我们真要用得着了也好应对。

   首先上来就同步一下我们的时间:
   # hwclock -s


   然后检查一下安装环境所需要的开发包组、确保所依赖的开发包组都装有了、我这里没有装、那我就用yum来装一下吧:
   # yum -y groupinstall "Development Tools"
   # yum -y groupinstall "Server Platform Development"
   # yum grouplist

   装好后查看一下、最主要两项:Development tools和Server Platform Development

   然后我们就去下载源码包了、这里我就去www.isc.org/donloads/官方网站下载了、支持使用的版本是9.9.5、当前使用的稳定版、这个版本中已经自带dlz了、以前的版本没有自带的、安装时要装这个dlz的、如果我们将来人希望指资源记录基于数据库的方式存放的话、而且要能够现场检索、现场响应的话、则自定义启用dlz功能即可、下载好我们就去解压缩:
   # tar xf bind-9.9.5.tar.gz

   wKioL1MhkdbjXvswAAHNdY4VZXg331.jpg
   

   这里注意一下:我们要去编译安装一个服务、首先要去看他的README、然后看他的INSTALL、大体了解一下有没有我们所需要的信息、当然我们这里就不多说了、直接往下走:
   # ./configure --prefix=/usr/local/bind9 --sysconfdir=/etc/named --enable-threads --enable-epoll --disable-chroot

   --prefix=/usr/local/bind9:指定编译存放的路径
   --sysconfdir=/etc/named:指定配置文件存放路径
   --enable-threads:启用了多线程的功能

   然后make和make install就OK了、安装完成就可以去配置了
   # make && make install

   wKioL1MhkjTAg7N0AAKi8eTJhyA380.jpg
   

   我们前面说过、编译安装named什么都得自己创建、用户也没有的、所以我们得给他创建一个用户先、而且用户是系统用户、要加-r、系统用户不会给他创建家目录的:
   先创建用户组:
   # groupadd -g 53 -r named
   # useradd -g named -r named
   wKioL1MhkpTQ-ZC8AAClx2mdHcA461.jpg
   这里我们先去创建named的工作目录、然后创建named.ca这个文件:
   # mkdir /var/named

   这里@后面的IP是能访问互联网的服务器、生成的数据存在到/var/named/named.ca中去
   # dig -t NS . @172.16.0.1 > /var/named/named.ca

   wKiom1MhkpmT9-OqAAE1lwAc-8c613.jpg
   

   然后再去编辑/etc/named/named.conf的配置文件、这个文件也没有、需要自己去编写的:
   # vim /etc/named/named.conf           

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#定义全局的
         options {
                 #定义named的固定工作路径
                 directory  "/var/named" ;
         };
         #定义根的区域
         zone  "."  IN {
                 type  hint;         #类型、hint表示为根的
                 file  "named.ca" ;   #指定的文件
         };
         #定义本本地的区域
         zone  "localhost"  IN {
                 type  master;            #类型属于master、属于自己的
                 file  "named.localhost" #指定的文件
                 allow-transfer { none; };  #不允许任何人传送的
         };
         #定义反向解析的
         zone  "0.0.127.in-addr.arpa"  IN {
                 type  master;             #类型属于master、属于自己的
                 file  "named.loopback" ;     #指定的文件
                 allow-transfer { none; }; #不允许任何人传送的
         };


   配置文件中的三个文件named.ca、named.localhost、named.loopback上面已经提供有一个了named.ca了、还有这两个named.localhost、named.loopback、同样我们也得提供、也是在/var/named目录下创建:


   # vim /var/named/named.localhost

1
2
3
4
5
6
7
8
9
$TTL 86400    ;定义宏
@       IN      SOA     localhost       admin.localhost. (
                         2014031101    ;序列号
                          2H            ;刷新时间
                          10M            ;失败时重试间隔时间
                          7D            ;过期时间
                          1D)            ;否定答案的时间
                  IN      NS      localhost.
localhost.       IN      A       172.0.0.1

   

   然后复制一份改写named.loopback的文件:
   # cp /var/named/named.localhost /var/named/named.loopback
   # vim named.loopback

1
2
3
4
5
6
7
8
9
$TTL 86400
@       IN      SOA     localhost       admin.localhost. (
                          2014031101
                          2H
                          10M
                          7D
                          1D )
                  IN      NS      localhost.
1                IN      PTR     localhost.


   如果想用rndc远程登录可以生成一个/etc/named/rndc.conf的配置文件:
   # /usr/local/bind9/sbin/rndc-confgen -r /dev/urandom > /etc/named/rndc.conf 

   到这里我们别忘了给named.conf和rndc.conf修改属主属组和权限:
   # chown root:named /etc/named/named.conf
   # chown root:named /etc/named/rndc.conf
   # chown root:named /var/named/*
   # chmod 640 /etc/named/named.conf
   # chmod 640 /etc/named/rndc.conf
   # chmod 640 /var/named/*

   wKioL1MhkyywE9LIAACdXssfy94489.jpg
   wKiom1Mhk3bS9GHdAACw_6olTGQ848.jpg

   

   为了方便、我们在PATH下加个的路径、/etc/profile.d/named.sh:
   # vim /etc/profile.d/named.sh
   export PATH=/usr/local/bind9/bin:/usr/local/bind9/sbin:$PATH

   在我们的终端重新登录一下就可以生效了

   好的、检查一下我们的区域文件有没有语法错误、然后就可以启动了:
   # named-checkzone "localhost" /var/named/named.localhost 
   # named-checkzone "0.0.127.in-addr.arpa" /var/named/named.loopback
   # named -u named    #这个表示以named用户启动named
   # ss -tunl | grep "\<53\>"  然后再查看一下有没有监听53号端口

   wKioL1Mhk37wLYL7AAF9YH3B058963.jpg


   最后、因为他是一个服务、所以我们要为他提供一个服务脚本、以后可以利用脚本启动、编辑/etc/rc.d/init.d/named:

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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# vim /etc/rc.d/init.d/named
     #!/bin/bash
     #
     # description: named daemon  描述信息
     # chkconfig: - 25 88    启动和关闭级别
     #
     # 启动named的pid文件、其实文件路径我们都可以自己指定的
     pidFile= /usr/local/bind9/var/run/named .pid
     # 启动服务时的锁文件、判断一个服务是不是启动是靠这个锁文件的
     lockFile= /var/lock/subsys/named
     # named的配置文件路径
     confFile= /etc/named/named .conf
         # 判断/etc/rc.d/init.d/functions路径下的functios是否存在这个文件、存在就sources进来
         [ -r  /etc/rc .d /init .d /functions  ] && .  /etc/rc .d /init .d /functions
     # 定义启动方法
     start() {
             # 判断锁文件是否存在、如果存在就说服务已经启动并退出
             if  [ -e $lockFile ];  then
                     echo  "named is already running..."
                     exit  0
             fi
             # 打印服务已经启动的信息
             echo  -n  "Starting named:"
             # 调用functions中的daemon方法、并用--pidfile指定pid文件在什么地方、还指定用户和配置文件、我们本来是直接启用named的、现在利用daemon这个函数来启用这个服务、他会获得很多额外的属性、如果成功了会帮我们打印什么[ OK ]的、还可以做判断
             daemon --pidfile  "$pidFile"  /usr/local/bind9/sbin/named  -u named -c  "$confFile"
             RETVAL=$?
             echo
             # 判断上面的命令是否执行成功、说明启动成功
             if  [ $RETVAL - eq  0 ];  then
                     # 如果判断成功、就创建锁文件
                     touch  $lockFile
                     return  $RETVAL
             else
                     # 否则、就是失败了、那就删除锁文件和pid文件
                     rm  -f $lockFile $pidFile
                     return  1
             fi
     }
     # 定义停止方法
     stop() {
             # 如果锁文件不存在
             if  [ ! -e $lockFile ];  then
                     # 说明服务还没有启动
                     echo  "named is stopped."
             fi
             echo  -n  "Stopping named:"
             killproc named
             RETVAL=$?
             echo
             # 判断以上的命令是否执行停止成功、如果成功
             if  [ $RETVAL - eq  0 ]; then
                     # 删除锁文件和pid文件
                     rm  -f $lockFile $pidFile
                     return  0
             else
                     # 否则打印说没能正常停止
                     echo  "Cannot stop named."
                     # 调用functions中的函数、会打印失败
                     failure
                     return  1
             fi
     }
     # 定义重启服务
     restart() {
             # 调用停止方法
             stop
             # 睡眠2秒
             sleep  2
             # 调用启动方法
             start
     }
     # 定义重新加载服务方法
     reload() {
             echo  -n  "Reloading named: "
             # killprco HUP信号、named进程的信号
             killproc named -HUP
             RETVAL=$?
             echo
             return  $RETVAL
     }
     # 定义服务状态
     status() {
             if  pidof named &>  /dev/null then
                     echo  -n  "named is running..."
                     success
                     echo
             else
                     echo  -n  "named is stopped..."
                     success
                     echo
             fi
     }
     # 定义错误提示信息
     usage() {
             echo  "Usage: named {start|stop|restart|status|reload}"
     }
     case  $1  in
     start)
             start ;;
     stop)
             stop ;;
     restart)
             restart ;;
     status)
             status ;;
     reload)
             reload ;;
     *)
             usage
             exit  4 ;;
     esac


   OK、到这里保存退出,给他个执行权限
   # chmod +x /etc/rc.d/init.d/named

   再加到chkconfig里面去:
   # chkconfig --add named
   # chkconfig --list named

=============================我是分隔线==========================================  










本文转自 wei0164 51CTO博客,原文链接:http://blog.51cto.com/tanxw/1376088,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
域名解析 存储 网络协议
域名解析的终极指南:从基础到进阶,彻底搞懂 DNS 记录
域名解析是网站运行的基础,正确配置DNS记录至关重要。本文从基础到进阶全面解析DNS知识,涵盖A、AAAA、CNAME、MX、TXT、CAA等常见记录类型及其应用场景。通过学习,你将了解DNS的工作原理,掌握如何优化域名配置,确保网站与邮件服务高效运行。无论搭建个人博客还是企业官网,本文都能助你轻松搞定域名解析!
1141 0
|
6月前
|
域名解析 存储 缓存
深入学习 DNS 域名解析
在平时工作中相信大家都离不开 DNS 解析,因为 DNS 解析是互联网访问的第一步,无论是使用笔记本浏览器访问网络还是打开手机APP的时候,访问网络资源的第一步必然要经过DNS解析流程。
|
4月前
|
网络协议 安全 Linux
阿里云服务器国际站dns服务器不可用怎么办?dns可以随便改吗?
阿里云服务器国际站dns服务器不可用怎么办?dns可以随便改吗?
|
7月前
|
负载均衡 网络协议 容灾
【飞天技术沙龙】云解析 DNS 上海站《多云+IDC 融合场景下的 DNS 最佳实践》圆满落幕
【飞天技术沙龙】云解析 DNS 上海站《多云+IDC 融合场景下的 DNS 最佳实践》圆满落幕
148 0
|
10月前
|
域名解析 缓存 网络协议
浏览器中输入URL返回页面过程(超级详细)、DNS域名解析服务,TCP三次握手、四次挥手
浏览器中输入URL返回页面过程(超级详细)、DNS域名解析服务,TCP三次握手、四次挥手
|
1月前
|
存储 Ubuntu Linux
VMware-安装CentOS系统教程及安装包
虚拟机相当于是一个独立于你电脑的环境,在这个环境上面,你可以安装Linux、Windows、Ubuntu等各个类型各个版本的系统,在这个系统里面你不用担心有病读等,不用担心文件误删导致系统崩溃。 虚拟机也和正常的电脑系统是一样的,也可以开关机,不用的时候,你关机就可以了,也不会占用你的系统资源,使用起来还是比较方便 这里也有已经做好的CentOS 7系统,下载下来解压后直接用VMware打开就可以使用
459 69
|
4天前
|
存储 分布式计算 Linux
安装篇--CentOS 7 虚拟机安装
VMware 装 CentOS 7 不知道从哪下手?这篇超详细图文教程手把手教你在 VMware Workstation 中完成 CentOS 7 桌面系统的完整安装流程。从 ISO 镜像下载、虚拟机配置,到安装图形界面、设置用户密码,每一步都有截图讲解,适合零基础新手快速上手。装好之后无论你是要搭 Hadoop 集群,还是练 Linux ,这个环境都够你折腾一整天!
177 2
|
1月前
|
Ubuntu Linux 索引
Centos 7、Debian及Ubuntu系统中安装和验证tree命令的指南。
通过上述步骤,我们可以在CentOS 7、Debian和Ubuntu系统中安装并验证 `tree`命令。在命令行界面中执行安装命令,然后通过版本检查确认安装成功。这保证了在多个平台上 `tree`命令的一致性和可用性,使得用户无论在哪种Linux发行版上都能使用此工具浏览目录结构。
244 78
|
4天前
|
安全 关系型数据库 MySQL
CentOS 7 yum 安装 MySQL教程
在CentOS 7上安装MySQL 8,其实流程很清晰。首先通过官方Yum仓库来安装服务,然后启动并设为开机自启。最重要的环节是首次安全设置:需要先从日志里找到临时密码来登录,再修改成你自己的密码,并为远程连接创建用户和授权。最后,也别忘了在服务器防火墙上放行3306端口,这样远程才能连上。
146 16
|
2月前
|
Linux 网络安全 Apache
针对在Centos/Linux安装Apache过程中出现的常见问题集锦
以上每个问题的解决方案应深入分析错误日志、系统消息和各种配置文件,以找到根本原因并加以解决。务必保持系统和Apache软件包更新到最新版本,以修复已知的bugs和安全漏洞。安装和管理Web服务器是一项需要细致关注和不断学习的任务。随着技术的发展,推荐定期查看官方文档和社区论坛,以保持知识的更新。
177 80

相关产品

  • 云解析DNS
  • 推荐镜像

    更多
  • DNS