Nginx 從安裝到高可用,一篇搞定,99% 的人都收藏了。。

来源:https://www.cnblogs.com/javastack/archive/2022/04/13/16141824.html
-Advertisement-
Play Games

來源:blog.csdn.net/qq_34886352/article/details/103581973 一、Nginx安裝 1、去官網http://nginx.org/下載對應的nginx包,推薦使用穩定版本 2、上傳nginx到linux系統 3、安裝依賴環境 (1)安裝gcc環境 yum ...


來源:blog.csdn.net/qq_34886352/article/details/103581973


一、Nginx安裝

1、去官網http://nginx.org/下載對應的nginx包,推薦使用穩定版本

2、上傳nginx到linux系統

3、安裝依賴環境

(1)安裝gcc環境

yum install gcc-c++

(2)安裝PCRE庫,用於解析正則表達式

yum install -y pcre pcre-devel

(3)zlib壓縮和解壓縮依賴

yum install -y zlib zlib-devel

(4)SSL 安全的加密的套接字協議層,用於HTTP安全傳輸,也就是https

yum install -y openssl openssl-devel

4、解壓,需要註意,解壓後得到的是源碼,源碼需要編譯後才能安裝

tar -zxvf nginx-1.16.1.tar.gz

5、編譯之前,先創建nginx臨時目錄,如果不創建,在啟動nginx的過程中會報錯

mkdir /var/temp/nginx -p

6、在nginx目錄,輸入如下命令進行配置,目的是為了創建makefile文件

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi

註:代表在命令行中換行,用於提高可讀性配置命令:

圖片

7、make編譯&安裝

make
make install

8、進入sbin目錄啟動nginx

啟動:nginx停止:./nginx -s stop重新載入:./nginx -s reload

二、配置反向代理

1、配置upstream

upstream [proxyName] {
    server 192.168.1.173:8080;
    server 192.168.1.174:8080;
    server 192.168.1.175:8080;
}

2、配置server

server {
    listem  80;
    server_name www.tomcats.com;

    location / {
        proxy_pass http://tomcats;
    }
}

三、配置負載均衡

nginx預設採用輪訓的方式進行負載均衡

1、使用加權輪詢

upstream [proxyName] {
    server 192.168.1.173:8080 weight=1;
    server 192.168.1.174:8080 weight=5;
    server 192.168.1.175:8080 weight=2;
}

2、hash負載均衡

upstream [proxyName] {
    ip_hash

    server 192.168.1.173:8080;
    server 192.168.1.174:8080;
    server 192.168.1.175:8080;
}

hash演算法實際上只會計算 192.168.1這段做哈希

使用ip_hash的註意點:

  • 不能把後臺伺服器直接移除,只能標記down.

3、url hash負載均衡

upstream [proxyName] {
    hash $request_url;

    server 192.168.1.173:8080;
    server 192.168.1.174:8080;
    server 192.168.1.175:8080;
}

4、最小連接負載均衡

upstream [proxyName] {
    least_conn;

    server 192.168.1.173:8080;
    server 192.168.1.174:8080;
    server 192.168.1.175:8080;
}

四、upstream指令參數

  • max_conns:限制最大同時連接數 1.11.5之前只能用於商業版
  • slow_start:單位秒,權重在指定時間內從1上升到指定值,不適用與hash負載均衡、隨機負載均衡 如果在 upstream 中只有一臺 server,則該參數失效(商業版才有)
  • down:禁止訪問
  • backup:備用機 只有在其他伺服器無法訪問的時候才能訪問到 不適用與hash負載均衡、隨機負載均衡
  • max_fails:表示失敗幾次,則標記server已宕機,剔出上游服務 預設值1
  • fail_timeout:表示失敗的重試時間 預設值10

1、keepalived

upstream [proxyName] {
    server 192.168.1.173:8080 weight=1;
    server 192.168.1.174:8080 weight=5;
    server 192.168.1.175:8080 weight=2;

    keepalive 32; #保持的連接數
}

