BIND(Berkeley internet Name Daemon)也叫做NAMED,是现今互联网上使用最为广泛的DNS 服务器程序。这篇文章将要讲述如何在 chroot 监牢中运行 BIND,这样它就无法访问文件系统中除“监牢”以外的其它部分。

例如,在这篇文章中,我会将BIND的运行根目录改为 /var/named/chroot/。当然,对于BIND来说,这个目录就是 /(根目录)。 “jail”(监牢,下同)是一个软件机制,其功能是使得某个程序无法访问规定区域之外的资源,同样也为了增强安全性(LCTT 译注:chroot “监牢”,所谓“监牢”就是指通过chroot机制来更改某个进程所能看到的根目录,即将某进程限制在指定目录中,保证该进程只能对该目录及其子目录的文件进行操作,从而保证整个服务器的安全)。Bind Chroot DNS 服务器的默认“监牢”为 /var/named/chroot。

你可以按照下列步骤,在CentOS 7.0 上部署 Bind Chroot DNS 服务器。

1、安装Bind Chroot DNS 服务器

[root@centos7 ~]# yum install bind-chroot bind -y

2、拷贝bind相关文件,准备bind chroot 环境

[root@centos7 ~]# cp -R /usr/share/doc/bind-*/sample/var/named/* /var/named/chroot/var/named/

3、在bind chroot 的目录中创建相关文件

[root@centos7 ~]# touch /var/named/chroot/var/named/data/cache_dump.db

[root@centos7 ~]# touch /var/named/chroot/var/named/data/named_stats.txt

[root@centos7 ~]# touch /var/named/chroot/var/named/data/named_mem_stats.txt

[root@centos7 ~]# touch /var/named/chroot/var/named/data/named.run

[root@centos7 ~]# mkdir /var/named/chroot/var/named/dynamic

[root@centos7 ~]# touch /var/named/chroot/var/named/dynamic/managed-keys.bind

4、 将 Bind 锁定文件设置为可写

[root@centos7 ~]# chmod -R 777 /var/named/chroot/var/named/data

[root@centos7 ~]# chmod -R 777 /var/named/chroot/var/named/dynamic

5、 将 /etc/named.conf 拷贝到 bind chroot目录

[root@centos7 ~]# cp -p /etc/named.conf /var/named/chroot/etc/named.conf

6、 在/etc/named.conf中对 bind 进行配置。

在 named.conf 文件尾添加 example.local 域信息, 创建转发域(Forward Zone)与反向域(Reverse Zone)(LCTT 译注:这里example.local 并非一个真实有效的互联网域名,而是通常用于本地测试的一个域名;如果你需要做权威 DNS 解析,你可以将你拥有的域名如这里所示配置解析。):

[root@centos7 ~]# vi /var/named/chroot/etc/named.conf

-

..

..

zone "example.local" {

type master;

file "example.local.zone";

};

zone "0.168.192.in-addr.arpa" IN {

type master;

file "192.168.0.zone";

};

..

..

named.conf 完全配置如下:

//

// named.conf

//

// 由Red Hat提供,将 ISC BIND named(8) DNS服务器

// 配置为暂存域名服务器 (用来做本地DNS解析).

//

// See /usr/share/doc/bind*/sample/ for example named configuration files.

//

options {

listen-on port 53 { any; };

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 { any; };

/*

- 如果你要建立一个 授权域名服务器 服务器, 那么不要开启 recursion(递归) 功能。

- 如果你要建立一个 递归 DNS 服务器, 那么需要开启recursion 功能。

- 如果你的递归DNS服务器有公网IP地址, 你必须开启访问控制功能,

只有那些合法用户才可以发询问. 如果不这么做的话,那么你的服

服务就会受到DNS 放大攻击。实现BCP38将有效抵御这类攻击。

*/

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";

pid-file "/run/named/named.pid";

session-keyfile "/run/named/session.key";

};

logging {

channel default_debug {

file "data/named.run";

severity dynamic;

};

};

zone "." IN {

type hint;

file "named.ca";

};

zone "example.local" {

type master;

file "example.local.zone";

};

zone "0.168.192.in-addr.arpa" IN {

type master;

file "192.168.0.zone";

};

include "/etc/named.rfc1912.zones";

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

7、 为 example.local 域名创建转发域与反向域文件

a)创建转发域

[root@centos7 ~]# vi /var/named/chroot/var/named/example.local.zone

添加如下内容并保存:

;

; Addresses and other host information.

;

$TTL 86400

@ IN SOA example.local. hostmaster.example.local. (

2014101901 ; Serial

43200 ; Refresh

3600 ; Retry

3600000 ; Expire

2592000 ) ; Minimum

; Define the nameservers and the mail servers

IN NS ns1.example.local.

IN NS ns2.example.local.

IN A 192.168.0.70

IN MX 10 mx.example.local.

centos7 IN A 192.168.0.70

mx IN A 192.168.0.50

ns1 IN A 192.168.0.70

ns2 IN A 192.168.0.80

b)创建反向域

[root@centos7 ~]# vi /var/named/chroot/var/named/192.168.0.zone

-

;

; Addresses and other host information.

;

$TTL 86400

@ IN SOA example.local. hostmaster.example.local. (

2014101901 ; Serial

43200 ; Refresh

3600 ; Retry

3600000 ; Expire

2592000 ) ; Minimum

0.168.192.in-addr.arpa. IN NS centos7.example.local.

70.0.168.192.in-addr.arpa. IN PTR mx.example.local.

70.0.168.192.in-addr.arpa. IN PTR ns1.example.local.

