linux 下使用mydns

环境:

  Centos 5.4

  使用软件:

  wget http://mydns.bboy.net/download/mydns-1.1.0.tar.gz

  wget http://soft.vpser.net/datebase/mysql/mysql-5.1.54.tar.gz

  安装前准备:

  yum -y install gcc gcc-c++ gcc-g77 flex bison file libtool libtool-libs autoconf kernel-devel libjpeg libjpeg-devel libpng libpng-devel libpng10 libpng10-devel gd gd-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glib2 glib2-devel bzip2 bzip2-devel libevent libevent-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel vim-minimal nano fonts-chinese gettext gettext-devel ncurses-devel gmp-devel pspell-devel unzip

  一、安装mysql数据库

  tar zxvf mysql-5.1.54.tar.gz

  cd mysql-5.1.54

  ./configure  --prefix=/usr/local/mysql --with-extra-charsets=all --enable-thread-safe-client --enable-assembler --with-charset=utf8 --with-extra-charsets=all --with-

  big-tables --with-readline --with-ssl --with-embedded-server --enable-thread-safe-client --enable-local-infileser

  make

  make install

  groupadd mysql

  useradd -s /sbin/nologin  -M -g mysql mysql

  cp /usr/local/mysql/share/mysql/my-medium.cnf /etc/my.cnf

  sed -i 's/skip-locking/skip-external-locking/g' /etc/my.cnf

  /usr/local/mysql/bin/mysql_install_db --user=mysql

  chown -R mysql /usr/local/mysql/var

  chgrp -R mysql /usr/local/mysql/.

  cp /usr/local/mysql/share/mysql/mysql.server /etc/init.d/mysql

  chmod 755 /etc/init.d/mysql

  vim /etc/ld.so.conf.d/mysql.conf添加如下:

  /usr/local/mysql/lib/mysql

  /usr/local/lib

  ldconfig

  ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql

  ln -s /usr/local/mysql/include/mysql /usr/include/mysql

  /etc/init.d/mysql start

  ln -s /usr/local/mysql/bin/mysql /usr/bin/mysql

  ln -s /usr/local/mysql/bin/mysqldump /usr/bin/mysqldump

  ln -s /usr/local/mysql/bin/myisamchk /usr/bin/myisamchk

  /usr/local/mysql/bin/mysqladmin -u root password  123456  设置密码

  二、安装mydns:

  tar zxvf mydns-1.1.0.tar.gz

  ./configure  --prefix=/usr/local/mydns --with-mysql-lib=/usr/local/mysql/lib/mysql/ --with-mysql-include=/usr/local/mysql/include/mysql/

  make && make install

  /usr/local/mysql/bin/mysqladmin  -uroot -p create mydns  创建dns数据库

  mysql>insert into mysql.user (host,user,password) values ('localhost','mydns',password('mydns'));     //建立用户mydns,密码mydns

  mysq>flush privileges;    //重载MySQL授权表

  mysql>grant all on mydns.* to mydns@'localhost' identified by 'mydns'; 把数据mydns授权于用户mydns

  生成主配置文件:

  /usr/local/mydns/sbin/mydns  --dump-config > /etc/mydns.conf

  三、配置mydns:

  修改mydns.conf如下:

  # DATABASE INFORMATION

  db-host = localhost             # SQL server hostname

  db-user = mydns                 # SQL server username

  db-password = mydns             # SQL server password

  database = mydns                # MyDNS database name

  # GENERAL OPTIONS

  user = mydns                    # Run with the permissions of this user

  group = mydns                   # Run with the permissions of this group

  listen = 172.16.6.200                   # Listen on these addresses ('*' for all)

  no-listen =                     # Do not listen on these addresses

  # CACHE OPTIONS

  zone-cache-size = 1024          # Maximum number of elements stored in the zone cache

  zone-cache-expire = 60          # Number of seconds after which cached zones expires

  reply-cache-size = 1024         # Maximum number of elements stored in the reply cache

  reply-cache-expire = 30         # Number of seconds after which cached replies expire

  # ESOTERICA

  log = LOG_DAEMON                # Facility to use for program output (LOG_*/stdout/stderr)

  pidfile = /var/run/mydns.pid    # Path to PID file

  timeout = 120                   # Number of seconds after which queries time out

  multicpu = 1                    # Number of CPUs installed on your system

  recursive = 8.8.8.8             # Location of recursive resolver把解析不了的转发到8.8.8

  recursive-timeout =             # Number of seconds before first retry

  recursive-retries =             # Number of retries before abandoning recursion

  recursive-algorithm =           # Recursion retry algorithm one of: linear, exponential, progressive

  allow-axfr = yes                # Should AXFR be enabled?

  allow-tcp = yes                 # Should TCP be enabled?

  allow-update = no               # Should DNS UPDATE be enabled?

  ignore-minimum = no             # Ignore minimum TTL for zone?

  soa-table = soa                 # Name of table containing SOA records

  rr-table = rr                   # Name of table containing RR data

  soa-where =                     # Extra WHERE clause for SOA queries

  rr-where =  # Extra WHERE clause for RR queries

  /usr/local/mydns/sbin/mydns  --background  放入后台运行mydns

  /usr/local/mydns/sbin/mydns  reload  重新加载配置文件

  /usr/local/mydns/sbin/mydns restart 重新启动mydns

  四、测试添加相应记录:

  use mydns;

  CREATE TABLE soa (

  id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,

  origin CHAR(255) NOT NULL,

  ns CHAR(255) NOT NULL,

  mbox CHAR(255) NOT NULL,

  serial INT UNSIGNED NOT NULL DEFAULT '20110601',

  refresh INT UNSIGNED NOT NULL DEFAULT '1800',

  retry INT UNSIGNED NOT NULL DEFAULT '7200',

  expire INT UNSIGNED NOT NULL DEFAULT '604800',

  minimum INT UNSIGNED NOT NULL DEFAULT '300',

  ttl INT UNSIGNED NOT NULL DEFAULT '1800'

  ) TYPE=MyISAM;   创建soa表

  CREATE TABLE rr (

  id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,

  zone INT UNSIGNED NOT NULL,

  name CHAR(64) NOT NULL,

  type ENUM('A','AAAA','CNAME','HINFO','MX','NS','PTR','RP','SRV','TXT') NOT NULL,

  data CHAR(128) NOT NULL,

  aux INT UNSIGNED NOT NULL,

  ttl INT UNSIGNED NOT NULL DEFAULT '36000'

  ) TYPE=MyISAM;  创建rr表

  添加数据:

  insert into soa values (1,'crazylinux.cn.','ns.crazylinux.cn.','root.crazylinux.cn.',2011060114,1800,7200,604800,360,1800);

  insert into rr values (1,1,'www','A','172.16.6.202',0,360);添加条A记录www.crazylinux.cn解析到172.16.6.202

  insert into rr values (2,1,'so','CNAME','so.crazylinux.cn.test.com.',0,360);添加条cname记录so.crazylinux.cn解析到so.crazylinux.cn.test.com.

  mysql> select * from rr;

  +----+------+------+-------+----------------------------+-----+-----+

  | id | zone | name | type  | data                       | aux | ttl |

  +----+------+------+-------+----------------------------+-----+-----+

  |  1 |    1 | www  | A     | 172.16.6.202               |   0 | 360 |

  |  2 |    1 | so   | CNAME | so.crazylinux.cn.test.com. |   0 | 360 |

  +----+------+------+-------+----------------------------+-----+-----+

  2 rows in set (0.00 sec)

  测试:

  [root@localhost ~]# dig  @172.16.6.200 www.crazylinux.cn

  ; <<>> DiG 9.3.4-P1 <<>> @172.16.6.200 www.crazylinux.cn

  ; (1 server found)<

linux 下使用powerdns

安装MySQL

yum -y install mysql mysql-server  设置mysql开机自启并启动mysql  

chkconfig --levels 235 mysqld on  /etc/init.d/mysqld start  修改mysql root密码:

mysqladmin -u root password yourrootsqlpassword  安装Powerdns

yum -y install pdns pdns-backend-mysql  连接mysql:  

mysql -u root -p  创建powerdns数据库:  

CREATE DATABASE powerdns;  

为Powerdns创建powerdns数据库用户:  

GRANT ALL ON powerdns.* TO

'power_admin'@'localhost'

IDENTIFIED

BY

'power_admin_password';  

FLUSH PRIVILEGES;  

请替换power_admin_password成自己的密码。 现在创建数据表:  

USE powerdns;  

CREATE TABLE domains (  

id INT auto_increment,  

name VARCHAR(255) NOT NULL,  

master VARCHAR(128) DEFAULT NULL,  last_check INT DEFAULT NULL,  type VARCHAR(6) NOT NULL,  notified_serial INT DEFAULT NULL,  account VARCHAR(40) DEFAULT NULL,  primary key (id)  );  

CREATE UNIQUE INDEX name_index ON domains(name);  CREATE TABLE records (  id INT auto_increment,  

domain_id INT DEFAULT NULL,  

name VARCHAR(255) DEFAULT NULL,  type VARCHAR(6) DEFAULT NULL,  

content VARCHAR(255) DEFAULT NULL,  ttl INT DEFAULT NULL,  

prio INT DEFAULT NULL,  

change_date INT DEFAULT NULL,  primary key(id)  );  

CREATE INDEX rec_name_index ON records(name);  CREATE INDEX nametype_index ON records(name,type);  CREATE INDEX domain_id ON records(domain_id);  CREATE TABLE supermasters (  ip VARCHAR(25) NOT NULL,  

nameserver VARCHAR(255) NOT NULL,  account VARCHAR(40) DEFAULT NULL  );  

最后退出mysql shell:  

quit;  

现在配置Powerdns以使用mysql后端:  

vi /etc/pdns/pdns.conf  增加如下内容到pdns.conf  [...]  

#################################  

# launch        Which backends to launch and order to query them in  #  

# launch=  

launch=gmysql  

gmysql-host=127.0.0.1  

gmysql-user=power_admin  

gmysql-password=power_admin_password  gmysql-dbname=powerdns  

[...]  

设置Powerdns自启动并立即启动Powerdns。  

chkconfig --levels 235 pdns on  

/etc/init.d/pdns start  

现在Powerdns已经正常运行,下面我们为Powerdns安装Poweradmin实现web管理。  

安装Poweradmin

Poweradmin运行在PHP环境中,我们现在配置web环境。

yum -y install httpd php php-devel php-gd php-imap php-ldap php-mysql php-odbc php-pear php-xml php-xmlrpc php-mbstring php-mcrypt php-mhash gettext  设置apache自启动,并启动APACHE。  

chkconfig --levels 235 httpd on  

/etc/init.d/httpd start  

Poweradmin还需要安装两个PEAR软件包。  

yum install php-pear-DB php-pear-MDB2-Driver-mysql  

现在Poweradmin所需的环境已经配置完成,我们将把Poweradmin安装在目录/var/www/html,这是APACHE默认的文档根目录。

到https://www.poweradmin.org/trac/wiki/GettingPoweradmin找到最新的版本下载:  cd /tmp  

wget https://www.poweradmin.org/download/poweradmin-2.1.5.tgz  然后安装在/var/www/html/poweradmin目录。  

tar xvfz poweradmin-2.1.5.tgz  

mv poweradmin-2.1.5 /var/www/html/poweradmin  touch /var/www/html/poweradmin/inc/config.inc.php  

chown -R APACHE:APACHE /var/www/html/poweradmin/  

现在打开浏览器运行安装程序(如:http://www.centos.bz/poweradmin/install或http://192.168.0.100/poweradmin/install)。 1、选择语言为英文,并点击Go to step 2  

2、点击“Go to step 3”到安装的第三步,填入数据库详细信息。输入root用户和密码,和输入Poweradmin的admin用户的密码。  

3、点击下一步,填入在安装powerdns那一步所创建的power_admin mysql用户的信息,并且填入域名服务器地址:  

4、下一步是需要执行mysql语句,我们不需要执行了,因为前面我们已经执行过了,直接点击下一步即可。  

5、继续点击下一步。  

6、现在poweradmin安装完成。  

7、为了安全,需要删除安装目录。  

rm -fr /var/www/html/poweradmin/install/  

现在你可以进入