Rumah  >  Artikel  >  Operasi dan penyelenggaraan  >  Bagaimana untuk menggabungkan nginx dengan keepalived untuk mencapai ketersediaan tinggi

Bagaimana untuk menggabungkan nginx dengan keepalived untuk mencapai ketersediaan tinggi

WBOY
WBOYke hadapan
2023-05-12 08:43:111173semak imbas

Pengenalan kepada keepalived

Fungsi keepalived adalah untuk mengesan status pelayan Jika pelayan web sedang down, atau terdapat kegagalan kerja, keepalived akan mengesannya dan akan Pelayan yang rosak dialih keluar daripada sistem, dan pelayan lain digunakan untuk menggantikan kerja pelayan Apabila pelayan berfungsi seperti biasa, keepalived menambahkan pelayan ke kumpulan pelayan secara automatik . Apa yang perlu dilakukan secara manual ialah Membaiki pelayan yang gagal.

Rajah seni bina sistem

Bagaimana untuk menggabungkan nginx dengan keepalived untuk mencapai ketersediaan tinggi

Langkah-langkah pelaksanaan

1. Konfigurasi persekitaran

1.1 Pasang nginx

Pasang kebergantungan yang berkaitan

yum install pcre-devel zlib zlib-devel openssl openssl-devel

Muat naik dan nyahmampat pakej termampat

tar zxvf nginx-1.12.2.tar.gz

Buat direktori, mengesan konfigurasi

mkdir -p /usr/local/nginx
./configure --prefix=/usr/local/nginx

Prakompilasi dan pasang

make && make install

Mulakan dan hentikan arahan berkaitan

cd /usr/local/nginx/sbin/
./nginx
./nginx -s stop
./nginx -s start

1.2 Pasang keepalived

yum install -y keepalived

2. Konfigurasi hos

Ubah suai konfigurasi keepalived fail

vim /etc/keepalived/keepalived.conf

Kandungan yang diubah suai adalah seperti berikut

#新增的配置
vrrp_script chk_http_port {
 script "/shell/nginx_check.sh" #脚本地址
 interval 2 #检测脚本执行的间隔
 weight 2 #比重
}

vrrp_instance vi_1 {
 state master #主服务器为master,从服务器为backup
 interface eth0 #网卡
 virtual_router_id 51 #主、备机的virtual_router_id必须相同
 priority 100 #主、备机不同的优先级,主机优先级较大,备机值较小,默认是100
 advert_int 1
 authentication {
  auth_type pass
  auth_pass 1111
 }
 #虚拟ip地址
 virtual_ipaddress {
  192.168.126.88
 }
}

Buat fail skrip

mkdir /shell/nginx_check.sh
vim /shell/nginx_check.sh

Kandungan fail skrip adalah seperti berikut

#!/bin/bash
a=`ps -c nginx –no-header |wc -l`
if [ $a -eq 0 ];then
  /usr/local/nginx/sbin/nginx
  sleep 2
  if [ `ps -c nginx --no-header |wc -l` -eq 0 ];then
    killall keepalived
  fi
fi

3 Konfigurasi hamba

Ubah suai fail konfigurasi yang disimpan

rreee

4

Mula

vrrp_instance vi_1 {
  state backup #主服务器为master,从服务器为backup
  interface eth0 #网卡
  virtual_router_id 51 #主、备机的virtual_router_id必须相同
  priority 50 #主、备机不同的优先级,主机优先级较大,备机值较小
  advert_int 1
  authentication {
    auth_type pass
    auth_pass 1111
  }
  #虚拟ip地址
  virtual_ipaddress {
    192.168.126.88
  }
}

Lihat alamat ip maya

service keepalived start

5

Tutup tembok api


ip addr
1: lo: <loopback,up,lower_up> mtu 65536 qdisc noqueue state unknown 
  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  inet 127.0.0.1/8 scope host lo
  inet6 ::1/128 scope host 
    valid_lft forever preferred_lft forever
2: eth0: <broadcast,multicast,up,lower_up> mtu 1500 qdisc pfifo_fast state up qlen 1000
  link/ether 00:0c:29:4f:31:ce brd ff:ff:ff:ff:ff:ff
  inet 192.168.126.100/24 brd 192.168.126.255 scope global eth0
  inet 192.168.126.88/32 scope global eth0
  inet6 fe80::20c:29ff:fe4f:31ce/64 scope link 
    valid_lft forever preferred_lft forever

Log masuk ke alamat IP maya untuk melihat


service iptables stop
#查看防火墙是否开机自启动
chkconfig --list | grep iptables
chkconfig iptables off

Atas ialah kandungan terperinci Bagaimana untuk menggabungkan nginx dengan keepalived untuk mencapai ketersediaan tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam