linux集羣——負載均衡(二)

LVS DR模式搭建-準備工作

· 三臺機器

· 分發器,也叫調度器(簡寫爲dir)

133.130

· rs1

133.132

· rs2

133.133

· vip

133.200

DR模式搭建

· vim /usr/local/sbin/lvs_dr.sh dir上編寫腳本,內容如下:

#! /bin/bash

echo 1 > /proc/sys/net/ipv4/ip_forward  打開端口轉發

ipv=/usr/sbin/ipvsadm              

vip=192.168.133.200

rs1=192.168.133.132

rs2=192.168.133.133

#注意這裏的網卡名字

ifdown ens33

ifup ens33   (這裏相當於ens33重啓)

ifconfig ens33:2 $vip broadcast $vip netmask 255.255.255.255 up    ifconfig設置虛擬網卡

route add -host $vip dev ens33:2

$ipv -C

$ipv -A -t $vip:80 -s wrr

$ipv -a -t $vip:80 -r $rs1:80 -g -w 1

$ipv -a -t $vip:80 -r $rs2:80 -g -w 1

sh /usr/local/sbin/lvs_dr.sh 執行腳本

· vim /usr/local/sbin/lvs_rs.sh 兩臺rs上也編寫腳本內容如下

#/bin/bash

vip=192.168.133.200

#把vip綁定在lo上,是爲了實現rs直接把結果返回給客戶端

ifdown lo

ifup lo

ifconfig lo:0 $vip broadcast $vip netmask 255.255.255.255 up

route add -host $vip lo:0

#以下操作爲更改arp內核參數,目的是爲了讓rs順利發送mac地址給客戶端

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

分別在dir上和兩個rs上執行這些腳本

測試瀏覽器訪問19.168.133.200
18.12 keepalived+LVS

keepalived+LVS DR

· 完整架構需要兩臺服務器(角色爲dir)分別安裝keepalived軟件,目的是實現高可用,但keepalived本身也有負載均衡的功能,所以本次實驗可以只安裝一臺keepalived

· keepalived內置了ipvsadm的功能,所以不需要再安裝ipvsadm包,也不用編寫和執行那個lvs_dir的腳本

·三臺機器分別爲:

dir(安裝keepalived)133.130

rs1 133.132

rs2 133.133

vip 133.200

· vim /etc/keepalived/keepalived.conf 編輯keepalived配置文件 //內容請到

https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/lvs_keepalived.conf 獲取

vrrp_instance VI_1 {

#備用服務器上爲 BACKUP

state MASTER

#綁定vip的網卡爲ens33,你的網卡和阿銘的可能不一樣,這裏需要你改一下

interface ens33

virtual_router_id 51

#備用服務器上爲90

priority 100

advert_int 1

authentication {

    auth_type PASS

    auth_pass aminglinux

}

virtual_ipaddress {

    192.168.133.200

}

}

virtual_server 192.168.133.200 80 {

#(每隔10秒查詢realserver狀態)

delay_loop 10

#(lvs 算法)

lb_algo wlc

#(DR模式)

lb_kind DR

#(同一IP的連接60秒內被分配到同一臺realserver)

persistence_timeout 60

#(用TCP協議檢查realserver狀態)

protocol TCP



real_server 192.168.133.130 80 {

    #(權重)

    weight 100

    TCP_CHECK {

    #(10秒無響應超時)

    connect_timeout 10

    nb_get_retry 3

    delay_before_retry 3

    connect_port 80

    }

}

real_server 192.168.133.132 80 {

    weight 100

    TCP_CHECK {

    connect_timeout 10

    nb_get_retry 3

    delay_before_retry 3

    connect_port 80

    }

 }

}

需要更改裏面的ip信息

systemctl strat keepalived 啓動keepalived

· ipvsadm -C 把之前的ipvsadm規則清空掉

·systemctl restart network 可以把之前的vip清空掉

·兩臺rs上,依然要執行/usr/local/sbin/lvs_rs.sh腳本

· keepalived有一個比較好的功能,可以在一臺rs宕機時,不再把請求轉發過去

ipvsadm -ln 查看機器狀態

測試瀏覽器訪問192.168.133.200

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章