Nginx+Tomcat反向代理與負(fù)載均衡的實(shí)現(xiàn)
一、正向代理與反向代理
正向代理
客戶端想要直接與目標(biāo)服務(wù)器連接,但是無法直接進(jìn)行連接,就需要先去訪問中間的代理服務(wù)器,讓代理服務(wù)器代替客戶端去訪問目標(biāo)服務(wù)器
反向代理
屏蔽掉服務(wù)器的信息,經(jīng)常用在多臺服務(wù)器的分布式部署上,像一些大型網(wǎng)站,由于訪問人數(shù)很多,就需要多臺服務(wù)器來解決,由一個(gè)反向代理服務(wù)器來代理,客戶端發(fā)來請求,先由反向代理服務(wù)器,按一定的規(guī)則分發(fā)到明確的服務(wù)器,但客戶端不知道是哪臺服務(wù)器,常用Nginx做反向代理
二、負(fù)載均衡
什么是負(fù)載均衡
將工作任務(wù)或者訪問請求進(jìn)行平衡,然后分?jǐn)偟蕉鄠€(gè)單元、服務(wù)器或者組件上執(zhí)行,解決高并發(fā),高可用(單點(diǎn)故障)、擴(kuò)展性(水平伸縮)的最高解決方案
代碼倉庫定義
開發(fā)人員分別將前段和后端代碼都存入自己的代碼倉庫,由分支進(jìn)行分類(分支、主分支、分分支)分類儲存后,打包上傳服務(wù)器
后端打包工具M(jìn)aven(打包為War、jar包)
前段打包工具Npm、nodejs
一般前端打包后會放入/usr/local/nginx/html目錄當(dāng)中(nginx配置)
后端的打包回放入在Tomcat服務(wù)里的Webapps中
私有倉庫 gitlab
公有倉庫 github
分流策略
Nginx負(fù)載均衡模式(rr負(fù)載均衡模式)
每個(gè)請求按時(shí)間順序逐一分配到不同的后端服務(wù)器,如果超過了最大失敗次數(shù)后(max_fails)默認(rèn)為1,在失效時(shí)間內(nèi)(fail_timeout)默認(rèn)為10秒,該節(jié)點(diǎn)失效權(quán)重變?yōu)?,超過失效時(shí)間后,則恢復(fù)正常,或者全部節(jié)點(diǎn)都為down后,那么將所有節(jié)點(diǎn)都恢復(fù)為有效,繼續(xù)探測,一般來說rr可以根據(jù)權(quán)重進(jìn)行均勻分配
權(quán)重
least_conn(最少連接)
優(yōu)先將客戶端請求調(diào)度到當(dāng)前連接最少的服務(wù)器
ip_hash(負(fù)載均衡模式)
每個(gè)請求按訪問ip的hash結(jié)果分配,這樣每個(gè)訪客固定訪問一個(gè)后端的服務(wù)器,可以解決session的問題,但是ip_hash會造成負(fù)載不均,有的服務(wù)請求接受多,有的請求接受少,所以不建議采用ip_hash模式,session共享問題可用后端服務(wù)的session共享代替nginx的ip_hash
fair(第三方負(fù)載均衡模式)
按后端的服務(wù)器響應(yīng)時(shí)間來分配請求,響應(yīng)時(shí)間短的有限分配
url_hash(第三方負(fù)載均衡模式)
基于用戶請求的url做hash,和ip_hash算法類似,是對每個(gè)請求按url的hash結(jié)果分配,使每個(gè)URL定向到同一個(gè)后端服務(wù)器,但也會造成分配不均的問題,這種模式后端服務(wù)器為緩存時(shí)比較好
三、Nginx+Tomcat反向代理與負(fù)載均衡部署
第一步 關(guān)閉防火墻和安全機(jī)制
命令:systemctl stop firewalld
setenforce 0

第二步 安裝依賴環(huán)境
命令:yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make

第三步 編譯安裝
命令:./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-file-aio --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module

第四步 編譯
命令:make -j4 && make install

第五步 添加系統(tǒng)識別
命令:ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin

第六步 編輯配置文件
命令:vim /lib/systemd/system/nginx.service

第七步 賦權(quán)并啟動服務(wù)
命令:chmod 777 /lib/systemd/system/nginx.service
systemctl start nginx
systemctl enable nginx

第八步 查看指定端口服務(wù)
命令:lsof -i:8080

第九步 用瀏覽器測試Nginx

第十步 部署Tomcat服務(wù)器

第十一步 解包到指定目錄并優(yōu)化路徑
命令:tar xf [壓縮包名] -C [指定路徑]

第十二步 修改配置文件
命令:vim /etc/profile

第十三步 刷新文件
命令:source /etc/profile

第十四步 重啟Tomcat
命令:/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh

第十五步 查看對應(yīng)端口
命令:lsof -i:8080

第十六步 安裝第三臺虛擬機(jī)

第十七步 創(chuàng)建目錄編輯動態(tài)頁面

第十八步 修改配置文件

第十九步 重啟Tomcat

第二十步 查看對應(yīng)端口

第二十一步 用瀏覽器進(jìn)行測試

第二十二步 第三臺虛擬機(jī)配置Tomcat

第二十三步 修改動態(tài)頁面內(nèi)容

第二十四步 修改第一臺靜態(tài)頁面

第二十五步 準(zhǔn)備一個(gè)靜態(tài)圖片

第二十六步 配置Nginx文件

第二十七步 修改配置內(nèi)容

第二十八步 用瀏覽器進(jìn)行測試





以上就是Nginx+Tomcat反向代理與負(fù)載均衡的實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Nginx+Tomcat反向代理與負(fù)載均衡的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
nginx編譯安裝出現(xiàn)的常見錯(cuò)誤及解決方法
這篇文章給大家介紹了nginx在編譯安裝過程中容易出現(xiàn)的常見錯(cuò)誤以及解決方法,文中有詳細(xì)的代碼講解,對我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-08-08
詳解nginx同一端口監(jiān)聽多個(gè)域名和同時(shí)監(jiān)聽http與https
這篇文章主要介紹了詳解nginx同一端口監(jiān)聽多個(gè)域名和同時(shí)監(jiān)聽http與https的相關(guān)資料,需要的朋友可以參考下2017-05-05
負(fù)載均衡下的webshell上傳+nginx解析漏洞的過程
這篇文章主要介紹了負(fù)載均衡下的webshell上傳+nginx解析漏洞,首先介紹了負(fù)載均衡下webshell上傳的四大難點(diǎn)及環(huán)境搭建教程,感興趣的朋友跟隨小編一起看看吧2024-02-02
使用Nginx進(jìn)行URL轉(zhuǎn)發(fā)的配置案例
Nginx是一個(gè)高性能的Web服務(wù)器和反向代理服務(wù)器,它還可以用于URL轉(zhuǎn)發(fā),在本教學(xué)文章中,我們將從安裝Nginx開始,逐步介紹配置步驟,并展示一個(gè)URL轉(zhuǎn)發(fā)的案例,感興趣的朋友可以參考下2023-09-09

