" />

色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

nginx七層負載均衡配置詳解

瀏覽:97日期:2023-03-13 15:37:18
目錄
  • 一、負載均衡介紹
  • 二、nginx下載安裝
    • 1、下載nginx源碼包
    • 2、安裝并啟用
  • 三、nginx七層負載均衡配置
    • real server設置:
    • 客戶端設置:
  • 四、nginx擴充調(diào)度算法(sticky)
    • 1.下載擴展包
    • 2.編譯前做一些優(yōu)化:
    • 3.重新編譯

一、負載均衡介紹

1)四層負載均衡

所謂四層就是基于IP+端口的負載均衡

四層負載均衡,是指OSI七層模型中的傳輸層,傳輸層已經(jīng)支持TCP/IP的控制,所以只需要對客戶端的請求進行TCP/IP協(xié)議的包轉(zhuǎn)發(fā)就可以實現(xiàn)負載。

2)七層負載均衡

七層是基于URL等應用層信息的負載均衡

七層負載均衡是在應用層,它可以完成很多應用方面的協(xié)議請求

3)四層與七層區(qū)別

四層負載均衡數(shù)據(jù)在底層就進行了分發(fā),而七層負載均衡數(shù)據(jù)包則是在最頂層進行分發(fā),七層負載均衡效率沒有四層負載均衡高。

四層負載均衡可以用來解決七層負載均衡端口限制問題(七層負載均衡最大使用65535個端口號)

但是四層不支持協(xié)議的轉(zhuǎn)發(fā)(http,https,DNS等)只支持IP,不識別域名。

七層負載均衡更貼近于服務,如HTTP協(xié)議就是七層協(xié)議

支持很多功能,比如支持http信息的改寫、頭部信息的改寫、安全應用規(guī)則控制、URL匹配規(guī)則控制、以及轉(zhuǎn)發(fā)、rewrite等一些規(guī)則,在應用層的服務里面可以做的內(nèi)容更多。

二、nginx下載安裝

1、下載nginx源碼包

nginx網(wǎng)站域名:http://nginx.org/

[root@server1 ~]# wget http://nginx.org/download/nginx-1.20.2.tar.gz [root@server1 ~]# lsnginx-1.20.2.tar.gz [root@server1 ~]# tar -zxf nginx-1.20.2.tar.gz [root@server1 ~]# lsnginx-1.20.2  nginx-1.20.2.tar.gz

2、安裝并啟用

[root@server1 ~]# cd nginx-1.20.2[root@server1 nginx-1.20.2]# lsauto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src [root@server1 nginx-1.20.2]# ./configure --help #可以看到可用參數(shù) [root@server1 nginx-1.20.2]# ./configure --with-http_ssl_module --with-http_stub_status_module  --prefix=/usr/local/nginx【注:此命令是安裝一些模塊,此命令必須在nginx源碼目錄下執(zhí)行】

解決:

yum install -y gcc

繼續(xù)編譯

解決:

yum install -y pcre-devel 

編譯成功

此時生成了文件Makefile,此文件會指導我們進行make(將源碼編譯成本系統(tǒng)可以用的可執(zhí)行程序)

make完成后,會在該目錄下的objs/nginx下生成nginx執(zhí)行程序,再進行make install

完成后所有編譯好的nginx程序都在指定的路徑 /usr/local/nginx下,做一個軟連接鏈接到/usr/local/bin下

[root@server1 ~]# ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/  ##建立軟連接[root@server1 ~]# which nginx/usr/local/bin/nginx

檢測語法正確后啟動nginx

[root@server1 ~]# /usr/local/nginx/sbin/nginx -t   ##查看語法是否有誤[root@server1 ~]# nginx    ##啟動nginx[root@server1 ~]# nginx -s reload  ##重新加載nginx[root@server1 ~]# nginx -s stop    ##停掉nginx

訪問http://172.25.254.1

注意:不能多次啟動nginx,每次啟動完成后要用nginx -s stop 關閉nginx,因為80端口不能被多次占用

三、nginx七層負載均衡配置

/usr/local/bin/nginx/nginx.conf 為nginx的主配置文件

real server設置:

開啟server2、server3虛擬機做負載均衡后端服務器

[root@server2 ~]# systemctl start httpdecho server2 > /var/www/html/index.html[root@server3 ~]# systemctl start httpdecho server3 > /var/www/html/index.html

nginx配置:

補:

可以加權重

也可以更換負載均衡算法

如要升級real server,手動下線

自己寫一個模塊:

修改配置文件后:

[root@server1 ~]# nginx -t[root@server2 ~]# nginx -s reload

客戶端設置:

[root@westos_student72 westos]# vim /etc/hosts172.25.254.1 server1  www.westos.org

測試:

[root@westos_student72 westos]# curl www.westos.orgserver2[root@westos_student72 westos]# curl www.westos.orgserver3[root@westos_student72 westos]# curl www.westos.orgserver2[root@westos_student72 westos]# curl www.westos.orgserver3[root@westos_student72 westos]# curl www.westos.orgserver2[root@westos_student72 westos]# curl www.westos.orgserver3

關閉server2的httpd服務:

