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

Bagaimana untuk menggabungkan nginx dengan keepalived untuk mencapai ketersediaan tinggi

WBOY
Lepaskan: 2023-05-12 08:43:11
ke hadapan
1285 orang telah melayarinya

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
Salin selepas log masuk

Muat naik dan nyahmampat pakej termampat

tar zxvf nginx-1.12.2.tar.gz
Salin selepas log masuk

Buat direktori, mengesan konfigurasi

mkdir -p /usr/local/nginx
./configure --prefix=/usr/local/nginx
Salin selepas log masuk

Prakompilasi dan pasang

make && make install
Salin selepas log masuk

Mulakan dan hentikan arahan berkaitan

cd /usr/local/nginx/sbin/
./nginx
./nginx -s stop
./nginx -s start
Salin selepas log masuk

1.2 Pasang keepalived

yum install -y keepalived
Salin selepas log masuk

2. Konfigurasi hos

Ubah suai konfigurasi keepalived fail

vim /etc/keepalived/keepalived.conf
Salin selepas log masuk

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
 }
}
Salin selepas log masuk

Buat fail skrip

mkdir /shell/nginx_check.sh
vim /shell/nginx_check.sh
Salin selepas log masuk

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
Salin selepas log masuk

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
  }
}
Salin selepas log masuk

Lihat alamat ip maya

service keepalived start
Salin selepas log masuk

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
Salin selepas log masuk

Log masuk ke alamat IP maya untuk melihat


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

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!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan