2014년 9월 17일 수요일

DRBD(Distributed Replicated Block Device) 설치 및 설정 방법





DRBD(Distributed Replicated Block Device)는 HA(High Availability) Cluster를 구축하기위해 만들어 졌으며, 
네트워크를 통해 디스크 복제(동기화)가 가능 하도록 해주어 Raid-1(Mirroring)과 같은 환경을 구축할수 있게 도와준다.








테스트 환경
  • CentOS 6.5
  • vmware




서버 구성

  • Host Name Type IP Storage


  • nell-node1 Primary 192.168.80.110 20G (SCSI) + 20G (SCSI)


  • nell-node2 Secondary 192.168.80.111 20G (SCSI) + 20G (SCSI)


기존 /sda에 disk를 추가하여 /sdb 추가 (drbd 가상 드라이브로 사용하기 위함)






                                                                                                                         




Host name 별칭 설정 (공통) => node1, node2



/etc/hosts 파일에 서버의 별칭을 설정 한다.

[root@nell-node1 /]# vi /etc/hosts

#DRBD

192.168.80.110 nell-node1

192.168.80.111 nell-node2





                                                                                                                         

NTP 동기화 (공통) => node1, node2



서버의 날짜 및 시간이 맞지 않으면 동기화가 되지 않을수 있기 때문에 crontab을 이용하여 주기 적으로 동기화 될수 있도록 설정 한다.

[root@nell-node1 /]# vi /etc/crontab

# NTP 동기화

# 매 1분마다 동기화를 진행하므로 NTP서버를 직접 구축해서 사용하는 것을 권장 한다.

1 * * * * root ntpdate 1.kr.pool.ntp.org






                                                                                                                         




만약 disk를 추가하였다면 lvm을 사용하여 /sd"X" 추가 해야한다.



[root@nell-node1 /]# fdisk /dev/sdb

WARNING: DOS-compatible mode is deprecated. It's strongly recommended to

switch off the mode (command 'c') and change display units to

sectors (command 'u').

Command (m for help): p

Disk /dev/sdb: 21.5 GB, 21474836480 bytes

255 heads, 63 sectors/track, 2610 cylinders

Units = cylinders of 16065 * 512 = 8225280 bytes

Sector size (logical/physical): 512 bytes / 512 bytes

I/O size (minimum/optimal): 512 bytes / 512 bytes

Disk identifier: 0x1bc263a6

Device Boot Start End Blocks Id System

/dev/sdb1 1 2610 20964793+ 82 Linux swap / Solaris

Command (m for help):

Command (m for help):

Command (m for help): m

Command action

a toggle a bootable flag

b edit bsd disklabel

c toggle the dos compatibility flag

d delete a partition

l list known partition types

m print this menu

n add a new partition

o create a new empty DOS partition table

p print the partition table

q quit without saving changes

s create a new empty Sun disklabel

t change a partition's system id

u change display/entry units

v verify the partition table

w write table to disk and exit

x extra functionality (experts only)

Command (m for help):






추가 방법

                                                                                                                         

fdisk /dev/"sdb" <- 추가한 disk 또는 디바이스

"n" -> "e" -> "p" -> "1" -> "1" -> "엔터"

1은 default 를 가르킨다 혹은 내가 지정할 용량을 적어도 된다.








디바이스 확인                                                                                                                         


[root@nell-node1 /]# fdisk -l



Disk /dev/sda: 21.5 GB, 21474836480 bytes

255 heads, 63 sectors/track, 2610 cylinders

Units = cylinders of 16065 * 512 = 8225280 bytes

Sector size (logical/physical): 512 bytes / 512 bytes

I/O size (minimum/optimal): 512 bytes / 512 bytes

Disk identifier: 0x000b89b6

Device Boot Start End Blocks Id System

/dev/sda1 * 1 26 204800 83 Linux

Partition 1 does not end on cylinder boundary.

/dev/sda2 26 287 2097152 82 Linux swap / Solaris

Partition 2 does not end on cylinder boundary.

