目錄
- 一、正向代理與反向代理
- 正向代理
- 反向代理
- 二、負載均衡
- 什么是負載均衡
- 代碼倉庫定義
- 分流策略
- 權重
- least_conn(最少連接)
- ip_hash(負載均衡模式)
- fair(第三方負載均衡模式)
- url_hash(第三方負載均衡模式)
- 三、Nginx+Tomcat反向代理與負載均衡部署
一、正向代理與反向代理
正向代理
客戶端想要直接與目標服務器連接,但是無法直接進行連接,就需要先去訪問中間的代理服務器,讓代理服務器代替客戶端去訪問目標服務器
反向代理
屏蔽掉服務器的信息,經常用在多臺服務器的分布式部署上,像一些大型網站,由于訪問人數很多,就需要多臺服務器來解決,由一個反向代理服務器來代理,客戶端發來請求,先由反向代理服務器,按一定的規則分發到明確的服務器,但客戶端不知道是哪臺服務器,常用Nginx做反向代理
二、負載均衡
什么是負載均衡
將工作任務或者訪問請求進行平衡,然后分攤到多個單元、服務器或者組件上執行,解決高并發,高可用(單點故障)、擴展性(水平伸縮)的最高解決方案
代碼倉庫定義
開發人員分別將前段和后端代碼都存入自己的代碼倉庫,由分支進行分類(分支、主分支、分分支)分類儲存后,打包上傳服務器
后端打包工具Maven(打包為War、jar包)
前段打包工具Npm、nodejs
一般前端打包后會放入/usr/local/nginx/html目錄當中(nginx配置)
后端的打包回放入在Tomcat服務里的Webapps中
私有倉庫 gitlab
公有倉庫 github
分流策略
Nginx負載均衡模式(rr負載均衡模式)
每個請求按時間順序逐一分配到不同的后端服務器,如果超過了最大失敗次數后(max_fails)默認為1,在失效時間內(fail_timeout)默認為10秒,該節點失效權重變為0,超過失效時間后,則恢復正常,或者全部節點都為down后,那么將所有節點都恢復為有效,繼續探測,一般來說rr可以根據權重進行均勻分配
權重
least_conn(最少連接)
優先將客戶端請求調度到當前連接最少的服務器
ip_hash(負載均衡模式)
每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問一個后端的服務器,可以解決session的問題,但是ip_hash會造成負載不均,有的服務請求接受多,有的請求接受少,所以不建議采用ip_hash模式,session共享問題可用后端服務的session共享代替nginx的ip_hash
fair(第三方負載均衡模式)
按后端的服務器響應時間來分配請求,響應時間短的有限分配
url_hash(第三方負載均衡模式)
基于用戶請求的url做hash,和ip_hash算法類似,是對每個請求按url的hash結果分配,使每個URL定向到同一個后端服務器,但也會造成分配不均的問題,這種模式后端服務器為緩存時比較好
三、Nginx+Tomcat反向代理與負載均衡部署
第一步 關閉防火墻和安全機制
命令:systemctl stop firewalld
setenforce 0
第二步 安裝依賴環境
命令: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
第五步 添加系統識別
命令:ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin
第六步 編輯配置文件
命令:vim /lib/systemd/system/nginx.service
第七步 賦權并啟動服務
命令:chmod 777 /lib/systemd/system/nginx.service
systemctl start nginx
systemctl enable nginx
第八步 查看指定端口服務
命令:lsof -i:8080
第九步 用瀏覽器測試Nginx
第十步 部署Tomcat服務器
第十一步 解包到指定目錄并優化路徑
命令:tar xf [壓縮包名] -C [指定路徑]
第十二步 修改配置文件
命令:vim /etc/profile
第十三步 刷新文件
命令:source /etc/profile
第十四步 重啟Tomcat
命令:/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh
第十五步 查看對應端口
命令:lsof -i:8080
第十六步 安裝第三臺虛擬機
第十七步 創建目錄編輯動態頁面
第十八步 修改配置文件
第十九步 重啟Tomcat
第二十步 查看對應端口
第二十一步 用瀏覽器進行測試
第二十二步 第三臺虛擬機配置Tomcat
第二十三步 修改動態頁面內容
第二十四步 修改第一臺靜態頁面
第二十五步 準備一個靜態圖片
第二十六步 配置Nginx文件
第二十七步 修改配置內容
第二十八步 用瀏覽器進行測試
以上就是Nginx+Tomcat反向代理與負載均衡的實現的詳細內容,更多關于Nginx+Tomcat反向代理與負載均衡的資料請關注其它相關文章!