LVS+Keepalivedを利用して、高機能で利用可能な負荷バランスサーバを実現します。
作者:NetSeekhttp://www.linuxtone.org(IT運営・維持専門家網|クラスタ構造124;性能の調整)転載を歓迎します。転載する時は必ずハイパーリンク形式で文章の原本の出所と作者の情報と本声明を明示してください。更新時間:2008-10-27背景: あなたのウェブサイトの業務量が増えるにつれて、サーバーの圧力はますます大きくなりますか?負荷バランスが必要!ビジネスのハードウエアはF 5のように高すぎます。あなた達は創業型のインターネット会社です。どうやってコストを効果的に節約し、不必要な浪費を節約しますか?ビジネスハードウェアのような高機能で利用可能な機能を同時に実現しますか?どのような良い負荷バランスが拡張できるプランがありますか?答えは肯定です。ありますLVS+Keepalivedを利用して、完全なオープンソースソフトウェアに基づくアーキテクチャを構築します。負荷の均衡と高い利用可能なサーバーを提供します。LVS+Keepalived紹介LVSL VSはLinux Virtual Serverの略記であり、つまりLinux仮想サーバであり、仮想サーバクラスタシステムである。このプロジェクトは1998年5月に章文嵩博士によって設立されました。中国国内で最初に出現したフリーソフトウェアプロジェクトの一つです。現在3つのIP負荷バランス技術(VS/NAT、VS/TUN、VS/DR)があります。10種類のスケジューリングアルゴリズム(rrr_wrr_lc_124 lblc_lblc_124)。Keepalvied Keepalivedはここで主にRealServerの健康状態検査とLoadBalanceホストとBackUPホストとの間のfailoverの実現二として使われています。ウェブサイトの負荷バランスの取れた拓朴図です。
snslb.jpg
IP情報リスト:名前 IP
コード:
コード:
コード:
コード:
コード:
コード:
コード:
コード:
snslb.jpg
IP情報リスト:名前 IP
コード:
LVS-DR-Master 61.164.122.6
LVS-DR-BACKUP 61.164.122.7
LVS-DR-VIP 61.164.122.8
WEB1-Realserver 61.164.122.9
WEB2-Realserver 61.164.122.10
GateWay 61.164.122.1
3.LVSとKeepalviedのパッケージをインストールする 1.関連パッケージのダウンロードコード:
#mkdir /usr/local/src/lvs
#cd /usr/local/src/lvs
#wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.24.tar.gz
#wget http://www.keepalived.org/software/keepalived-1.1.15.tar.gz
2.LVSとKeepalivedをインストールするコード:
#lsmod |grep ip_vs
#uname -r
2.6.18-53.el5PAE
#ln -s /usr/src/kernels/2.6.18-53.el5PAE-i686/ /usr/src/linux
#tar zxvf ipvsadm-1.24.tar.gz
#cd ipvsadm-1.24
#make && make install
#find / -name ipvsadm # ipvsadm
#tar zxvf keepalived-1.1.15.tar.gz
#cd keepalived-1.1.15
#./configure && make && make install
#find / -name keepalived # keepalived
#cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
#cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
#mkdir /etc/keepalived
#cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
#cp /usr/local/sbin/keepalived /usr/sbin/
#service keepalived start|stop # .
4.LVSを構成し、負荷の均衡を実現する。 1.LVS-DRは、LVSスクリプトを配置して負荷バランスを実現します。このスクリプトはプレゼンテーションでlvsを理解しやすくし、keepalivedプロジェクトではこのスクリプトを起動しないようにします。LVSのkeepalviedのHA案について、完全にkeepalived.com nfの1つのファイルから解決して、ここで声明します。コード:
#vi /usr/local/sbin/lvs-dr.sh
#!/bin/bash
# description: start LVS of DirectorServer
#Written by :NetSeek http://www.linuxtone.org
GW=61.164.122.1
# website director vip.
SNS_VIP=61.164.122.8
SNS_RIP1=61.164.122.9
SNS_RIP2=61.164.122.10
./etc/rc.d/init.d/functions
logger $0 called with $1
case "$1" in
start)
# set squid vip
/sbin/ipvsadm --set 30 5 60
/sbin/ifconfig eth0:0 $SNS_VIP broadcast $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP up
/sbin/route add -host $SNS_VIP dev eth0:0
/sbin/ipvsadm -A -t $SNS_VIP:80 -s wrr -p 3
/sbin/ipvsadm -a -t $SNS_VIP:80 -r $SNS_RIP1:80 -g -w 1
/sbin/ipvsadm -a -t $SNS_VIP:80 -r $SNS_RIP2:80 -g -w 1
touch /var/lock/subsys/ipvsadm >/dev/null 2>&1
;;
stop)
/sbin/ipvsadm -C
/sbin/ipvsadm -Z
ifconfig eth0:0 down
route del $SNS_VIP
rm -rf /var/lock/subsys/ipvsadm >/dev/null 2>&1
echo "ipvsadm stoped"
;;
status)
if [ ! -e /var/lock/subsys/ipvsadm ];then
echo "ipvsadm stoped"
exit 1
else
echo "ipvsadm OK"
fi
;;
*)
echo "Usage: $0 {start|stop|status}"
exit 1
esac
exit 0
.Realserverスクリプトを設定します。コード:
#vi /usr/local/sbin/realserver.sh
#!/bin/bash
# description: Config realserver lo and apply noarp
#Written by :NetSeek http://www.linuxtone.org
SNS_VIP=61.164.122.8
. /etc/rc.d/init.d/functions
case "$1" in
start)
ifconfig lo:0 $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP
/sbin/route add -host $SNS_VIP dev lo:0
echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
sysctl -p >/dev/null 2>&1
echo "RealServer Start OK"
;;
stop)
ifconfig lo:0 down
route del $SNS_VIP >/dev/null 2>&1
echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
echo "RealServer Stoped"
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac
exit 0
またはsecondary ip address方式で構成されています。 # vi/etc/syssctl.com nfコード:
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
[code]
#sysctl –p
#ip addr add 61.164.122.8/32 dev lo
#ip add list
3. lvs-dr realserver , DR LVS :
#watch ipvsadm –ln
5.Keepalviedを利用して負荷の均衡と高い利用可能性を実現する。 1.主負荷均衡サーバに配置し、keepalived.com nfを配置する。 #vi/etc/keepalived/keepalived.com nfコード:
! Configuration File for keepalived
global_defs {
notification_email {
[email protected]
}
notification_email_from [email protected]
smtp_server 127.0.0.1
# smtp_connect_timeout 30
router_id LVS_DEVEL
}
# 20081013 written by :netseek
# VIP1
vrrp_instance VI_1 {
state MASTER # MASTER BACKUP
interface eth0
virtual_router_id 51
priority 100 # 100 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
61.164.122.8
#( VIP, .)
}
}
virtual_server 61.164.122.8 80 {
delay_loop 6 #( 10 realserver )
lb_algo wrr #(lvs )
lb_kind DR #(Direct Route)
persistence_timeout 60 #( IP 60 realserver)
protocol TCP #( TCP realserver )
real_server 61.164.122.9 80 {
weight 3 #( )
TCP_CHECK {
connect_timeout 10 #(10 )
nb_get_retry 3
delay_before_retry 3
connect_port 80
}
}
real_server 61.164.122.10 80 {
weight 3
TCP_CHECK {
connect_timeout 10
nb_get_retry 3
delay_before_retry 3
connect_port 80
}
}
}
2.BACKUPサーバと同じ配置で、先にlvsをインストールしてからkeepalivedをインストールし、その後も配置/etc/keepalived/keepalived/keepalived.com nfを配置し、赤い表記の部分を変更すればいいです。3.lvs_を停止します。dr.shプレゼンテーションスクリプト vi/etc/rc.local #/usr/local/sbin/lvs-dr.sh lvs-dr.shというスクリプトをコメントしてください。 #/usr/local/sbin/lvs-dr.sh stop停止lvs-drスクリプト #/etc/init.d/keepalived start keepalivedサービスを起動して、keepalivedはkeepalived.co.nfプロファイルを利用して、負荷の均衡と高い利用を実現できます。 LVS全体の負の均衡HA方案は、keepalived.co.nfの一つのファイルで解決できます。4.lvsサービスが正常かどうかを確認する。 #watch ipvsadm–lnコード:
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddressort Scheduler Flags
-> RemoteAddressort Forward Weight ActiveConn InActConn
TCP 61.164.122.8:80 wrr persistent 60
-> 61.164.122.10:80 Route 3 0 0
-> 61.164.122.9:80 Route 3 0 0
菶tail–f/var/log/message ログをモニターし、状態を確認し、LVS負荷のバランスと高いユーザビリティが有効かどうかをテストします。5.マスターサーバのkeepalivedサービスを停止し、BAKCUPサーバーが正常にサービスを受けられているかを確認します。四.関連参考 1.LVS基礎知識まとめLVSのアルゴリズム紹介 http://www.linuxtone.org/viewthread.php?tid=69学習LVSの3つの転送モード http://www.linuxtone.org/viewthread.php?tid=77LVSのIP負荷バランス技術 http://www.linuxtone.org/viewthread.php?tid=68もっと多いのはどうぞhttp://www.linuxtone.org 負荷均衡版はKeepalived関連参考資料を調べます。 http://www.keepalived.org/documentation.html