/dev/sda3 287 2611 18668544 83 Linux

Disk /dev/sdb: 21.5 GB, 21474836480 bytes

255 heads, 63 sectors/track, 2610 cylinders

Units = cylinders of 16065 * 512 = 8225280 bytes

Sector size (logical/physical): 512 bytes / 512 bytes

I/O size (minimum/optimal): 512 bytes / 512 bytes

Disk identifier: 0x1bc263a6

Device Boot Start End Blocks Id System

/dev/sdb1 1 2610 20964793+ 82 Linux swap / Solaris -> 추가된 디바이스








DRBD 설치 (공통) => node1, node2

                                                                                                                         




elrepo의 저장소를 추가 하고 설치 한다.

[root@nell-node1 /]# rpm -ivh
http://elrepo.org/elrepo-release-6-5.el6.elrepo.noarch.rpm

[root@nell-node1 /]# yum install -y kmod-drbd84 drbd84-utils




수동으로 DRBD Module을 커널에 적재 시킨다.

[root@nell-node1 /]# modprobe drbd










DRBD 설정 (공통) => node1, node2

                                                                                                                         




"drbd_disk1.res 라는 이름으로 설정 파일을 하나 생성하고 아래와 같이 사용자의 환경에 맞게 변경 하자.

[root@nell-node1 /]# vi /etc/drbd.d/drbd_disk1.res



resource drbd_disk1 {

startup {

wfc-timeout 30;

outdated-wfc-timeout 20;

degr-wfc-timeout 30;

}

net {

cram-hmac-alg sha1;

shared-secret sync_disk;

}

syncer {

rate 100M;

verify-alg sha1;

}

on nell-node1 {                                               # node의 host name 별칭

device /dev/drbd0;                                          # drbd의 논리 블록 디바이스명

disk /dev/sdb1;                                              # 실제 디스크 디바이스명

address 192.168.80.110:7789;               # port는 /etc/sysconfig/iptables에 추가

meta-disk internal;

}

on nell-node2 {

device /dev/drbd0;

disk /dev/sdb1;

address 192.168.80.111:7789;

meta-disk internal;

}

}














DRBD Meta data 생성 (공통) => node1, node2

                                                                                                                         


[root@nell-node1 /]# drbdadm create-md drdb_disk1


riting meta data...

initializing activity log

NOT initializing bitmap

New drbd meta data block successfully created.

success








간혹 아래와 같은 이유로 meta data가 생성이 안될 경우가 있다.


Device size would be truncated, which would corrupt data and result in 'access beyond end of device' errors.

You need to either

* use external meta data (recommended)

* shrink that filesystem first

* zero out the device (destroy the filesystem)

Operation refused.

Command 'drbdmeta 0 v08 /dev/sdb internal create-md' terminated with exit code 40









해결책은 디스크를 초기화 시켜 버리고 생성하면 된다.

[root@nell-node1 /]# dd if=/dev/zero of=/dev/sdb1 bs=1M











DRBD 실행 (공통) => node1, node2

                                                                                                                         



Starting DRBD resources: [

create res: drbd_disk1

prepare disk: drbd_disk1

adjust disk: drbd_disk1

adjust net: drbd_disk1

]

..........





node1 과 node2를 같이 실행해야 접속이 된다.

                                                                                                                         



간혹 아래 메세지가 나오는 경우가 있을수 있다. 아래 메세지는 동기화 하려는 서버와 연결을 맺고자 대기 타고있는데 시간을 초과하여 실행을 할수 없다는 뜻이다.

따라서, 동기화할 서버를 30초이내에 시작하면 해결된다. (대기 시간 변경은 drbd_disk.res 리소스 설정 파일에 "wfc-timeout"를 적절히 변경 하면 된다.)






DRBD's startup script waits for the peer node(s) to appear.

- In case this node was already a degraded cluster before the

reboot the timeout is 30 seconds. [degr-wfc-timeout]

- If the peer was available before the reboot the timeout will

expire after 30 seconds. [wfc-timeout]

(These values are for resource 'drbd_disk1'; 0 sec -> wait forever)

To abort waiting enter 'yes' [ 15]:









************동기화 모드 설정*************


                                                                                                                         



nell-node1 서버를 primary로 지정 하겠다.

[root@nell-node1 /]# drbdadm primary --force drbd_disk1








이후 Primary와 Secondary의 동기화가 완료 될때까지 기다리자.

[root@nell-node1 /]# drbd-overview 


0:drbd_disk1/0 SyncSource Primary/Secondary UpToDate/Inconsistent C r-----

[=================>..] sync'ed: 92.2% (800/10236)M



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




동기화가 완료 되면 이런식으로 나와야 한다.


[root@nell-node1 /]# drbd-overview

0:drbd_disk1/0 Connected Primary/Secondary UpToDate/UpToDate C r-----













DRBD Device 파일 포멧 (공통) => node1, node2


                                                                                                                         

drbd_disk1.res 에서 지정한 "/dev/drbd0"를 ext4 파일 시스템으로 포멧 한다.

[root@nell-node1 /]# mkfs.ext4 /dev/drbd0











동기화 테스트


                                                                                                                         



마운트 할 디렉토리를 생성 하고 마운트 하자.

[root@nell-node1 /]# mkdir /drbd_disk1

[root@nell-node1 /]# mount /dev/drbd0 /drbd_disk1

[root@nell-node1 /]# mount | grep drbd



/dev/drbd0 on /drbd_disk1 type ext4 (rw)




간단한 파일을 생성하여 테스트

[root@nell-node1 /]# echo "mallo" > /drbd_disk1/drbd-test.txt

[root@nell-node1 /]# ls -al /drbd_disk





total 28

drwxr-xr-x. 3 root root 4096 Sep 17 19:19 .

dr-xr-xr-x. 26 root root 4096 Sep 16 19:30 ..

-rw-r--r--. 1 root root 6 Sep 17 19:19 drbd-test.txt

drwx------. 2 root root 16384 Sep 17 18:10 lost+found








[root@nell-node1 /]# cat /drbd_disk1/drbd-test.txt


mallo



이제 Primary로 지정한 ruo91-node1에서 /dev/drbd0를 마운트 해제 하고,

Secondary로 지정된 ruo91-node2서버에서 생성한 파일이 존재 하는지 확인을 해보겠다.









nell-node1에서 마운트를 해제 하자.


                                                                                                                         



[root@nell-node1 /]# umount /dev/drbd0

초보라면 흔히 할 수 있는 실수 마운트 해제 할 디렉토리 안에서 


마운트 해제를 하면 안된다







Primary에서 Secondary로 변경 하자.


                                                                                                                         


[root@nell-node1 /]# drbdadm secondary drbd_disk1











Secondary로 변경이 되었는지 확인 하자.


                                                                                                                         


[root@nell-node1 /]# drbd-overview




0:drbd_disk1/0 Connected Secondary/Secondary UpToDate/UpToDate C r-----











nell-node2


                                                                                                                         



nell-node2에서 Secondary를 Primary 상태로 변경 한다.


[root@nell-node1 /]# drbdadm primary drbd_disk1












마운트 할 디렉토리를 생성 하고 마운트 한다.


                                                                                                                         



[root@nell-node1 /]# mkdir /drbd_disk1

[root@nell-node1 /]# mount /dev/drbd0 /drbd_disk1

[root@nell-node1 /]# mount | grep drbd



/dev/drbd0 on /drbd_disk1 type ext4 (rw)







이제 nell-node1에서 생성한 파일이 존재 하는지 확인 하자.


[root@nell-node1 /]# ls -al /drbd_disk1/






total 28

drwxr-xr-x. 3 root root 4096 Sep 17 19:19 .

dr-xr-xr-x. 26 root root 4096 Sep 16 19:30 ..

-rw-r--r--. 1 root root 6 Sep 17 19:19 drbd-test.txt

drwx------. 2 root root 16384 Sep 17 18:10 lost+found















댓글 없음: