XenServer 5.6에 NAS 구성하기 > knowledge

본문 바로가기

사이트 내 전체검색

knowledge

XenServer 5.6에 NAS 구성하기

작성일 18-09-27 14:16

페이지 정보

작성자 웹지기 조회 7,546회 댓글 0건

본문

[펌] http://ifwind.tistory.com/10


XenServer의 Local Storage 중 일부를 NAS로 구성하여 리눅스 가상머신에는 NFS로 붙이고, 윈도우 가상머신에는 CFS로 붙이는 구성을 해보았다. XenServer에 NAS를 구성하면 다음과 같은 장점이 있다.

  • ISO 라이브러리를 XenServer내에 구성할 수 있다.
  • XenServer는 항상 가동중이기 때문에 VM의 상태와 관계없이 안정적인 네트워크 스토리지를 제공할 수 있다.
  • VM에서 사용하는 중요 데이터를 XenServer에 저장하고 VM은 마음대로 실습(?)할 수 있다.

참고로 본인의 XenServer 하드웨어는 다음과 같다.

  • CPU: AMD 애슬론II-X2 250(레고르)
  • MEM: DDR2 2GB
  • M/B: Asus M4A78-VM
  • HDD: 640GB 5400rpm
  • XenServer 5.6
  • IP: 192.168.0.2

작업은 다음의 순서로 진행한다.

  1. nas 용 스토리지를 할당하고 XenServer에 마운트 한다.
  2. nfs 서비스를 설정한다.
  3. samba 서비스를 설정한다.

1) nas 용 스토리지를 할당하고 XenServer에 마운트 한다.

이하 작업은 XenServer에 접속해서 수행한다.

XenServer에 nas용 마운트 포인트를 생성하고 쓰기 권한을 풀어준다.

$ mkdir /nas 
$ chmod 777 /nas

fdisk 명령으로 확인해보면 우리가 사용할 수 있는 스토리지는 Linux LVM으로 구성되었음을 확인할 수 있다.

$ fdisk -l 
Disk /dev/sda: 640.1 GB, 640135028736 bytes 
255 heads, 63 sectors/track, 77825 cylinders 
Units = cylinders of 16065 * 512 = 8225280 bytes 
Device Boot Start End Blocks Id System 
/dev/sda1 * 1 523 4194304 83 Linux 
Partition 1 does not end on cylinder boundary. 
/dev/sda2 523 1045 4194304 83 Linux 
/dev/sda3 1045 77825 616740673 8e Linux LVM

vgdisplay로 Linux LVM의 VG Name 및 가용량을 확인한다. VG Name은 이후 작업의 입력인자로 사용된다.

$ vgdisplay 
--- Volume group --- 
VG Name VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa 
System ID 
Format lvm2 
Metadata Areas 1 
Metadata Sequence No 23 
VG Access read/write 
VG Status resizable 
MAX LV 0 
Cur LV 8 
Open LV 3 
Max PV 0 
Cur PV 1 
Act PV 1 
VG Size 588.16 GB 
PE Size 4.00 MB 
Total PE 150568 
Alloc PE / Size 123961 / 484.22 GB 
Free PE / Size 26607 / 103.93 GB 
VG UUID 0yYD2Q-Aq5U-Nvgx-SUyF-2pMN-iOG1-ZkGcem

원하는 용량만큼 lv를 생성한다. lvcreate –L 용량 lv_name VG_ Name 형태로 명령어를 입력한다.

$ lvcreate -L 50GB -n nas_lv VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa

생성된 lv를 ext3로 포맷한다.

$ mkfs.ext3 /dev/VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa/nas_lv

이제 마운트 해본다.

$ mount /dev/VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa/nas_lv  /nas

부팅 후에도 자동 마운트 되도록 설정한다.

fstab을 이용하면 편할텐데, 디바이스 파일(/dev/VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa/nas_lv)이 재부팅하면 인식되지 않는 현상이 발생한다. 편법으로 자동 실행 스크립트를 만들어서 lvchange 명령으로 디바이스 파일 재생성 및 마운트하도록 구성했다.

$ vi /etc/init.d/nas_mount 
#!/bin/sh 

# chkconfig: 345 20 80 
# description: This script takes care of starting \ 
# and stopping nas_mount 

# See how we were called. 
case "$1" in 
start) 
# Start set. 
echo -n "/nas mounting... " 
lvchange -ay VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa && \ 
mount /dev/VG_XenStorage-9af52d2d-12da-425b-b7f3-acdf5eb9d4aa/nas_lv /nas 
echo "done" 
;; 
stop) 
# Stop set. 
echo "/nas umounting... " 
umount /nas 
echo "done" 
;; 
status) 
mount | grep /nas 
;; 
*) 
echo "Usage: nas_mount {start|stop|status}" 
exit 1 
;; 
esac 
exit 0

이 스크립트를 실행 가능한 파일로 변경하고 자동 실행되도록 설정한다.

$ chmod 755 /etc/init.d/nas_mount 
$ chkconfig --level 345 nas_mount on

이제 XenServer를 재부팅하여 /nas에 정상 마운트되는지 확인한다.

$ shutdown -r now 
$ df -h # 부팅 완료 후에 확인

2) NFS 서비스를 설정한다.

XenServer에 NFS 서비스를 설정하여 다른 서버에서 /nas를 마운트 할 수 있도록 한다.

먼저 호스트명이 정의되있지 않다면 hosts 파일에 정의한다. 아이피 주소 및 서버명은 본인의 것으로 사용한다.