80.0.168.192.in-addr.arpa. IN PTR ns2.example.local.。

8、开机自启动 bind-chroot 服务

[root@centos7 ~]# /usr/libexec/setup-named-chroot.sh /var/named/chroot on

[root@centos7 ~]# systemctl stop named

[root@centos7 ~]# systemctl disable named

[root@centos7 ~]# systemctl start named-chroot

[root@centos7 ~]# systemctl enable named-chroot

ln -s '/usr/lib/systemd/system/named-chroot.service' '/etc/systemd/system/multi-user.target.wants/named-chroot.service'

本文由 LCTT 原创翻译,Linux中国 荣誉推出

linux dns chroot,系统运维|在 CentOS7.0 上搭建 Chroot 的 Bind DNS 服务器相关推荐

  1. Centos7.0上搭建LAMP平台安装discuz后无法访问

    Centos7.0上搭建LAMP平台安装discuz后无法访问,出现500错误.解决方式:centos7.0上的php程序是5.4的,编译安装一个5.3版本的就可以访问了. 转载于:https://b ...

  2. linux 7 realm,系统运维|Samba 系列(十五):用 SSSD 和 Realm 集成 Ubuntu 到 Samba4 AD DC...

    本教程将告诉你如何将 Ubuntu 桌面版机器加入到带有 SSSD 和 Realm 服务的 Samba4 活动目录域中,以在活动目录中认证用户. 要求: 第 1 步:初始配置 1. 在把 Ubuntu ...

  3. linux 内存监控工具,系统运维|你值得拥有 —— 25 个 Linux 性能监控工具

    一段时间以来,我们在网上向读者介绍了如何为Linux以及类Linux操作系统配置多种不同的性能监控工具.在这篇文章中我们将罗列一系列使用最频繁的性能监控工具,并对介绍到的每一个工具提供了相应的简介链接 ...

  4. linux释放系统内存,系统运维

    /proc是个虚拟文档系统,我们能够通过对他的读写操作做为和kernel实体间进行通信的一种手段.也就是说能够通过修改/proc中的文档,来对当前kernel的行为做出调整. 那么我们能够通过调整/p ...

  5. oracle和linux面试题,系统运维面试题(AIXLINUXORACLE)试题

    注意事项: 1.共计八大类题,道小题,满分180分: 2.考试时间为3小时. 一.选择题(共10题,每题2分,共计20分) 1.下面哪个命令可以用来验证操作系统是否升级成功? A.oslevel B. ...

  6. centos linux引导修复_【Linux 运维】 Centos7.x 系统修复模式

    一.linux的运行级别: 运行级别就是来确定系统启动时到底启动那个服务. linux默认有7个运行级别: 0 关机 1 单用户模式,用于系统修复 2 不完全的命令模式,不含NFS服务 3 完全的命令 ...

  7. Linux系统运维与架构设计之Linux概述

    Linux系统运维与架构设计之Linux概述 Linux系统运维与架构设计 1.1 浅谈计算机系统 1.1.1 计算机硬件系统 现代计算机是基于冯·诺依曼体系结构,由运算器.控制器.存储器.输入设备. ...

  8. 黑马-零基础入门linux系统运维

    Day1:Linux发展史与安装 一.Linux发展史 1.Linux前身-Unix 1968年 Multics项目 MIT.Bell实验室.美国通用电气有限公司走到了一起,致力于开发Multics项 ...

  9. 很实用的Linux 系统运维常用命令及常识(超实用)

    很实用的Linux 系统运维常用命令及常识(超实用) 作为Linux运维,需要了解Linux操作系统的基本使用和管理知识,下面脚本之家小编给大家介绍下Linux运维需要掌握的命令,想成为Linux运维 ...

最新文章

  1. javascript数组查重方法总结
  2. 如何将业务系统的数据抽取汇聚到数据中台?
  3. 【Linux基础】 Redhat6.5中OpenOffice的安装
  4. linux中断处理模式,Linux在保护模式下的中断处理分析.pdf
  5. 安卓软件错误log_关于android程序的log错误信息的问题,请明白人看下吧,我是初学者,新建的android项目,一个代码都没改过...
  6. 上次那个上门要源代码的女网红,后来咋样了?
  7. 应用程序架构指导袖珍版
  8. scala中的filter函数
  9. cocos creator android之微信开放平台修改签名 baseResp.errCode=-6
  10. 从零基础入门Tensorflow2.0 ----六、31 kaggle 10 monkeys模型微调
  11. 如何实现一个文件系统
  12. kepware modbus
  13. 多款OCR免费工具,好用极了实在是太方便了
  14. 万网绑定二级域名_万网主机绑定二级域名子目录
  15. 为了看Google IO 2019大会使用的工具
  16. 花了3个小时解决了和异地女朋友一起看电影的需求(内附源码)
  17. 新浪微博since_id值
  18. 根据区的code获取省市的code代码,下面有切割数字方法
  19. bk-02 C++ vector用法 博客园
  20. python中将字符变为大写_Python实现将字符串的首字母变为大写,其余都变为小写的方法...

热门文章

  1. Linux下怎么确定Nginx安装目录
  2. Azkaban的Web Server源码探究系列20:resolvebuildFlow
  3. 分享:When.js 2.0.0 发布,Promises/A 的实现
  4. 介绍Windows Azure移动服务:用于您连接的客户端应用程序的后端
  5. ajax 调用后台的方法
  6. DWZ 在js中刷新某个navTab
  7. easyui combobox开启搜索自动完成功能
  8. Druid 配置_配置WebStatFilter
  9. Spring SetFactoryBean实例
  10. 存储过程中执行动态Sql语句