[root@westos_student72 westos]# for i in {1..10}; do curl www.westos.org;doneserver3server3server3server3server3server3server3server3server3server3

nginx不再對server2進行調(diào)度,說明nginx對后端自帶健康檢測。

若此時再把server3掛掉:

系統(tǒng)報錯,沒有可用后端 ,此時我們可以這樣設置:

四、nginx擴充調(diào)度算法(sticky)

ip_hash調(diào)度算法比較符合客戶使用習慣,算法為了保證連接穩(wěn)定根據(jù)客戶端ip進行負載均衡,相同客戶端IP訪問時,會訪問到同一服務端,一個sever對一個IP。

ip_hash算法缺陷在于:客戶端發(fā)送請求到nginx服務器,再由nginx服務器到后端RS,后端RS再返回到nginx服務器再返回客戶端,所以后端RS不知道是誰訪問了自己。

改進:可以用Sticky cookie來實現(xiàn),類似于瀏覽器的cookie。客戶端發(fā)送請求時,后端RS返回信息時會將session信息傳回客戶端,客戶端存到瀏覽器中,這是RS分配給每一個客戶端的,以后每次請求RS就通過這個cookie來判斷是哪個客戶端。

開源文檔中顯示此功能只有Nginx Plus才有,此時我們就要先擴充一下我們的調(diào)度算法:加上sticky模塊重新編譯。

1.下載擴展包

擴展包名字:nginx-goodies-nginx-sticky-module-ng-08a395c66e42.zip

下載擴展包,安裝解壓工具并解壓

2.編譯前做一些優(yōu)化:

1、關閉gcc的debug模式,這樣編譯出的二進制程序會更小

[root@server1 nginx-1.20.2]# vim auto/cc/gcc

2、關閉版本顯示

[root@server1 nginx-1.20.2]# vim src/core/nginx.h

3.重新編譯

由于nginx是靜態(tài)編譯,所以每次增加新功能時都需要重新編譯,而且要加載之前的所有參數(shù)

[root@server1 nginx-1.20.2]# cd nginx-1.20.2[root@server1 nginx-1.20.2]# nginx -s stop ##編譯前停掉nginx[root@server1 nginx-1.20.2]# make clean  ##清除原來編譯的內(nèi)容 [root@server1 nginx-1.20.2]# ./configure --with-http_ssl_module --with-http_stub_status_module --prefix=/usr/local/nginx --add-module=/root/nginx-goodies-nginx-sticky-module-ng-08a395c66e42

編譯make

[root@server1 nginx-1.20.2]# make

注意不要進行make install安裝,因為軟件已經(jīng)安裝過,現(xiàn)在直是去更新,執(zhí)行make install 會進行覆蓋安裝

覆蓋原二進制程序

[root@server5 nginx-1.20.2]# cd objs/[root@server5 objs]# ls[root@server5 objs]# du -h nginx[root@server5 objs]# cp nginx /usr/local/nginx/sbin/cp: overwrite ‘/usr/local/nginx/sbin/nginx"? y[root@server5 objs]# cd /usr/local/nginx/sbin/[root@server5 sbin]# lsnginx[root@server5 sbin]# du -h nginx 936K	nginx

測試:

此時nginx就有了sticky的cookie功能

檢測語法沒問題后啟動nginx:

用瀏覽器訪問才能看見效果,因為cookie只能存在于瀏覽器

此時我們發(fā)現(xiàn)用瀏覽器訪問只能訪問到server2,而用curl壓測是負載均衡的。因為瀏覽器緩存了cookie值,cookie值不變,后端響應的RS也不會變。

到此這篇關于nginx七層負載均衡配置詳解的文章就介紹到這了,更多相關nginx 七層負載均衡 內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: Nginx
主站蜘蛛池模板: 国产精品一级片 | 成人免费午夜性视频 | 久久院线 | 亚洲依依成人综合在线网址 | 久久久久久青草大香综合精品 | 美女被免费网站视频软件 | 人碰人碰人成人免费视频 | 91精品国产欧美一区二区 | 亚洲图片在线视频 | 亚洲免费中文 | 欧美色视频日本片免费高清 | 国产精品一区久久 | 国产欧美日韩在线观看一区二区三区 | 天堂av2017男人的天堂 | 久久这里只有精品免费视频 | 中文字幕乱码无线码在线 | 免费精品99久久国产综合精品 | 成年人免费的视频 | 美国一级做a一级视频 | 午夜伦y4480影院中文字幕 | 久草青青 | 国产成人啪一区二区 | 久草综合网 | 久久精品国产99久久99久久久 | 全免费a级毛片免费毛视频 全午夜免费一级毛片 | 欧美多人三级级视频播放 | 成年人网站免费 | 日本a级三级三级三级久久 日本a级特黄三级三级三级 | 182福利视频| 久久久久亚洲香蕉网 | 免费精品99久久国产综合精品 | 欧美三级香港三级日本三级 | 国产精品欧美韩国日本久久 | 九九亚洲精品自拍 | 国产成人免费 | 免看一级一片一在线看 | 亚洲精品国产一区二区三 | 国产a∨一区二区三区香蕉小说 | 午夜国产精品不卡在线观看 | 国产人成午夜免费噼啪视频 | 日韩精品久久一区二区三区 |