네 중규모나 조금 큰 규모의 리눅스서버를 구성할때 가장 많이 쓴다는 CentOS 입니다
RHEL의 짝퉁판이죠 좋게 말하면 클론이구요 (합법적인 짝퉁 ^^)
조금 큰규모 서버 구성하실땐 꼭 CentOS를 쓰시더라구요
다른 배포판들도 요즘 많이 괜찮아졌는데 서버는 Redhat이라는게 이제 딱 박혔나봐요
(또 서버용으로 많이 쓰시는 건 Debian이 있죠)
그래도 레드햇계열은 방대한량의 데이터가 나와있어 참고할 것이 많다는게 젤 큰 것이려나요
솔찍히 안정적이기도 하죠 ^^
여기서 본딩을 해볼텐데요(티밍=본딩=이더채널=트렁킹 다 같습니다 OS마다 좀 다르게 부르는 것일 뿐)
제가 지금 구성해 놓은 서버에서는 이걸 할 수 가 없어서
오픈소스이면서 리눅스를 구동하는데 있어서는 VMware에 절대 뒤지지 않는 Virtualbox로 설명하겠습니다
별로 보잘것 없는 사양의 VM을 생성하고 랜카드 4개를 박았습니다
4개는 되어야 본딩 할 맛이 안 나겠습니까 ㅎㅎ
실제 서버 운용하시는 분들은 이렇게 gnome 같은 xwindow는 설치를 잘 안하실 텐데요
여기서는 편의를 위해 설치 했습니다
ifconfig를 해보면 랜카드 4개가 잘 인식되어 있군요
본딩을 시작하기전에 꼭 깔려 있어야 하는게 있습니다 바로 ethtool인데요
아마 기본적으로 설치가 되어 있을 텐데 설치가 안되어 있다면 설치해 주시구요
touch 명령어로 빈 파일들을 생성해 주셔야 합니다
생성해 주셔야 할 파일들은
음 미리 다 생성해 놓고 하셔도 되니 다 적겠습니다
#touch /etc/sysconfig/network-scripts/ifcfg-bond0
#touch /etc/sysconfig/network-scripts/ifcfg-eth0
#touch /etc/sysconfig/network-scripts/ifcfg-eth1
#touch /etc/modprobe.d/bonding.conf
요런 놈들을 만들어 주시면 되겠습니다 ifcfg-eth 는 본딩할 만큼 만들어 주시면 되겠습니다
저는 지금 센토스 깔고 바로하는거라 ifcfg-bond0이랑 bonding.conf 빼고는 전부 만들어져 있는데요
이럴경우 그냥 진행 하시면 됩니다
네 vi 나 vim으로 ifcfg-bond0 파일을 열어 다음코드를 입력합니다
DEVICE=bond0
IPADDR=○○○.○○○.○○○.○○○ /* 자신의 아이피를 넣으면됩니다 */
NETMASK=○○○.○○○.○○○.○○○ /* 넷마스크 */
GATEWAY=○○○.○○○.○○○.○○○ /* 게이트웨이 */
DNS1=○.○.○.○ /* DNS */
DNS2=○.○.○.○ /* 보조 DNS */
USERCTL=no
BOOTPROTO=none
ONBOOT=yes
NM_CONTROLLED=no
/* 고정 아이피로 안하시려면 네트워크부분 싹 지우시고 BOOTPROTO를 dhcp로 해주시면됩니다
스샷처럼요 */
USERCTL=no 옵션을 넣어 줘도 좋겠죠
원래 안에 있던 내용은 싹다 날려 버립니다
DEVICE=eth0
USERCTL=no
ONBOOT=yes
MASTER=bond0
SLAVE=yes
BOOTPROTO=none
NM_CONTROLLED=no
그리고 위에 코드를 입력합니다
네 저렇게 vi 에디터로 입력해도 되지만 너무 많아서 입력하기 귀찮더군요
텍스트에디터로 열어서 ctrl + c , ctrl + v 해줍니다
그래도 디바이스 명은 고쳐주세요
저걸 다 고쳐 주셨다면
bonding.conf를 생성합니다
(아까 생성하셨다면 패스하세요)
그리고 이것 또한 vi 에디터로 열어서 수정해줍니다
alias bond0 bonding
options bond0 mode=6 miimon=100
빨간 글씨 부분은 마음에 드는 것으로 수정하셔야 하는데 0번 ~ 6번중에 선택하시면 됩니다
0. balance-rr : (Round Robin) Load Balancing, 송신할 패킷마다 사용하는 NIC을 바꾼다.
1. active-backup: Failover, bond내에서 한개의 Slave만 사용
포트문제가 생길경우 다른 Slave가 Enable
2. balance-xor : Load Balancing, 소스와 목적지의 MAC을 XOR 연산을 통해 사용할 NIC를 결정하여 분배
3. Broadcast : Fault-Tolerance, 모든 Slave으로 데이터전송(failover), 일반적으로는 잘 사용안함.
4. 802.3ad : Dynamic Link Aggregation, IEEE 802.3ad 프로토콜을 이용하여 동적 Aggregation 작성
대역폭 상승, 부하 분산, Failover 지원
5. balance-tlb(TLB) : 적응형 송신 부하 분산, 송신패킷 로드밸런싱, 송신시 부하가 낮은 NIC이용
수신은 특정 NIC이용
6. balance-alb(ALB) : 적응형 부하 분산, 송수신패킷 로드밸런싱, 송수신시 부하가 낮은 NIC를 사용
아 그리고 그 뒤에 나온 miimon에 대해서 설명을 드리자면
mii는 네트워크 인터페이스가 살아있는지 확인하는데 쓰는데요
mii링크를 얼마나 자주 감시 할지를 설정합니다 (단위 0.001초)
기본값은 0 이고 0으로 설정시 failover는 비활성화 됩니다
그리고 이제 거의 다 되었습니다 네트워크 파일을 수정해야 되는데요
/etc/sysconfig/network 를 vi에디터로 열어
NETWORKING=yes
NETWORKING_IPV6=no
HOSTNAME=자기호스트이름
GATEWAYDEV=bond0
들을 추가해 줍니다(있는건 내버려 두세요)
modprobe bonding 명령으로 본딩 설정을 적용시키고
service network restart 네트워크 서비스를 재시작 하시면 됩니다
본딩이 완료 되었습니다 달라진게 보이시나요?
bond0 인터페이스가 Master로 있고
나머지 NIC 들이 전부 노예로ㅋ 있습니다
cat /proc/net/bonding/bond0
으로 본딩 내용과 상태를 체크하실수 있습니다
4기가비트의 대역폭을 가지게 되었네요 ㅎ
제 블로그도 잘 들어와 집니다 ㅎ
(근데 가상머신에서는 본딩하면 심각하게 느려집니다 ㅠ.ㅠ)
블로그 기본스킨이 다좋은데 색이 좀 어중간해서 CentOS 배경화면보고 영감을 받아 색을 좀 쨍 하게 했습니다 ㅎ
리눅스도 써보면 은근 매력적인 운영체제 입니다 많이 이용하세요.