在Ubuntu上實現Nginx的高可用性,通常涉及以下幾個關鍵步驟:
使用Nginx作為反向代理服務器,將流量分發到多個后端服務器上。
sudo apt update
sudo apt install nginx
編輯Nginx配置文件(通常位于 /etc/nginx/nginx.conf 或 /etc/nginx/sites-available/default),添加負載均衡配置:
http {
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
server {
listen 80;
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
}
Keepalived可以提供虛擬IP地址(VIP)和故障轉移功能。
sudo apt install keepalived
編輯Keepalived配置文件(通常位于 /etc/keepalived/keepalived.conf):
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 51
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 42
}
virtual_ipaddress {
192.168.1.100
}
}
virtual_server 192.168.1.100 80 {
delay_loop 6
lb_algo rr
lb_kind DR
nat_mask 255.255.255.0
persistence_timeout 50
protocol TCP
real_server 192.168.1.1 80 {
weight 1
TCP_CHECK {
connect_timeout 10
connect_port 80
}
}
real_server 192.168.1.2 80 {
weight 1
TCP_CHECK {
connect_timeout 10
connect_port 80
}
}
real_server 192.168.1.3 80 {
weight 1
TCP_CHECK {
connect_timeout 10
connect_port 80
}
}
}
確保Nginx服務器的健康狀態可以被Keepalived檢測到。
在Nginx配置文件中添加健康檢查端點:
server {
listen 80;
location /health {
return 200 "OK";
}
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
啟動Nginx和Keepalived服務:
sudo systemctl start nginx
sudo systemctl start keepalived
通過停止一個Nginx實例或斷開其與Keepalived的連接,測試故障轉移功能是否正常工作。
sudo systemctl stop nginx
如果配置正確,Keepalived會將虛擬IP地址切換到另一個健康的Nginx實例上。
通過以上步驟,你可以在Ubuntu上實現Nginx的高可用性。確保定期檢查和維護系統,以確保其穩定運行。