server {
    listem  80;
    server_name www.tomcats.com;

    location / {
        proxy_pass http://tomcats;
        proxy_http_version 1.1; #連接的協議版本
        proxy_set_header Connection ""; 清空連接請求頭
    }
}

2、控制瀏覽器緩存

server {
    listem  80;
    server_name www.tomcats.com;

    location / {
        proxy_pass http://tomcats;
               expires 10s;  #瀏覽器緩存10秒鐘
               #expires @22h30m  #在晚上10點30的時候過期
               #expires -1h  #緩存在一小時前時效
               #expires epoch  #不設置緩存
               #expires off  #緩存關閉,瀏覽器自己控制緩存
               #expires max  #最大過期時間
    }
}

3、反向代理緩存

upstream [proxyName] {
    server 192.168.1.173:8080 weight=1;
    server 192.168.1.174:8080 weight=5;
    server 192.168.1.175:8080 weight=2;
}

#proxy_cache_path 設置緩存保存的目錄的位置
#keys_zone設置共用內以及占用的空間大小
#mas_size 設置緩存最大空間
#inactive 緩存過期時間,錯過此時間自動清理
#use_temp_path 關閉零時目錄
proxy_cache_path /usr/local/nginx/upsteam_cache keys_zone=mycache:5m max_size=1g inactive=8h use_temp_path=off;

server {
    listem  80;
    server_name www.tomcats.com;
    #開啟並使用緩存
    proxy_cache mycache;
    #針對200和304響應碼的緩存過期時間
    proxy_cache_valid 200 304 8h;

    location / {
        proxy_pass http://tomcats;
    }
}

五、配置ssl證書提供https訪問

1. 安裝SSL模塊

要在nginx中配置https,就必須安裝ssl模塊,也就是: http_ssl_module

進入到nginx的解壓目錄:/home/software/nginx-1.16.1

新增ssl模塊(原來的那些模塊需要保留)

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi  \
--with-http_ssl_module

編譯和安裝

makemake install

2、配置HTTPS

把ssl證書 *.crt 和 私鑰 *.key 拷貝到/usr/local/nginx/conf目錄中。

新增 server 監聽 443 埠:

server {
    listen       443;
    server_name  www.imoocdsp.com;
    # 開啟ssl
    ssl     on;
    # 配置ssl證書
    ssl_certificate      1_www.imoocdsp.com_bundle.crt;
    # 配置證書秘鑰
    ssl_certificate_key  2_www.imoocdsp.com.key;
    # ssl會話cache
    ssl_session_cache    shared:SSL:1m;
    # ssl會話超時時間
    ssl_session_timeout  5m;
    # 配置加密套件,寫法遵循 openssl 標準
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
    ssl_prefer_server_ciphers on;

    location / {
        proxy_pass http://tomcats/;
        index  index.html index.htm;
    }
}

六、配置ha nginx

1、安裝keepalived

(1)下載

https://www.keepalived.org/download.html

(2)解壓

tar -zxvf keepalived-2.0.18.tar.gz

(3)使用configure命令配置安裝目錄與核心配置文件所在位置:

./configure --prefix=/usr/local/keepalived --sysconf=/etc
  • prefix :keepalived安裝的位置sysconf:keepalived核心配置文件所在位置,固定位置,改成其他位置則keepalived啟動不了,/var/log/messages中會報錯
  • sysconf :keepalived核心配置文件所在位置,固定位置,改成其他位置則keepalived啟動不了,/var/log/messages中會報錯

配置過程中可能會出現警告信息,如下所示:

*** WARNING - this build will not support IPVS with IPv6. Please install libnl/libnl-3 dev libraries to support IPv6 with IPVS.

# 安裝libnl/libnl-3依賴
yum -y install libnl libnl-devel

(4)安裝keepalived

make && make install

(5)配置文件 在/etc/keepalived/keepalived.conf

