ホームページ >運用・保守 >Nginx >Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法

Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法

王林
王林転載
2023-05-29 20:29:351034ブラウズ

一.keepalived

keepalived は、クラスターの高可用性を保証するサービス ソフトウェアです。ネットワーク内で優先度の高いノードが、vip の arp パッケージに応答する責任のあるマスターになります。この関係は、ネットワーク内の他のホストに通知し、また、優先順位を通知するためにマルチキャストの形式でネットワークに vrrp 通知を送信します。バックアップ ノードは、マスターから送信されたマルチキャスト パケットの処理のみを担当します。マスターの優先度が自身の優先度よりも高くないことが判明した場合、またはマスターからの vrrp 通知を受信しない場合、バックアップ ノードは自身をマスター ノードに切り替えます。マスター状態。

#2. 環境設定

  1. 環境: qemu-kvm、クライアント debian(9.4.0)

  2. ##仮想マシン qemu-kvm のインストール: 仮想化テクノロジ qemu-kvm の概要
  3. 1. 一時スナップショットを使用して 2 つの仮想マシンを作成します。次の操作は両方の仮想マシンで実行する必要があります。

faramita2016@linux-l9e6:~> qemu-kvm -cpu host -m 512 -hda vdisk.img -net nic -net bridge,br=br0 -snapshot -nographic

2. 仮想マシンの静的 IP を設定します

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

5. /var/www/html/index.nginx-debian.html ファイルを変更し、現在の仮想マシン IP を追加して、実際の応答サーバー

root@debian:~# vi /var/www/html/index.nginx-debian.html 
……
<h1>welcome to nginx! 10.0.0.3</h1>
……

Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法#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
  }
}

2. スタンバイ ノードの仮想マシンで、/etc/keepalived/ keepalived.conf ファイル、以下の項目を除く、その他はマスターノードと同じ

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
fi

4. サービスの確認

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)Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法
2 にバインドされています。バックアップ ノードの仮想マシンで、nginx と keepalived サービスを開始します

root@debian:~# /etc/init.d/nginx start
root@debian:~# /etc/init.d/keepalived start

バックアップ ノード ネットワーク カード ens3 Unbound vip (10.0.0.100)Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法
3 で ip a コマンドを実行し、ホスト ブラウザは http://10.0.0.100## にアクセスします。


# と 10.0.0.3 の Web ページが表示され、keepalived サービスが有効になり、vip がメイン ノード

4 にバインドされたことが示されます。メイン ノードの仮想マシンで、nginx サービスを閉じてダウンタイムをシミュレートします。Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法

root@debian:~# /etc/init.d/nginx stop


ip a コマンドを実行します。メイン ノードのネットワーク カード ens3 は vip にバインドされていません ( 10.0.0.100)

5. バックアップ ノード仮想マシンで、ipNginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法


ip a コマンドを実行し、バックアップ ノードをクエリします。ネットワーク カード ens3 は vip (10.0.0.100)

6 にバインドされています。ホスト ブラウザは http://10.0.0.100Nginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法# にアクセスします。

# 10.0.0.4 Web ページが表示され、キープアライブ サービスが有効になり、VIP がバックアップ ノードにバインドされたことが示されます。

以上がNginx+Keepalived を使用してデュアルマシンのホット バックアップを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。