DLZ(Dynamically Loadable Zones)与传统的BIND9不同,BIND的不足之处:
* BIND从文本文件中获取数据,这样容易因为编辑错误出现问题。* BIND需要将数据加载到内存中,如果域或者记录较多,会消耗大量的内存。* BIND启动时解析Zone文件,对于一个记录较多的DNS来说,会耽误更多的时间。* 如果近修改一条记录,那么要重新加载或者重启BIND 才能生效,那么需要时间,可能会影响客户端查询。而Bind-dlz 即将帮你解决这些问题, 对Zone文件操作也更方便了,直接对数据库操作,可以很方便扩充及开发管理程序。实验所需清单:
CentOS 6.4 64位系统
bind-9.10.2.tar.gz
mysql-5.6.23.tar.gz
1.安装mysql
安装依赖包:
#yum -y install make cmake ncurses-devel bison-devel libaio-devel gcc-c++
创建mysql用户及组
#groupadd mysql
#useradd mysql -g mysql -M -s /sbin/nologin
安装mysql
#tar xf mysql-5.6.23.tar.gz
#cd mysql-5.6.23
#cmake .
#make && make install
#cd /usr/local/mysql/
#scripts/mysql_install_db --user=mysql
#chown -R :mysql .
#chown -R mysql data
#bin/mysqld_safe --user=mysql
#cp support-files/mysql.server /etc/init.d/mysql
#chkconfig --add mysql
#ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
#service mysql start
#bin/mysqladmin -u root password 'bmw12345'
#echo "/usr/local/mysql/lib" >> /etc/ld.so.conf
#ldconfig
2.配置bind
#yum -y install openssl-devel
#tar xf bind-9.10.2.tar.gz
#cd bind-9.10.2
#./configure --with-dlz-mysql --enable-largefile --enable-threads=no --prefix=/home/bind --disable-openssl-version-check
#make && make install
#useradd bind -M -s /sbin/nologin
#vim /home/bind/etc/named.conf
dlz "My zone" {
database "mysql
{host=127.0.0.1 dbname=dns ssl=false port=3306 user=root pass=bmw12345}
{select zone from dns_records where zone = '$zone$'}
{select ttl, type, mx_priority, case when lower(type)='txt' then concat('\"', data, '\"')
when lower(type) = 'soa' then concat_ws(' ', data, resp_person, serial, refresh, retry, expire, minimum)
else data end from dns_records where zone = '$zone$' and host = '$record$'}";
};
配置不再详说,网上一大把
#/home/bind/sbin/named -u bind -c /home/bind/etc/named.conf
3.数据库添加
#mysql -uroot -pbmw12345
进入数据库操作
#create database dns;
#use dns
#CREATE TABLE dns_records(id int(11) unsigned NOT NULL auto_increment,zone varchar(255) NOT NULL,host varchar(255) NOT NULL default '@',type varchar(255) NOT NULL,data text,ttl int(11) default 600,mx_priority int(11) default NULL,refresh int(11) default NULL,retry int(11) default NULL,expire int(11) default NULL,minimum int(11) default NULL,serial bigint(20) default NULL,resp_person varchar(255) default NULL,primary_ns varchar(255),PRIMARY KEY(id));
#CREATE INDEX host_index ON dns_records(host);
#CREATE INDEX type_index ON dns_records(type);
#CREATE INDEX zone_index ON dns_records(zone);
#insert into dns_records (zone,host,type,data,refresh,retry,expire,minimum,serial,resp_person,primary_ns) values('test.com','@','SOA','ns.test.com',7200,3600,86400,3600,1000,'root.test.com.','ns.test.com.');
#insert into dns_records (zone,host,type,data) values('test.com','@','NS','ns.test.com.');
#insert into dns_records (zone,host,type,data) values('test.com','ns','A','1.1.1.1');
#insert into dns_records (zone,host,type,data) values('test.com','www','A','127.0.0.1');
4.验证
dig安装:yum -y install bind-utils
#dig @127.0.0.1 www.test.com