(6)忘記安裝配置的目錄,則通過如下命令找到:

whereis keepalived

(7)啟動keepalived

進入sbin目錄

./keepalived

2、配置keepalived 主機

(1)通過命令 vim keepalived.conf 打開配置文件

global_defs {
    # 路由id:當前安裝keepalived的節點主機標識符,保證全局唯一
    router_id keep_171
}

vrrp_instance VI_1 {
    # 表示狀態是MASTER主機還是備用機BACKUP
    state MASTER
    # 該實例綁定的網卡
    interface ens33
    # 保證主備節點一致即可
    virtual_router_id 51
    # 權重,master權重一般高於backup,如果有多個,那就是選舉,誰的權重高,誰就當選
    priority 100
    # 主備之間同步檢查時間間隔,單位秒
    advert_int 2
    # 認證許可權密碼,防止非法節點進入
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    # 虛擬出來的ip,可以有多個(vip)
    virtual_ipaddress {
        192.168.1.161
    }
}

附:查看網卡信息命令

ip addr

(2)啟動keepalived

(3)查看進程

ps -ef|grep keepalived

(4)查看vip(虛擬ip)

在網卡ens33下,多了一個192.168.1.161,這個就是虛擬ip

3、把keepalived註冊為系統服務

(1)拷貝配置文件

  • 將keepalived目錄下etc/init.d/keepalived拷貝到/etc/init.d/
  • 將keepalived目錄下etc/sysconfig/keepalived拷貝到/etc/sysconfig/

(2)刷新systemctl

systemctl daemon-reload

(3)啟動、停止、重啟keepalived

#啟動
systemctl start keepalived.service
#停止
systemctl stop keepalived.service
#重啟
systemctl restart keepalived.service

4、實現雙機主備高可用

圖片

(1)修改備機配置

global_defs {
    router_id keep_172
}
vrrp_instance VI_1 {
    # 備用機設置為BACKUP
    state BACKUP
    interface ens33
    virtual_router_id 51
    # 權重低於MASTER
    priority 80
    advert_int 2
    authentication {
        auth_type PASS auth_pass 1111
    }
    virtual_ipaddress {
        # 註意:主備兩台的vip都是一樣的,綁定到同一個vip
        192.168.1.161
    }
}

(2) 啟動 Keepalived

(3) 訪問vip即可訪問主機,當主機失效時訪問vip就會訪問到備機

5、keepalived配置nginx自動重啟

(1)編寫腳本

/etc/keepalived/下創建腳本check_nginx_alive_or_not

#!/bin/bash

A=`ps -C nginx --no-header |wc -l`
# 判斷nginx是否宕機,如果宕機了,嘗試重啟
if [ $A -eq 0 ];then
    /usr/local/nginx/sbin/nginx
    # 等待一小會再次檢查nginx,如果沒有啟動成功,則停止keepalived,使其啟動備用機
    sleep 3
        if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
            killall keepalived
        fi
fi

(2)添加運行許可權

chmod +x /etc/keepalived/check_nginx_alive_or_not.sh

(3)配置keepalived監聽nginx腳本

vrrp_script check_nginx_alive {
    script "/etc/keepalived/check_nginx_alive_or_not.sh"
    interval 2 # 每隔兩秒運行上一行腳本
    weight 10 # 如果腳本運行失敗,則升級權重+10
}

(4)在vrrp_instance中新增監控的腳本

track_script {
    check_nginx_alive # 追蹤 nginx 腳本
}

(5)重啟Keepalived使得配置文件生效

systemctl restart keepalived

6、keepalived雙主熱備

(1)配置DNS輪詢

在同一個功能變數名稱下配置兩個ip,自行百度

(2)配置第一臺主機

global_defs {
    router_id keep_171
}
vrrp_instance VI_1 {
    state MASTER i
    nterface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.161
    }
}

vrrp_instance VI_2  {
    state BACKUP
    interface ens33
    virtual_router_id 52
    priority 80
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.162
    }
}