$ vi /etc/hosts 
192.168.0.2 XenServer

/nas 디렉토리를 192.168번대 시스템에서 접근할 수 있도록 설정한다.

$ vi /etc/exports 
/nas 192.168.0.0/24(rw,no_root_squash,sync)

옵션설명

  • rw: 클라이언트에서 쓰기 가능
  • no_root_squash: 클라이언트의 root를 서버의 root로 인정 (root에게 모든 권한 부여)
  • sync: write전에 동기화, 반대는 async 
    ※ XenServer 5.6에서 nfs는 극악의 성능을 보이는데 sync를 async로 변경하면 아주 아주 빨라진다. 성능에 불만이 있다면 async를 시도해볼 만 하다. 좀 불안하긴 하겠지만...


XenServer의 portmapper 서비스는 –l 옵션이 기본으로 설정되어 있어 서비스가 제대로 작동하지 않는다. 아래 지시대로 PMAP_ARGS을 주석 처리하여 문제가 없도록 한다.

$ vi /etc/sysconfig/portmap 
#PMAP_ARGS=-l # 주석처리

NFS 설정을 적용하고 확인한다.

$ exportfs -a 
$ exportfs 
/nas 192.168.0.0/24

NFS 관련 서비스를 시작한다.

$ service nfs start 
$ service portmap start

정상 작동 중인지 확인한다. 111 포트를 사용하는 portmapper, 2049 포트를 사용하는 nfs등을 확인할 수 있다.

$ rpcinfo -p 
program vers proto port 
100000 2 tcp 111 portmapper 
100000 2 udp 111 portmapper 
100024 1 udp 600 status 
100024 1 tcp 600 status 
100021 1 udp 47834 nlockmgr 
100021 3 udp 47834 nlockmgr 
100021 4 udp 47834 nlockmgr 
100003 2 udp 2049 nfs 
100003 3 udp 2049 nfs 
100003 4 udp 2049 nfs 
100021 1 tcp 38515 nlockmgr 
100021 3 tcp 38515 nlockmgr 
100021 4 tcp 38515 nlockmgr 
100003 2 tcp 2049 nfs 
100003 3 tcp 2049 nfs 
100003 4 tcp 2049 nfs 
100005 1 udp 32767 mountd 
100005 1 tcp 32767 mountd 
100005 2 udp 32767 mountd 
100005 2 tcp 32767 mountd 
100005 3 udp 32767 mountd 
100005 3 tcp 32767 mountd

$ showmount --export 
Export list for XenServer: 
/nas 192.168.0.0/24

마지막으로 iptables의 설정을 변경하여 NFS 서비스의 포트를 개방해야 한다. 하지만 클라이언트의 portmapper 서비스가 비정규 포트를 사용하기 때문에 iptables를 적정하게 수정하는게 매우 힘들다. 여기서는 iptables 서비스를 중단하고 자동 실행되지 않도록 변경한다.

$ service iptables stop 
$ chkconfig --level 2345 iptables off

다른 서버에서 XenServer의 /nas 디렉토리를 NFS로 마운트해본다.

$ mkdir /xenserver-nas 
$ mount -t nfs 192.168.0.2:/nas /xenserver-nas

3) samba 서비스를 설정한다.

samba 서비스는 XenServer에 설치되어 있지 않다. XenServer가 인터넷에 연결되어 있다면 yum 을 이용해 설치할 수 있다. 인터넷으로 패키지를 받아올 수 있도록 CentOS-Base.repo 파일의 base 섹션 내 enable을 1로 변경한다.

$ vi /etc/yum.repos.d/CentOS-Base.repo 
[base] 
... 
enable=1

이제 yum을 이용해 samba를 설치하고 자동 실행되도록 구성한다.

$ yum install samba 
$ chkconfig --levels 345 smb on

삼바 환경파일을 백업해 놓고 적절하게 수정한다. 여기서는 /nas 디렉토리를 서비스 하도록 구성했다.

$ cp /etc/samba/smb.conf /etc/samba/smb.bak 
$ vi /etc/samba/smb.conf 
server string = NAS on XenServer 
netbios name = XenServer 
log file = /var/log/samba/%m.log 
security = user 
passdb backend = tdbsam 
load printers = no 
cups options = raw 
[nas] 
comment = nas 
path = /nas 
public = yes 
writable = yes 
printable = no

삼바 서비스를 재시작 한다.

$ service samba restart

NFS를 설정하면서 iptables를 비활성화 시켰지만 여전히 iptables를 사용코자 한다면 iptables 테이블에 samba 서비스용 포트를 허용하도록 다음 2개 라인을 추가한다.

$ vi /etc/sysconfig/iptables 
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 139 -j ACCEPT 
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 445 -j ACCEPT

윈도우에서 시작 –> 실행으로 다음 명령을 입력하여 정상 연결되는지 확인한다.

\\192.168.0.2\nas

리눅스 시스템에서는 mount 명령으로 연결해본다.

$ mount –t cifs –o user=<username>,password=<yourpass> //192.168.0.2/nas /nas
$ ls –la /nas
[이 게시물은 웹지기님에 의해 2018-10-09 11:28:48 knowledge에서 이동 됨]

추천0

비추천 0

댓글목록

등록된 댓글이 없습니다.

전체 89건 1 페이지

이미지 목록

게시물 검색
Copyright © 즐거운 코딩 생활 ( funyphp ). All rights reserved.
PC 버전으로 보기