一.keepalived
keepalived は、クラスターの高可用性を保証するサービス ソフトウェアです。ネットワーク内で優先度の高いノードが、vip の arp パッケージに応答する責任のあるマスターになります。この関係は、ネットワーク内の他のホストに通知し、また、優先順位を通知するためにマルチキャストの形式でネットワークに vrrp 通知を送信します。バックアップ ノードは、マスターから送信されたマルチキャスト パケットの処理のみを担当します。マスターの優先度が自身の優先度よりも高くないことが判明した場合、またはマスターからの vrrp 通知を受信しない場合、バックアップ ノードは自身をマスター ノードに切り替えます。マスター状態。
#2. 環境設定
faramita2016@linux-l9e6:~> qemu-kvm -cpu host -m 512 -hda vdisk.img -net nic -net bridge,br=br0 -snapshot -nographic
root@debian:~# cat /etc/network/interfaces # the primary network interface allow-hotplug ens3 #iface ens3 inet dhcp iface ens3 inet static address 10.0.0.3 // 设置ip netmask 255.0.0.0 gateway 10.0.0.1 hwaddress ether 52:54:00:12:34:53 // 设置mac地址
3. ネットワーク カード ip
root@debian:~# ip addr del 10.0.0.8/8 dev ens3 // 删除客户机原有ip root@debian:~# ifdown ens3 root@debian:~# ifup ens3
4. nginx と keepalived
をインストールしますroot@debian:~# apt-get install -y nginx keepalived
root@debian:~# vi /var/www/html/index.nginx-debian.html …… <h1>welcome to nginx! 10.0.0.3</h1> ……
#3. ソフトウェア構成
# プライマリ ノード仮想マシン (10.0.0.3)、バックアップ ノード仮想マシン (10.0.0.4)、仮想 IP (10.0.0.100)
1. プライマリ ノードの仮想マシンで、/etc/keepalived/keepalived.conf ファイルを編集します。root@debian:~# cat /etc/keepalived/keepalived.conf global_defs { router_id ri_1 // 标识当前keepalived节点 } vrrp_script chk_nginx { script "/root/chk_nginx.sh" // 定义监控脚本 interval 2 // 执行监控脚本的闹中间隔时间 } vrrp_instance vi_1 { state master // 设置节点为主节点,节点的初始状态 interface ens3 // 设置绑定虚拟ip的网络接口 virtual_router_id 50 // vrrp组名,指明节点同属一个组 priority 100 // 节点优先级,主节点应当高于备用节点 advert_int 1 // 组播信息发送间隔 #nopreempt // 禁止抢占服务,只对备用节点生效,主节点根据priority优先级进行抢占,不受nopreempty控制 authentication { auth_type pass // 设置认证方式 auth_pass 123456 // 密码 } virtual_ipaddress { 10.0.0.100/24 // 设置vip } track_script { // 调用监控脚本 chk_nginx } }
state backup // 设置节点为主节点,节点的初始状态 priority 10 // 节点优先级
3. 全ノードで実行、監視スクリプトの作成、/root/chk_nginx.shファイルの編集
root@debian:~# vi /root/chk_nginx.sh #!/bin/bash a=`ps -c nginx --no-header | wc -l` if [ $a -eq 0 ] then /etc/init.d/keepalived stop fi4. サービスの確認
1. マスター ノード仮想マシン、nginx および keepalived サービスの開始 root@debian:~# /etc/init.d/nginx start
root@debian:~# /etc/init.d/keepalived start
実行ip a コマンドでは、マスター ノードのネットワーク カード ens3 が vip (10.0 .0.100)
2 にバインドされています。バックアップ ノードの仮想マシンで、nginx と keepalived サービスを開始します
root@debian:~# /etc/init.d/nginx start root@debian:~# /etc/init.d/keepalived start
バックアップ ノード ネットワーク カード ens3 Unbound vip (10.0.0.100)
3 で ip a コマンドを実行し、ホスト ブラウザは http://10.0.0.100## にアクセスします。
# と 10.0.0.3 の Web ページが表示され、keepalived サービスが有効になり、vip がメイン ノード
4 にバインドされたことが示されます。メイン ノードの仮想マシンで、nginx サービスを閉じてダウンタイムをシミュレートします。
root@debian:~# /etc/init.d/nginx stop
ip a コマンドを実行します。メイン ノードのネットワーク カード ens3 は vip にバインドされていません ( 10.0.0.100)
5. バックアップ ノード仮想マシンで、ip
ip a コマンドを実行し、バックアップ ノードをクエリします。ネットワーク カード ens3 は vip (10.0.0.100)
6 にバインドされています。ホスト ブラウザは http://10.0.0.100# にアクセスします。
# 10.0.0.4 Web ページが表示され、キープアライブ サービスが有効になり、VIP がバックアップ ノードにバインドされたことが示されます。
以上がNginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。