(3)配置第二台主機

global_defs {
    router_id keep_172
}
vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 80
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.161
    }
}

vrrp_instance VI_2 {
    state MASTER
    interface ens33
    virtual_router_id 52
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.162
    }
}

(4)重啟兩台Keepalived

systemctl restart keepalived

七、LVS(Linux Virtual Server)實現高可用負載均衡

1、為什麼要使用LVS+Nginx

  • lvs基於四層負載均衡,工作效率較Nginx的七層負載更高,使用LVS搭建Nginx集群,可以提高性能
  • 四層負載均衡無法對信息處理,只能通過ip+埠的形式轉發,所以需要七成負載進行數據的處理
  • Nginx接收請求來回,LVS可以只接受不響應

2、LVS的三種模式

(1)NAT模式

  • 客戶端將請求發往LVS,LVS會選擇一臺伺服器響應請求,伺服器將結果返回給LVS,LVS再返回給客戶端。
  • 在NAT模式中,伺服器的網關必須指向LVS,否則報文無法送達客戶端
  • NAT 技術將請求的報文和響應的報文都需要通過LVS進行地址改寫,因此網站訪問量比較大的時候負載均衡調度器有比較大的瓶頸,一般要求最多之能 10-20 台節點
  • NAT 模式支持對 IP 地址和埠進行轉換。即用戶請求的埠和真實伺服器的埠可以不一致

(2)TUN模式

  • 客戶端將請求發往LVS,LVS會選擇一臺伺服器響應請求,在客戶端與伺服器之間建立隧道,返回結果的時候直接由伺服器返迴響應,不在經過LVS。
  • TUN模式必須所有的伺服器上都綁定VIP的IP地址,所有的伺服器都必須有網卡。
  • TUN模式走隧道運維難度大,並且會直接暴露伺服器地址
  • 伺服器將應答包直接發給用戶。所以,減少了負載均衡器的大量數據流動,負載均衡器不再是系統的瓶頸,就能處理很巨大的請求量,這種方式,一臺負載均衡器能夠為很多伺服器進行分發。而且跑在公網上就能進行不同地域的分發

(3)DR模式

  • 客戶端將請求發往LVS,LVS會選擇一臺伺服器響應請求,返回結果的時候通過統一的路由進行返回,不在經過LVS。
  • 和TUN模式一樣,LVS只是分發請求,應答包通過單獨的路由返回給客戶端,與TUN相比這種方式不需要隧道結構,可以相容大多數的操作系統,同時統一路由可以隱藏真實的物理伺服器。DR模式效率更高,但配置更複雜.
  • 所有伺服器節點和LVS只能在一個區域網裡面。

3、搭建LVS-DR模式

先關閉掉伺服器上網路配置管理器,避免網路介面衝突

systemctl stop NetworkManagersystemctl disable NetworkManager

(1)創建子介面(創建LVS的虛擬ip)

進入網卡配置目錄/etc/sysconfig/network-scripts/,找到網卡配置文件,這裡以ifcfg-ens33為例,拷貝並創建子介面

cp ifcfg-ens33 ifcfg-ens33:1

修改子介面配置如下

  • 配置中的 192.168.1.150 就是vip,是提供給外網用戶訪問的ip地址
DEVICE="ens33:1"ONBOOT="yes"IPADDR=192.168.1.150NETMASK=255.255.255.0BOOTPROTO=static
  • 重啟網路服務
service network restart

重啟成功後,ip addr 查看一下,你會發現多了一個ip,也就是虛擬ip(vip)

註意:阿裡雲不支持配置網卡,需要購買相應的負載均衡服務,騰訊雲支持配置網卡,但需要購買網卡支持,一個網卡支持10個虛擬ip配置

(2)安裝ipvsadm

如今的centos都集成了LVS,所以ipvs是自帶的,我們只需要安裝ipvsadm即可(ipvsadm是管理集群的工具,通過ipvs可以管理集群,查看集群等操作)

yum install ipvsadm

(3)配置伺服器(RS)的虛擬ip

進入網卡配置目錄/etc/sysconfig/network-scripts/,找到ifcfg-lo,拷貝並創建子介面

cp ifcfg-lo ifcfg-lo:1

修改子介面配置如下

DEVICE="lo:1"
IPADDR=192.168.1.150
NETMASK=255.255.255.255
NETWORK=127.0.0.0
BROADCAST=127.255.255.255
ONBOOT="yes"
NAME=loopback

重啟網路服務成功後,ip addr 查看一下,你會發現多了一個ip,也就是虛擬ip(vip)

(4)為伺服器(RS)配置arp

ARP響應級別與通告行為參數說明

arp-ignore:ARP響應級別(處理請求)
    0:只要本機配置了ip,就能響應請求
    1:請求的目標地址到達對應的網路介面,才會響應請求
arp-announce:ARP通告行為(返迴響應)
    0:本機上任何網路介面都向外通告,所有的網卡都能接受到通告
    1:儘可能避免本網卡與不匹配的目標進行通告2:只在本網卡通告

打開sysctl.conf:

vim /etc/sysctl.conf

配置所有網卡、預設網卡以及虛擬網卡的arp響應級別和通告行為,分別對應:all,default,lo

# configration for lvs net.ipv4.conf.all.arp_ignore = 1 net.ipv4.conf.default.arp_ignore = 1 net.ipv4.conf.lo.arp_ignore = 1 net.ipv4.conf.all.arp_announce = 2 net.ipv4.conf.default.arp_announce = 2 net.ipv4.conf.lo.arp_announce = 2

刷新配置文件

sysctl -p

增加一個網關,用於接收數據報文,當有請求到本機後,會交給lo去處理

route add -host 192.168.1.150 dev lo:1

將網關添加至開機啟動

echo "route add -host 192.168.1.150 dev lo:1" >> /etc/rc.local

(4)使用ipvsadm配置集群規則

創建LVS節點,用戶訪問的集群調度者

ipvsadm -A -t 192.168.1.150:80 -s rr -p 5
  • -A:添加集群
  • -t:tcp協議ip地址:設定集群的訪問
  • ip:也就是LVS的虛擬ip
  • -s:設置負載均衡的演算法,
  • rr:表示輪詢
  • -p:設置連接持久化的時間,在指定時間內同一個用戶的請求會訪問到同一個伺服器中

創建多台RS真實伺服器

ipvsadm -a -t 192.168.1.150:80 -r 192.168.1.171:80 -g
ipvsadm -a -t 192.168.1.150:80 -r 192.168.1.172:80 -g
  • -a:添加真實伺服器
  • -t:tcp協議
  • -r:真實伺服器的ip地址
  • -g:設定DR模式

保存到規則庫,否則重啟失效

ipvsadm -S

檢查集群

#查看集群列表
ipvsadm -Ln
#查看集群狀態
ipvsadm -Ln --stats

一些其他命令

 # 重啟ipvsadm,重啟後需要重新配置
 service ipvsadm restart
 # 查看持久化連接
 ipvsadm -Ln --persistent-conn
 # 查看連接請求過期時間以及請求源ip和目標ip
 ipvsadm -Lnc
 # 設置tcp tcpfin udp 的過期時間(一般保持預設)
 ipvsadm --set 1 1 1
 # 查看過期時間
 ipvsadm -Ln --timeout

(5)訪問虛擬ip,完成LVS搭建

附:LVS的負載均衡演算法

(1)靜態演算法

靜態:根據LVS本身自由的固定的演算法分發用戶請求。

  • 輪詢(Round Robin 簡寫’rr’):輪詢演算法假設所有的伺服器處理請求的能力都一樣的,調度器會把所有的請求平均分配給每個真實伺服器。(同Nginx的輪詢)
  • 加權輪詢(Weight Round Robin 簡寫’wrr’):安裝權重比例分配用戶請求。權重越高,被分配到處理的請求越多。(同Nginx的權重)
  • 源地址散列(Source Hash 簡寫’sh’):同一個用戶ip的請求,會由同一個RS來處理。(同Nginx的ip_hash)
  • 目標地址散列(Destination Hash 簡寫’dh’):根據url的不同,請求到不同的RS。(同Nginx的url_hash)

