天天看點

Nginx反向代理負載均衡Nginx反向代理負載均衡

Nginx反向代理負載均衡

實驗環境

-主機名 -ip -服務 系統
RS1 192.168.132.100 nginx ,keepalived centos8
RS2 192.168.132.135 nginx,keepalived centos8
nginx 192.168.132.137 nginx centos8
apache 192.168.132.140 apache centos8

反向代理

RS1

[[email protected] ~]# systemctl disable --now firewalld.service
[[email protected] ~]# sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/selinux/config
[[email protected] ~]# dnf -y install keepalived nginx
[[email protected] ~]# vi /etc/nginx/nginx.conf
.....
upstream lx.com {                                //寫在server外面
         server  192.168.132.137 weight=2;
         server  192.168.132.140;
}
.....
location / {                             //寫在server裡面
             proxy_pass http://lx.com;
         }

           

RS2

[[email protected] nginx]# scp -r nginx.conf 192.168.132.100:/etc/nginx/nginx.conf
roo[email protected]'s password: 
nginx.conf                       100% 2592     2.1MB/s                                                                                         

           

測試

[外鍊圖檔轉存失敗,源站可能有防盜鍊機制,建議将圖檔儲存下來直接上傳(img-AI1L53Br-1666014938951)(D:\360Downloads\image-20221017211025051.png)]

nginx

[[email protected] ~]# systemctl disable --now firewalld.service
[[email protected] ~]# sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/selinux/config
[[email protected] ~]# dnf -y install nginx
[[email protected] ~]# systemctl enable --now nginx.service 
[[email protected] ~]# echo 'hehe' > /usr/share/nginx/html/index.html 
           

apache

[[email protected] ~]# systemctl disable --now firewalld.service 
[[email protected]~]# sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/selinux/config
[[email protected] ~]# dnf -y install httpd
[[email protected] ~]# systemctl enable --now httpd
[[email protected] ~]# echo 'xixi' > /var/www/html/index.html
           

負載均衡

RS1

[[email protected] ~]# cd /etc/keepalived/
[[email protected] keepalived]# ls
keepalived.conf
[[email protected] keepalived]# mv keepalived.conf{,-bak}
[[email protected] keepalived]# ls
keepalived.conf-bak
[[email protected] keepalived]# vi keepalived.conf
[[email protected] keepalived]# cat keepalived.conf
global_defs {
   router_id lb01
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33     //要和自己網卡名字一緻
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.132.249   //vip貴賓不能是ping的通的
    }
}

virtual_server 192.168.132.249 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    persistence_timeout 50
    protocol TCP

    real_server 192.168.132.135 80 {
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }

    real_server 192.168.132.100 80 {
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}
[[email protected] keepalived]# systemctl restart keepalived.service 
[[email protected] keepalived]# ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
    link/ether 00:0c:29:8c:44:a8 brd ff:ff:ff:ff:ff:ff
    inet 192.168.132.100/24 brd 192.168.132.255 scope global noprefixroute ens33
       valid_lft forever preferred_lft forever
    inet 192.168.132.249/32 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::20c:29ff:fe8c:44a8/64 scope link noprefixroute 
       valid_lft forever preferred_lft forever
3: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
    link/ether 52:54:00:3a:e5:b9 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
       valid_lft forever preferred_lft forever
           

RS2

[[email protected] ~]# cd /etc/keepalived/
[[email protected] keepalived]# ls
keepalived.conf
[[email protected] keepalived]# mv keepalived.conf{,-bak}
[[email protected] keepalived]# ls
keepalived.conf-bak
//到RS1上遠端傳輸配置檔案
[[email protected] keepalived]# scp -r keepalived.conf 192.168.132.135:/etc/keepalived/
[email protected]'s password: 
keepalived.conf                                                                                               100%  831   335.4KB/s   00:00  

[[email protected] keepalived]# ls
keepalived.conf  keepalived.conf-bak
[[email protected] keepalived]# vi keepalived.conf
[[email protected] keepalived]# systemctl restart keepalived.service 
[[email protected] keepalived]# cat keepalived.conf
global_defs {
   router_id lb02
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.132.249
    }
}

virtual_server 192.168.132.249 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    persistence_timeout 50
    protocol TCP

    real_server 192.168.132.135 80 {
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }

    real_server 192.168.132.100 80 {
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}
           

測試

關閉掉RS1的keepalive服務測試
必須也要關閉nginx服務
[[email protected] ~]# systemctl stop keepalived.service 
[[email protected] ~]# systemctl stop nginx.service 



           

3

delay_before_retry 3

}

}

}

### 測試

           

關閉掉RS1的keepalive服務測試

必須也要關閉nginx服務

[[email protected] ~]# systemctl stop keepalived.service

[[email protected] ~]# systemctl stop nginx.service

[外鍊圖檔轉存失敗,源站可能有防盜鍊機制,建議将圖檔儲存下來直接上傳(img-t6RsWIpp-1666014938952)(D:\360Downloads\image-20221017215315573.png)]
           

繼續閱讀