====DNS 서버 구축 자료 ===

jgpark_bind_conf.zip

작업일지.zip

이슈발생.zip

메뉴얼.zip

즐겨찾기.txt

====bind conf 파일 설정====

[기존 YUM 으로 설치된 bind 확인]

#rpm -qa | grep bind

[root@localhost ~]# rpm -qa | grep bind

bind-libs-9.3.6-4.P1.el5_4.2

ypbind-1.19-12.el5

bind-9.3.6-4.P1.el5_4.2

bind-chroot-9.3.6-4.P1.el5_4.2

bind-utils-9.3.6-4.P1.el5_4.2


[bind rpm 삭제]

rpm -e bind-libs-9.3.6-4.P1.el5_4.2

rpm -e bind-utils-9.3.6-4.P1.el5_4.2



필요 파일 다운로드

bind

ftp://ftp.isc.org/isc/bind9/9.4.2/bind-9.4.2.tar.gz

#tar zxvf bind-9.4.2.tar.gz

1) Case1 => bind-9.6.1 이상버전 Vi로 소스수정할 필요 없다 (Centos 기준 )

2) Case2 => Vi로 소스경로를 수정해주고 컴파일 해야 장애가 나지 않는다

bind-9.4.2# vi  bin/named/include/named/globals.h (109번째쯤 줄에서 찾을것)

EXTERN const char *   ns_g_defaultpidfile        INIT(NS_LOCALSTATEDIR

                                                             "/run/named.pid");

EXTERN const char *   lwresd_g_defaultpidfile   INIT(NS_LOCALSTATEDIR

                                                            "/run/lwresd.pid");

 

******************이후**********************

EXTERN const char *   ns_g_defaultpidfile        INIT(NS_LOCALSTATEDIR

                                                             "/named.pid");

EXTERN const char *  lwresd_g_defaultpidfile     INIT(NS_LOCALSTATEDIR

                                                             "/lwresd.pid");

#yum install gcc

(install 6개 gcc(의존 cpp, glibc-devel, glibc-headers, kernel-headers, libgomp) update 3개(glibc, glibc-common, libgcc)

#yum install gcc-c++

install 1개 : gcc-c++ (의존1개 libstdc++-devel)

upbrade 1개 : libstdc++


openssl 설치

openssl-1.0.1e.tar.gz

http://www.openssl.org/source/openssl-1.0.1d.tar.gz


zlib설치

cd /usr/local/src

zlib-1.2.7.tar.gz

http://zlib.net/zlib-1.2.7.tar.gz

# tar zxf zlib-1.2.1.tar.gz

[root@localhost src]# cd zlib-1.2.1

[root@localhost zlib-1.2.1]# ./configure --shared

[root@localhost zlib-1.2.1]# make && maket install

[root@localhost zlib-1.2.1]# make clean

[root@localhost zlib-1.2.1]# echo "/usr/local/lib" >> /etc/ld.so.conf

[root@localhost zlib-1.2.1]# /sbin/ldconfig


최신 openssl 소스 얻기

www.openssl.org/source/ 에서 최신 버젼의 소스를 확인합니다. [LATEST] 가 붙어있는 소스가 최신 소스입니다.

[공지] openssl 0.9.8 버젼이 아파치에서 설치하는 부분에 SSL 라이브러리 오류가 있습니다. 한단계 낮은 버젼을 설치해 주시기 바랍니다.

3. 설정단계(./config)

openssl 소스 컴파일 설정전에 zlib 라이브러리 변수 옵션을 먼저 잡아줍니다.

export LDFLAGS=-L/usr/local/lib

export CPPFLAGS=-I/usr/local/include

최신 openssl 소스를 다운받은 후에 압축을 풀고, 풀려진 openssl 디렉토리에서 컴파일 설정을 진행합니다.

--openssldir 디렉토리를 /usr/local/openssl 과 같이 특정 디렉토리를 지정해 줍니다.

./config \

--openssldir=/usr/local/openssl \

shared \

threads \

zlib


----------------------------

tar xvfpz openssl-0.9.8g.tar.gz

cd openssl-0.9.8g

****cf : yum install perl 5

./config --prefix=/usr/local/openssl shared threads zlib

make

make install

echo "/usr/local/openssl/lib" >> /etc/ld.so.conf





-----------------------------

4. 컴파일(make)

컴파일을 진행합니다. make

5. 테스트(make test)

테스트를 진행합니다. make test

6. 설치(make install)

openssl을 설치합니다.

make install

openssl 컴파일 오브젝트들을 삭제합니다.

make clean

openssl 컴파일 옵션 변수들을 삭제합니다.

****cf : yum install perl

unset LDFLAGS

unset CPPFLAGS

7. 동적 라이브러리 적용

openssl 라이브러리들을 시스템 동적 라이브러리 설정에 추가합니다.(레드헷 기준)

echo /usr/local/openssl/lib >> /etc/ld.so.conf

/sbin/ldconfig 

- openssl-1.0.1e.tar.gz 설치 예시

[root@nark root]# cd /usr/local/src

[root@nark src]# wget http://www.openssl.org/source/openssl-1.0.1d.tar.gz

[root@nark src]# tar zxf openssl-1.0.1e.tar.gz

[root@nark src]# cd openssl-1.0.1e

[root@nark openssl-0.9.7d]# export LDFLAGS=-L/usr/local/lib

[root@nark openssl-0.9.7d]# export CPPFLAGS=-I/usr/local/include

[root@nark openssl-0.9.7d]# ./configure \

> --openssldir=/usr/local/openssl \

> shared \

> threads \

> zlib

...

[root@nark openssl-0.9.7d]# make

[root@nark openssl-0.9.7d]# make test

[root@nark openssl-0.9.7d]# make install

[root@nark openssl-0.9.7d]# make clean

[root@nark openssl-0.9.7d]# unset LDFLAGS

[root@nark openssl-0.9.7d]# unset CPPFLAGS

[root@nark openssl-0.9.7d]# echo "/usr/local/openssl/lib" >> /etc/ld.so.conf

[root@nark openssl-0.9.7d]# /sbin/ldconfig


bind 9.4.2

bind-9.4.2.tar.gz

ftp://ftp.isc.org/isc/bind9/9.4.2/bind-9.4.2.tar.gz

./configure 설정

=====================

./configure \

--prefix=/usr/local/bind \

--sysconfdir=/etc \

--localstatedir=/var \

--mandir=/usr/share/man \

--with-openssl=/usr/local/openssl \

--with-libtool \

--enable-threads \

--enable-fast-instal \

--sharedstatedir=/usr/local/server/bind/share \

==> 실행

결과==>

config.status: creating include/Makefile

config.status: creating inet/Makefile

config.status: creating irs/Makefile

config.status: creating isc/Makefile

config.status: creating nameser/Makefile

config.status: creating port_after.h

config.status: creating port_before.h

config.status: creating resolv/Makefile

config.status: creating port/Makefile

config.status: creating port/linux/Makefile

config.status: creating port/linux/include/Makefile

 

=======================







make && make install

=====================

실행==>

[root@localhost bind-9.4.2]#make

결과==>

creating named-checkzone

make[2]: Leaving directory `/usr/local/src/bind-9.4.2/bin/check'

make[1]: Leaving directory `/usr/local/src/bind-9.4.2/bin'

making all in /usr/local/src/bind-9.4.2/doc

make[1]: Entering directory `/usr/local/src/bind-9.4.2/doc'

...

making all in /usr/local/src/bind-9.4.2/doc/xsl

make[2]: Entering directory `/usr/local/src/bind-9.4.2/doc/xsl'

 

=======================

[make 후의 파일 변화 기록]

[root@localhost bind-9.4.2]# find / * > ../BIND_0

 

실행==>

[root@localhost bind-9.4.2]#make install

 

making install in /usr/local/src/bind-9.4.2/doc/arm

make[2]: Entering directory `/usr/local/src/bind-9.4.2/doc/arm'

make[2]: Leaving directory `/usr/local/src/bind-9.4.2/doc/arm'

....

make[2]: Entering directory `/usr/local/src/bind-9.4.2/doc/xsl'

make[2]: Leaving directory `/usr/local/src/bind-9.4.2/doc/xsl'

make[1]: Leaving directory `/usr/local/src/bind-9.4.2/doc'

/bin/sh ./mkinstalldirs /usr/local/bind/bin \

        /var/run /etc

/usr/bin/install -c isc-config.sh /usr/local/bind/bin

=======================

[make intall후의 파일 변화 기록]

[root@localhost bind-9.4.2]# find / * > ../BIND_1



★ 환경설정 설명

--prefix=/usr/local/server/bind

설치 디렉토리 지정으로 /usr/local/bind로 설치한다.

--bindir=/usr/local/server/bind/bin

BIND를 관리하기 위한 각종 명령어가 위치한 디렉토리로 일반적인 실행 명령어가 위치한다.

--sbindir=/usr/local/server/bind/sbin

BIND에 시스템 의존적인 명령어가 위치할 디렉토리로 일반 사용자가의 접근을 엄격히 제한한다.

--libexecdir=/usr/local/server/bind/libexec

바이너리 실행 라이브러리가 위치할 디렉토리 설정으로 /usr/local/bind/libexec 디렉토리에 설치가 된다. 단독으로 실행가능하며 또한 라이브러리로 제공될 수 있다.


--datadir=/usr/local/server/bind/share

읽기 전용의 시스템 의존적인 데이터가 위치할 디렉토리로 share 디렉토리에 위치하게 된다. /usr/local/server/bind/share로 설정한다.

--sysconfidr=/etc

환경설정 파일이 위치할 디렉토리 지정으로 가장 핵심적인 역할을 하게 되며 일반 사용자의 엄격한 제한을 설정한다.

--sharedstatedir=/usr/local/server/bind/share

변경가능하며 시스템에 의존적이지 않는 데이터가 위치할 디렉토리로 share 디렉토리에 위치하도록 설정한다.

--localstatedir=/var

서버를 운영하면서 발생할 수 있는 가변젹인 데이터가 위치하며 특히 BIND 서버에서는 각 도메인에 대한 DB 파일이 위치할 디렉토리로 사용된다.

--libdir=/usr/local/server/bind/lib

공유 라이브러리가 위치할 디렉토리로 사용된다.

--includedir=/usr/include/bind

BIND의 헤더 파일이 위치할 디렉토리 지정으로 각종 헤더 파일은 /usr/include/biond 디렉토리로 지정하여 BIND를 이용한 프로그램을 개발할 때 사용할 수 있다.

--infodir=/usr/share/info, --mandir=/usr/share/man

info, man 문서가 위치할 디렉토리로 시스템에서 제공하는 /usr/share/info, /usr/share/man 디렉토리로 설정한다.

--enable-threads

다중 스레드를 제공하고자 할 때 활성화하여 보다 효율적인 서비스를 제공할 수 있다.

--enable-static

공유 라이브러리 방식이 아닌 정적 라이브러리 방식으로 컴파일을 한다.

--enable-fast-install

빠른 설치와 함께 최적화된 설치를 활성화한다.

--disable-ipv6

기본값으로 IPV4, IPV6르 제공하게 되는데 만약 IPV6를 사용하지 않는다면 비활성화한다.

--with-openssl

서버를 관리할 때 RNDC를 사용할 계획이라면 설정하며 RNDC는 암호화된 데이터를 사용하므로써 서버의 보안을 향상실킬 수 있다. 단, openssl이 설치되어 있어야 설치할 때 에러가 발생하지 않는다.

--with-randomdev=/dev/random

난수 발생 장치를 지정하며 /dev/random으로 설정한다.

--with-libtool

컴파일을 할 때 GNU 라이브러리 툴을 사용한다.

--with-gnu-ld

링커를 GNU 링커를 사용하도록 지정한다.

--with-pic

PIC기능을 사용하도록 설정한다.


PIC, Interrrupt


PIC(Priority Interrupt Controller)

외부에서 발생한 인터럽트를 관장하는 일종의 칩으로 여러 개의 인터럽트가 동시에 발생하였을 때 인터럽트의 우선 순위를 관리하게 된다. 예를 들어 키보드와 마우스에 동시에 액션이 발생하였을 때 우선 순위를 가지고 각각 실행하게 된다.


Interrupt

시스템을 운영하면서 각종 장치 및 프로그램에서 발생하는 신호로 인터럽트가 발생하면 운영제체는 작업을 잠시 멈추고 인터럽트 신호에 귀 기울이게 된다. 예를 들어 특정한 스크립트를 실행하고 있을때 키보드로부터 “Ctrl + C" 즉 실행 취소 인터럽트가 발생한다면 즉시 하던 작업을 일단 멈추고 해당 인터럽트에 따라 작업을 진행하게 된다.


IRQ(interrupt request)

각 주변장차에 발생하는 인터럽트 신호를 구별하기 위해 미리 할당되어 있는 값을 의미한다. 하나의 채널을 이용하여 각 장치들의 신호를 구별해야하기 때문에 각각의 장치를 구별하기 위한 고유의 값으로 할당하게 된다.


환경설정 스크립트 실행

위에서 생성한 환경설정 스크립트를 실행한다. 실행도중 에러가 발생한다면 철자를 잘못입력하였거나 또는 지원되지 않는 옵션설정 또는 필요한 패키지가 설치되지 않았기 때문에 발생한다. 특히 --with-openssl을 포함하였다면 시스템에 반드시 openssl 패키지가 먼저 설치되어 있어야 한다.



/etc/named.caching-nameserver.conf파일 설정

*listen-on port 53 { 127.0.0.1 };

네임서버의 포트번호와 접근할 수 있는 IP를 설정하는 지시지

기본적으로 자신만이 53번 포트에 접속을 허용, 외부에서 접속 가능하게 하려면 { any; };


*listen-on-v6 port 53 { ::1; };

ipv6 하의 네임서버 운영을 설정하는 것으로 현재는 필요하지 않음. 기본설정 사용 또는 주석


*directory "/var/named";

DNS의 zone파일의 위치를 지정


*dump-file "/var/named/data/cache_dump.db";

캐시 덤프파일이 생성되는 파일의 절대경로 위치를 지정하는 지시자


*statistics-file "/var/named/data/named_stats.txt";

통계파일이 생성되는 절대경로와 파일이름을 지정하는 지시자


*memstatistics-file "/var/named/data/named_stats.txt";

메모리 관련 통계파일이 생성되는 절대경로와 파일이름을 지정하는 지시자


*query-source   port 53;

 query-source-v6 port 53;

네임서버의 쿼리를 받아들일 소스 포트를 설정하는 지시자. 기본으로 53번 포트의 쿼리 설정


*allow-query { localhost; };

네임서버 쿼리를 허용할 IP 혹은 IP 대역을 설정하는 지시자. 외부와의 쿼리 허용은 any;를 입력


*logging {}

네임서버 실행에 있어서 디버깅시 참고할 수 있는 로그파일생성 위치를 지정하는 지시자.


*match-clients  { localhost; };

 match-destination { localhost; };

로컬 리졸버 사용을 허용할 클라이언트를 지정하는 지시자, 외부에 허용하기 우해서는 any;를 입력


*recursion yes;

외부에서 현재의 네임서버를 지정하여 사용허용, 불가를 설정

네임서버 보안을 위한다면 no로 설정


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

네임서버 데몬 실행시 외부의 설정파일을 포함하고자 한다면 include 지시자를 이용하여 포함할 파일의 위치와 파일이름의 절대경로를 입력



*“.” : 루트도메인이라는 뜻

type hint; : hint는 루토도메인을 지정, master는 1차 네임서버 의미, slave는 2차 네임서버

*file "named.ca"; : 최상위 도메인(com, net)에 대해 관리권한을 가진 네임서버들의 정보를 가지고 있다.


*루트도메인에 대한 정의 파일은 ftp://ftp.internic.net/domain/에서 다운받을 수 있다.

업데이트를 위해 파일을 받고 /var/named/named.ca 파일로 복사하면 된다.


*zone(rev)파일 생성

******.zone파일 하나 선택후

cat *****.zone > whoishg.zone로 zone 파일 생성

$TTL 86400

@              IN SOA         ns1.whoishg.com. root.whoishg.com. (

                                                42  ;serial

                                                3H  ;refresh

                                                15M ;retry

                                                1W  ;expiry

                                                1D   ;minimum

                IN NS         ns1.whoishg.com.

                IN A           118.128.134.62

                IN MX 10      mail.whoishg.com.

www           IN A           118.128.134.57

mail            IN A           118.128.134.54

ftp             IN A           118.128.134.60

webhard       IN A           118.128.134.60

whoishg.com   IN A           118.128.134.57

www           CNAME         www1.whoishg.com

$TTL : Time To Live의 약자, 이곳에 설정한 도메인 정보를 다른 네임서버에서 읽어간 다음 그 네임서버측에서 보관할 시간 86420초는 하루

@ 는 ORIGIN을 의미하는 특수문자로 public domain 을 의미하며, 앞서 환경설정 파일에서 지정한 도메인을 의미

IN : IN다음에 나오는 설정을 사용

SOA : Start of Authority의 약자, 도메인 네임서버에 대한 모든 정보를 가지고 있다.

serial : slave와 정보갱신시 필요한 값

refresh :  슬레이브에서 마스터의 설정사항을 주기적으로 체크하는 시간

retry : 슬레이브에서 마스터로 접속할 때 접속장애시 재접속 시도시간(refresh보다 적어야지 의미가 있다)

expire : 존파일의 유효기간 설정

minimum : $TTL값과 같은 의미 다른네임서버에서 존파일데이터를 가지고 갔을때 그 데이터에 대한 유효기간 설정값










Bind 9.4.2(포함) 이상으로 업그레이드시는 named.conf  부분에 아래와 같은 설정을 추가하세요!!!

설정하지 않으면 디폴드 값이 바뀌어서 버전업그레이드후  PC에서 질의가 안됩니다.

options {

    ...

    allow-recursion { any; };

    allow-query { any; };

    allow-query-cache { any; };

    ...

};






## slave dns 구성

===================

slave dns란, slave dns는 백업역할을 수행한다. master dns 서버가 장애가 발생하여 서비스를 원활하게 해주지 못할 경우, slave dns 서버가 master dns 서버를 대신하여 도메인서비스를 해주는 것이다. 이는 서비스를 지속시킬 수 있을 뿐만 아니라 slave로 도메인서비스를 하는 동안 master dns 서버의 장애를 해결할 시간을 벌 수 있다.

whoishg.com 도메인이 서비스 되고 있는 dns 서버의 주소는 118.128.134.62이고,

slave dns 를 구성할 서버의 주소는 118.128.134.59 로 정하고 실습을 해보자.

[실습]

slave dns 구성

실습os : centos 5.5

master 서버 : 118.128.134.62

slave 서버 : 118.128.134.59

master 의 네임서버가 동작하지 못할 때, slave 네임서버가 대신 도메인서비스를 해줘야 하므로, master 가 1차 네임서버, slave가 2차 네임서버가 되는 것이다.

현재 master 서버에서 whois.com 가상의 도메인에 대한 도메인서비스가 구동되고 있는 중이다. slave dns 구성을 위해 master 서버에서 몇 가지 설정을 해보자.

[master 192.168.10.4]

1)

[root /root]#vi /etc/named.caching-nameserver.conf


options { } 안에 , 아래의 한줄을 추가하고 저장한다.

allow-transfer {118.128.134.59;}; ========>slave ip addr

이는 존파일에 대한 내용을 slave 서버로 전송해줄때, 지정한 ip주소 혹은 네트워크 대역으로 지정해줄 수 있다.

보안과 관련된 것이며, 아무 서버나 master 서버의 dns정보를 가져올 수 있는 것이 아닌 master에서 지정한 주소로만 dns정보가 전송되어질 수 있게 제한을 두는 것이다.

 (allow-transfer를 설정하지 않더라도 slave dns구성과는 무관하다)


2)

[root /root]#vi /etc/named.rfc1912.zones  -> slave dns 구성을 위해 rfc 존파일을 수정

zone "." IN {

        type hint;

        file "named.ca";

};

zone "whoishg.com" IN {

        type master;

        file "whoishg.zone";

        allow-update {118.128.134.59;};      -> slave 서버에 master dns 정보를 전송하겠다는 설정.

                                                                                { } 안에 slave 서버의 ip주소를 넣어준다.

};

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

        type master;

        file "whoishg.rev";

        allow-update {118.128.134.59;};    -> reverse 존 파일도 slave 로 전송하자.

};


참고) bind 구 버전에서는 allow-update가  allow-transfer 로 사용된다.

그러나 bind 9 버전부터는 allow-transfer 를 사용해도 무관하지만, allow-update를 사용해도 된다.

allow-update 는 dns정보를 전송할 서버의 ip주소를 적는 것 외에도 특정 키 값을 적어 다른 서버와 주고받아 보안적인 부분을 강화한 옵션이다. 그러나 특정 키 값을 사용하지 않고, 다른 서버의 ip주소만 입력해도 dns정보를 다른 서버로 전송해준다.

저장하고 나온 뒤, named 데몬을 reload 하기 전에 slave dns 구성이 잘되었는지 확인할 때를 대비하여test.co.kr 존파일에서 slave dns가 master dns 정보를 업데이트 하는 주기(refresh) 값을 짧게 미리 변경해주자.

이는 테스트를 위한 목적으로 변경하는 것이다.

[root /var/named/chroot/var/named]#vi whoishg.zone


$TTL    86400

@               IN SOA  whoishg.com. root.whoishg.com. (

                                        43              ; serial (d. adams)      ->                 존파일수정한다면 시리얼값을 반드시 이전보다큰 값으로 변경해준다.

                                        1M             ; refresh  --> 주기값을 1분                                                                으로 변경한다.

                                        15M             ; retry

                                        1W              ; expiry

                                        1D )            ; minimum

                IN NS           ns.whoishg.com    ->1차 네임서버

                IN NS          ns2.whoishg.com    -> 2차 네임서버 (slave 서버)


@       IN A            118.128.134.62

ns      IN A            118.128.134.62

www     IN A            118.128.134.**

ns2      IN  A            118.128.134.59   -> 2차 네임서버에 대한 ns2 호스트 값


저장한 뒤, reload 하자.

[root /root]#/etc/init.d/named reload

Reloading named:                                           [  OK  ]

[root /root]#

[root /root]#cat /etc/resolv.conf

nameserver 192.168.10.4             ->1차 네임서버(master)

nameserver 192.168.10.5             ->2차 네임서버(slave)



 [slave 192.168.10.5]

이제 slave 서버에서 master dns 정보를 받아오기 위한 설정을 하자.

slave 서버에도 bind 설치 및 named 데몬이 구동되어야 한다.(2차 네임서버이기 때문에)

[root@localhost ~]# rpm -qa | grep bind

bind-chroot-9.3.6-20.P1.el5_8.5

bind-utils-9.3.6-20.P1.el5_8.5

bind-9.3.6-20.P1.el5_8.5

bind-libs-9.3.6-20.P1.el5_8.5


[root@localhost ~]# /etc/init.d/named start

Starting named:                                            [  OK  ]

[root@localhost ~]#


아래와 같이 네임서버를 지정해주자.

[root@localhost ~]# cat /etc/resolv.conf

nameserver 118.128.134.62 ->1차 네임서버(master)

nameserver 118.128.134.59 ->2차 네임서버(slave)


1)

[root@localhost ~]# vi /etc/named.caching-nameserver.conf    -> named 설정파일에서 도메인서비스를 위해 아래의 설정사항에서 localhost 를 any로 변경해주자


listen-on port 53 { any; };

allow-query     { any; };

allow-query-cache { any; };

match-clients      { any; };

match-destinations { any; };

저장하고, rfc 존파일에서 dns정보를 추가하자.

master 서버에서 dns 정보를 백업받아오기 위해 slave 서버의 rfc 존파일에 설정을 해야 한다.

2)

아래와 같이 master 서버의 rfc존파일 설정과 동일하게 하되, 몇 가지 사항들을 수정해주자.

[root@localhost ~]# vi /etc/named.rfc1912.zones

zone "." IN {

        type hint;

        file "named.ca";

};

zone "test.co.kr" IN {

        type slave;                -> slave dns는 type 이 slave이다.

        file "slaves/whoishg.zone";        -> slaves/ 경로 밑에 whoishg.zone 파일로 백업을 받는다는 것이다.

     여기서 slaves디렉토리는 chroot 기능으로 인해 /var/named/chroot/var/named/ 밑에 존재 한다.

        masters {118.128.134.62;};        -> master 서버의 ip 주소를 입력하여 master로 부터 dns정보를 받아올 것을 허용한다.

};

zone "134.128.118.in-addr.arpa" IN {                    -> reverse 정보도 받아오기 위해 설정한다.

        type slave;                -> slave dns는 type 이 slave이다.

        file "slaves/whoishg.rev";

        masters {118.128.134.62;};

};


저장하고 나온 뒤, 설정사항 적용을 위해 named 데몬을 reload 시키자.


[root@localhost ~]# /etc/init.d/named reload

Reloading named:                                           [  OK  ]

[root@localhost ~]#

참고)

만약 2차네임서버인 slave 서버에서 iptables 방화벽이 사용중이라면, named 데몬에 대한 53포트를 iptables방화벽에서 열어주자.

1차네임서버인 master서버의 네임서버가 동작하지 않을 때, 2차네임서버인 slave서버가 이를 대신해 도메인서비스를 해줘야한다. 따라서 2차 네임서버가 local에서만 동작하지 않고 다른 서버에서도 동작되어 2차네임서버를 이용하여 도메인서비스를 제공할 수 있도록 slave서버의 iptables방화벽에서 udp 53번 포트를 열어주어야 한다.

[root@localhost ~]# vi /etc/sysconfig/iptables


-A RH-F     firewall-1-INPUT -m state --state NEW -m udp -p udp --dport 53 -j ACCEPT


위와같이 한 줄 추가해주면 udp 53번포트 named 데몬에 대해 방화벽에서 허용으로 설정된다.

iptables 파일 수정 후, 설정 적용을 위해 iptables 데몬 재구동을 반드시 하자.

[root@localhost ~]# /etc/init.d/iptables restart


[slave dns 구성 확인]

[slave 118.128.134.59]

[root@localhost ~]# cd /var/named/chroot/var/named/slaves/

[root@localhost slaves]# ll

total 16

-rw-r--r-- 1 named named 389 Oct 22 22:03 10.in-addr.arpa.zone

-rw-r--r-- 1 named named 358 Oct 22 22:03 test.co.kr.zone


master 서버로 부터 dns 정보를 받아와 slave서버의 slaves 디렉토리 밑에 설정한 2개의 파일이 생성 되었다.

정상적으로 slave 구성이 되었다.

이제 master 쪽에서 dns 존파일을 수정했을 때, slave 서버에서 이를 업데이트 하는지 테스트 해보자.

[slave 118.128.134.59]

백업받아온 whoishg.com 존파일의 현재 상태 확인.

[root@localhost ~]# cd /var/named/chroot/var/named/slaves/

[root@localhost slaves]# cat test.co.kr.zone

$ORIGIN .

$TTL 86400      ; 1 day

test.co.kr              IN SOA  test.co.kr. root.localhost.localdomain. (

                                2012102201 ; serial

                                60      ; refresh (1 minutes)

                                900        ; retry (15 minutes)

                                604800     ; expire (1 week)

                                86400      ; minimum (1 day)

                                )

                        NS      ns.test.co.kr.

                        NS      ns2.test.co.kr.

                         A       118.128.134.62

$ORIGIN whoishg.com.

ns2                    A       118.128.134.59

ns                      A       118.128.134.62

www                     A       118.128.134.**

[root@localhost slaves]#


[master 192.168.10.4]

master dns정보를 수정한다.

[root /root]#vi /var/named/chroot/var/named/test.co.kr.zone


[root /root]#cat /var/named/chroot/var/named/test.co.kr.zone

$TTL    86400

@               IN SOA  whoishg.com. root.whoishg.com. (

                                        43            ; serial (d. adams)        -> 시리얼값을 1 증가시켜줘야한다.(필수)

                                        1M             ; refresh                                                             15M             ; retry

                                        1W              ; expiry

                                        1D )            ; minimum

                IN NS           ns.whoishg.com.

                IN NS           ns2.whoishg.com.

@       IN A           

ns      IN A            118.128.134.62

www     IN A            118.128.134.**

ns2       IN A            118.128.134.59

cafe    IN A            118.128.134.62           ->호스트값 1개를 추가하였다.

수정 후, named reload 를 반드시 해주자.

[root /root]#/etc/init.d/named reload

Reloading named:                                           [  OK  ]


[slave 118.128.134.59]

master dns 의 업데이트 된 정보를 받아오는지 확인해보자.

[root@localhost ~]# cd /var/named/chroot/var/named/slaves/

[root@localhost slaves]# ll

구현못해봄 ㅠㅠ (실습에서는 /var/named/slaves/에 전송되어짐)


직접파일을 열어 확인해보자.

[root@localhost slaves]# cat whoishg.zone

$ORIGIN .

$TTL 86400      ; 1 day

test.co.kr              IN SOA  test.co.kr. root.localhost.localdomain. (

                                2012102202 ; serial

                                60         ; refresh (1 minute)

                                900        ; retry (15 minutes)

                                604800     ; expire (1 week)

                                86400      ; minimum (1 day)

                                )

                        NS      ns.whoishg.com.

                        NS      n2.whoishg.com.

                        A       118.128.134.62

$ORIGIN whoishg.com.

cafe                   A       118.128.134.62     -->업데이트 된 것을 확인할 수 있다.

ns2                    A        118.128.134.59          

ns                     A       118.128.134.62

www                  A       118.128.134.**


위와 같이 slave dns가 제대로 구성되었다.

또 한가지 nslookup 을 통해서 확인해보자.

[master 118.128.134.62]

[[root /root]#nslookup

> whoishg

Server:         118.128.134.62                   ->1차 네임서버에서 질의한다.

Address:        118.128.134.62#53

Name:   whoishg.com

Address: 118.128.134.62


그렇다면 master 서버의 네임서버를 stop시키고 nslookup을 통해 2차네임서버에서 whoishg를 정상 질의할 수 있는지 확인해보자.

[root /root]#/etc/init.d/named stop

Stopping named:                                            [  OK  ]


[root /root]#nslookup

> whoishg

Server:   118.128.134.62             ->1차네임서버인 master dns가 정상구동되지않는 상태에서 도메인질의시 slave서버인 2차 네임서버에서 test.co.kr도메인을 정상 질의한다.

Address:        118.128.134.59#53

Name:   whoishg.com

Address: 118.128.134.62


위와 같이 1차 네임서버가 죽은 상태에서 2차 네임서버에서 해당 도메인을 정상 질의한다.

그러면 최종적으로 slave dns 구성을 모두 마친 것이다. 정상적으로 refresh 시간 마다 master 서버의 dns 정보를slave 서버에서 업데이트를 해주고, master 서버의 네임서버가 구동되지 않을 경우에는 slave서버가 대신하여 도메인서비스를 해준다


+ Recent posts