> 운영 및 유지보수 > 엔진스 > Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법

Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법

王林
풀어 주다: 2023-05-29 20:29:35
앞으로
1043명이 탐색했습니다.

一.keepalived

keepalived는 클러스터의 고가용성을 보장하는 서비스 소프트웨어입니다. 네트워크에서 우선순위가 높은 노드는 VIP의 arp 패키지에 대한 응답을 담당하는 마스터로서 네트워크의 다른 호스트에게 매핑 관계를 알려줍니다. VIP와 Mac 주소 사이에 연결하고 멀티캐스트 형태로 네트워크에 vrrp 알림을 보내 우선순위를 알립니다. 백업 노드는 마스터가 보낸 멀티캐스트 패킷 처리만 담당합니다. 마스터의 우선 순위가 자신의 우선 순위보다 높지 않거나 마스터로부터 vrrp 알림을 받지 못한 경우 백업 노드는 자체적으로 마스터로 전환됩니다. 마스터 상태.

2. 환경 설정

  1. 환경: qemu-kvm, 클라이언트 debian (9.4.0)

  2. 가상 머신 qemu-kvm 설치: 가상화 기술 소개 qemu-kvm

1. 임시 스냅샷을 사용하는 두 개의 가상 머신

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를 설정하고 nginx 및 keepalived

를 활성화하세요.

root@debian:~# ip addr del 10.0.0.8/8 dev ens3  // 删除客户机原有ip
root@debian:~# ifdown ens3
root@debian:~# ifup ens3
로그인 후 복사

5. /var/www/html/index.nginx-debian.html 파일을 수정하고 현재 가상 머신 IP를 추가하여 실제 응답 서버를 표시합니다

root@debian:~# apt-get install -y nginx keepalived
로그인 후 복사

Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법

3. 소프트웨어 구성

마스터 노드 가상 머신(10.0.0.3), 대기 노드 가상 머신(10.0.0.4), 가상 IP(10.0.0.100)


1 기본 노드 가상 머신에서 /etc/keepalived/keepalived.conf 파일

을 편집합니다.
root@debian:~# vi /var/www/html/index.nginx-debian.html 
……
<h1>welcome to nginx! 10.0.0.3</h1>
……
로그인 후 복사

2. 대기 노드 가상 머신의 경우 /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
  }
}
로그인 후 복사

3와 동일합니다. 모니터링 스크립트, /root/chk_nginx.sh 파일 편집

state backup  // 设置节点为主节点,节点的初始状态
  priority 10  // 节点优先级
로그인 후 복사

4. 서비스 확인

1. 마스터 노드 가상 머신 시작, nginx 및 keepalived 서비스

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
로그인 후 복사

Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법
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
로그인 후 복사
로그인 후 복사

Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법
백업 노드 네트워크 카드를 실행합니다. ens3은 vip(10.0.0.100)

3. 호스트 브라우저가 http://10.0.0.100


Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법에 액세스하면 keepalived 서비스가 적용되었음을 나타냅니다. VIP가 마스터 노드에 바인딩되었습니다

4. 마스터 노드 가상 머신에서 nginx 서비스를 닫고 중단을 시뮬레이션합니다

root@debian:~# /etc/init.d/nginx start
root@debian:~# /etc/init.d/keepalived start
로그인 후 복사
로그인 후 복사

Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법 ip a 명령을 실행하면 메인 노드 네트워크 카드 ens3이 바인딩되지 않습니다. vip (10.0.0.100)

5. 백업 노드 가상 머신에서 ip를 쿼리합니다.


Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법 ip a 명령을 실행하면 백업 노드 네트워크 카드 ens3이 vip(10.0.0.100) 10.0.0.100에 바인딩됩니다. )

6. 호스트 브라우저가 http://10.0.0.100


Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법10.0.0.4 웹페이지에 접속하면 Keepalived 서비스가 적용되었고 VIP가 백업 노드에 바인딩되었음을 알 수 있습니다

위 내용은 Nginx+Keepalived가 이중 머신 핫 백업을 실현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