(2)動態演算法

動態:會根據流量的不同,或者伺服器的壓力不同來分配用戶請求,這是動態計算的。

  • 最小連接數(Least Connections 簡寫’lc’):把新的連接請求分配到當前連接數最小的伺服器。

  • 加權最少連接數(Weight Least Connections 簡寫’wlc’):伺服器的處理性能用數值來代表,權重越大處理的請求越多。Real Server 有可能會存在性能上的差異,wlc動態獲取不同伺服器的負載狀況,把請求分發到性能好並且比較空閑的伺服器。

  • 最短期望延遲(Shortest Expected Delay 簡寫’sed’):特殊的wlc演算法。舉例闡述,假設有ABC三台伺服器,權重分別為1、2、3 。如果使用wlc演算法的話,當一個新請求進來,它可能會分給ABC中的任意一個。使用sed演算法後會進行如下運算:

    • A:(1+1)/1=2
  • B:(1+2)/2=3/2

  • C:(1+3)/3=4/3

最終結果,會把這個請求交給得出運算結果最小的伺服器。最少隊列調度(Never Queue 簡寫’nq’):永不使用隊列。如果有Real Server的連接數等於0,則直接把這個請求分配過去,不需要在排隊等待運算了(sed運算)。

八、搭建Keepalived+Lvs+Nginx高可用集群負載均衡

如果原先伺服器上配置了LVS+nginx需要清空ipvsadm中的配置

ipvsadm -C

如果配置了Keepalived+Nginx雙主集群也需要去除掉Keepalived中原先的配置,按照的後文進行配置

(1)使用keepalived配置Master LVS

在LVS的機器上安裝keepalived,安裝過程參考上文

(1)修改keepalived的配置

global_defs {
    router_id keep_151
}
vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 41
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.150
    }
}

#配置集群訪問的ip+埠,埠和nginx保持一致
virtual_server 192.168.1.150 80{
    #健康檢查的時間,單位:秒
    delay_loop 6
    #配置負載均衡的演算法,預設的輪詢
    lb_algo rr
    #設置LVS的模式 NAT|TUN|DR
    lb-kind DR
    #設置會話持久化的時間
    persistence_timeout 5
    #協議
    protocol TCP

    #配置負載均衡的真實伺服器,也就是nginx節點的具體的ip地址
    real_server 192.168.1.171 80{
        #輪詢權重配比
        weight 1
        #設置健康檢查
        TCP_CHECK {
            #檢查80埠
            connect_port 80
            #超時時間
            connect_timeout 2
            #重試次數
            nb_get_retry 2
            #重試間隔時間
            delay_before_retry 3
        }
    }
    real_server 192.168.1.171 80{
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 2
            nb_get_retry 2
            delay_before_retry 3
        }
    }
}

(2)啟動/重啟keepalived

systemctl restart keepalived

(2)使用keepalived配置Backup LVS

配置在備用機上

global_defs {
    router_id keep_152
}
vrrp_instance VI_1 {
    state  BACKUP
    interface ens33
    virtual_router_id 41
    priority 50
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.150
    }
}

#配置集群訪問的ip+埠,埠和nginx保持一致
virtual_server 192.168.1.150 80{
    #健康檢查的時間,單位:秒
    delay_loop 6
    #配置負載均衡的演算法,預設的輪詢
    lb_algo rr
    #設置LVS的模式 NAT|TUN|DR
    lb-kind DR
    #設置會話持久化的時間
    persistence_timeout 5
    #協議
    protocol TCP

    #配置負載均衡的真實伺服器,也就是nginx節點的具體的ip地址
    real_server 192.168.1.171 80{
        #輪詢權重配比
        weight 1
        #設置健康檢查
        TCP_CHECK {
            #檢查80埠
            connect_port 80
            #超時時間
            connect_timeout 2
            #重試次數
            nb_get_retry 2
            #重試間隔時間
            delay_before_retry 3
        }
    }
    real_server 192.168.1.171 80{
        weight 1
        TCP_CHECK {
            connect_port 80
            connect_timeout 2
            nb_get_retry 2
            delay_before_retry 3
        }
    }
}

近期熱文推薦:

1.1,000+ 道 Java面試題及答案整理(2022最新版)

2.勁爆!Java 協程要來了。。。

3.Spring Boot 2.x 教程,太全了!

4.別再寫滿屏的爆爆爆炸類了,試試裝飾器模式,這才是優雅的方式!!

5.《Java開發手冊(嵩山版)》最新發佈,速速下載!

覺得不錯,別忘了隨手點贊+轉發哦!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、手寫一個ajax 1 const xhr = new xmlHttpRequest() 2 3 xhr.open(請求方式:post get, 請求地址, 同步或者非同步) 4 5 xhr.onreadyStateChange = function(){ 6 if(xhr.readyState 4 ...
  • uni-app詳解 一、介紹 uni-app 是一個使用 Vue.js(opens new window)開發所有前端應用的框架,開發者編寫一套代碼,可發佈到iOS、Android、Web(響應式)、以及各種小程式(微信/支付寶/百度/頭條/飛書/QQ/快手/釘釘/淘寶)、快應用等多個平臺。 uni ...
  • 做的項目中需要將後端提供的數據展示在前端頁面,一開始我是用JS的setInterval()方法,設置一個時間,每過時間發起一次ajax請求。雖然也能湊活著實現,但總感覺數據不是實時刷新的,而且還占用資源,所以學習WebSocke,並總結了一下,以下是本人總結的前後端WebSocke相關代碼: 一、後 ...
  • 命令模式是什麼 命令模式是一種行為型設計模式,它可以將一個請求封裝為一個對象,使發出請求的責任和執行請求的責任分割開。這樣兩者之間通過命令對象進行溝通,這樣方便將命令對象進行儲存、傳遞、調用、增加與管理。 為什麼用命令模式 在軟體開發系統中,“方法的請求者”與“方法的實現者”之間經常存在緊密的耦合關 ...
  • 模板方法模式是什麼 模版方法模式是設計模式中的行為型的一種模式,它在基類中定義了一個演算法的框架,允許子類在不修改結構的情況下重寫演算法的特定步驟。 為什麼要用模板方法模式 模板方法將整個演算法轉換為一系列獨立的步驟,以便子類能對其進行擴展,同時還可讓超類中所定義的結構保持完整。或者當多個類的演算法步驟一致 ...
  • 平時開發 Python 代碼過程中,經常會遇到這個報錯: ValueError: list.remove(x): x not in list 錯誤提示信息也很明確,就是移除的元素不在列表之中。 比如: >>> lst = [1, 2, 3] >>> lst.remove(4) Traceback ( ...
  • Intellij IDEA 2022 正式發佈了,作為正版用戶,胖哥趕緊更新了一波,好家伙!這幾個功能確實很香啊。新版更新的東西真不少,不愧是一個大版本更新。 依賴分析 IDEA的依賴檢查、依賴衝突解決長期為人詬病,現在終於引進了依賴分析器,它可以幫助你對項目中的依賴信息進行檢索,以 幫助您檢測和解 ...
  • 《零基礎學Java》 JDBC中常用的類和介面 利用JDBC的這些類和介面可以更方便地訪問並處理存儲在資料庫中的數據。 DriverManager類 DriverManager類 是JDBC的管理層,用來管理資料庫中的驅動程式。在使用Java操作資料庫之前,必須使用 Class類 的 靜態方法for ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...