文章目錄
- 一、Nginx實作負載均衡原理
- 1、Nginx靜態處理優勢
- 2、Nginx動靜分離原理
- 二、Nginx配置反向代理主要引數
- 三、實驗(圖文詳解)
- 環境配置
- ==1.部署Nginx 負載均衡器==
- ==2.部署2臺Tomcat 應用服務器==
- ==3.動靜分離配置==
- ==Tomcat Server1 配置==
- ==Tomcat Server2 配置==
- ==Nginx server 配置==
- 4.測驗效果
一、Nginx實作負載均衡原理
Nginx實作負載均衡是通過反向代理實作

如圖所示:
Nginx服務器作為前端,Tomcat服務器作為后端,web頁面請求由Nginx服務來進行轉發,
但是不是把所有的web請求轉發,而是將靜態頁面請求Nginx服務器自己來處理,動態頁面請求,轉發給后端的Tomcat服務器來處理,
據我們所知,Tomcat是屬于輕量級的應用服務器,可接受訪問量可能會不足,所以我們需要多臺Tomcat服務器,然后通過Nginx配置權重來進行挑選Tomcat服務器去進行處理,負載均衡的一種策略,
Nginx服務器
1、首頁使用精準匹配
2、靜態頁面使用正則匹配自己處理
3、動態頁面使用正則匹配jsp結尾的請求,使用proxy_pass轉發給Tomcat服務器
1、Nginx靜態處理優勢
●Nginx處理靜態頁面的效率遠高于Tomcat的處理能力
●若Tomcat的請求量為1000次,則Nginx的請求量為6000次
●Tomcat每秒的吞吐量為0.6M,Nginx的每秒吞吐量為3 .6M
●Nginx處理靜態資源的能力是Tomcat處理的6倍
2、Nginx動靜分離原理

服務端接收來自客戶端的請求中,既有靜態資源也有動態資源,靜態資源有Nginx提供服務,動態資源Nginx轉發至后端,
二、Nginx配置反向代理主要引數
配置后端服務器池,以提供回應資料
upstream 服務器名 {}
配置將訪問請求轉發給后端服務器池名
proxy_pass http://服務器名
三、實驗(圖文詳解)
1、Nginx+Tomcat負載均衡、動靜分離
2、Nginx作為負載均衡器,Tomcat作為應用服務器
3、所需安裝包
Nginx負載均衡、動靜分離安裝包
環境配置
| 主機 | 作業系統 | IP地址 | 所需軟體 |
|---|---|---|---|
| Nginx Server | CentOS7 | 192.168.184.10 | nginx-1.12.0.tar.gz |
| Tomcat Server1 | CentOS7 | 192.168.184.20 | apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm |
| Tomcat Server2 | CentOS7 | 192.168.184.30 | apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm |
1.部署Nginx 負載均衡器
建議直接使用Shell腳本一鍵部署Nginx進行安裝
理論部分請看Nginx網站服務配置,圖文詳解(超詳細)
Nginx安裝包

寫一個shell腳本將代碼復制進去,然后使用source或者. 執行腳本,等待一鍵安裝即可

#!/bin/bash
#======編譯安裝nginx服務======
#安裝所需開發包和編譯環境、編譯器
yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make
#創建程式用戶,便于準確控制訪問
useradd -M -s /sbin/nologin nginx
#解壓安裝包
cd /opt
tar zxvf nginx-1.12.0.tar.gz -C /opt/
#指定安裝路徑、指定用戶名、組名、啟用模塊以支持統計狀態
cd nginx-1.12.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-file-aio --with-http_gzip_static_module --with-http_flv_module --with-http_ssl_module
#編譯及安裝
make && make install
#軟鏈接便于系統識別nginx操作命令
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
#添加nginx系統服務
echo '[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecrReload=/bin/kill -s HUP $MAINPID
ExecrStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target' > /lib/systemd/system/nginx.service
#賦權及開啟服務、開啟開機自啟
chmod 754 /lib/systemd/system/nginx.service
systemctl start nginx.service
systemctl enable nginx.service


2.部署2臺Tomcat 應用服務器
理論部分請看Tomcat服務部署(圖文詳解)
vim tomcat.sh
#/bin/bash
#關閉防火墻
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
#安裝JDK
cd /opt
rpm -qpl jdk-8u201-linux-x64.rpm
rpm -ivh jdk-8u201-linux-x64.rpm
java -version
#設定JDK環境變數
echo 'export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
export CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export PATH=$JAVA_HOME/bin:$PATH' > /etc/profile.d/java.sh
source /etc/profile
#安裝啟動Tomcat
cd /opt
tar zxvf apache-tomcat-9.0.16.tar.gz
mv apache-tomcat-9.0.16 /usr/local/tomcat
/usr/local/tomcat/bin/startup.sh
source tomcat.sh
netstat -natp | grep 8080
java -version




3.動靜分離配置
Tomcat Server1 配置
mkdir /usr/local/tomcat/webapps/lic
vim /usr/local/tomcat/webapps/lic/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("動態頁面:短發瀟瀟暮雨");%>
</body>
</html>
vim /usr/local/tomcat/conf/server.xml
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Context docBase="/usr/local/tomcat/webapps/lic" path="" reloadable="true" />
</Host>
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh





Tomcat Server2 配置
mkdir /usr/local/tomcat/webapps/lic
vim /usr/local/tomcat/webapps/lic/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("動態頁面:長襟落落秋風");%>
</body>
</html>
vim /usr/local/tomcat/conf/server.xml
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Context docBase="/usr/local/tomcat/webapps/lic" path="" reloadable="true" />
</Host>
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh




Nginx server 配置
#準備靜態頁面和靜態圖片
echo '<html><body><h1>這是默認目錄靜態頁面</h1></body></html>' > /usr/local/nginx/html/index.html
mkdir /usr/local/nginx/html/kiki
#配置負載均衡的服務器串列,weight引數表示權重,權重越高,被分配到的概率越大
vim /usr/local/nginx/conf/nginx.conf
......
http {
......
#gzip on;
upstream tomcat_server {
server 192.168.184.20:8080 weight=1;
server 192.168.184.30:8080 weight=1;
}
server {
listen 80;
server_name www.lic.com;
charset utf-8;
#access_log logs/host.access.log main;
#配置Nginx處理動態頁面請求,將 .jsp檔案請求轉發到Tomcat 服務器處理
location ~ .*.jsp$ {
proxy_pass http://tomcat_server;
proxy_set_header HOST $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
#配置Nginx處理靜態圖片請求
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ {
root /usr/local/nginx/html/kiki;
expires 10d;
}
location / {
root html;
index index.html index.htm;
}
......





4.測驗效果
測驗靜態頁面效果
瀏覽器訪問 http://192.168.184.10/
瀏覽器訪問 http://192.168.184.10/cat.jpg


測驗負載均衡效果,不斷重繪瀏覽器測驗
瀏覽器訪問 http://192.168.184.10/lic/index.jsp


轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/250154.html
標籤:其他
上一篇:華為MDC通過網卡轉發接入外網
下一篇:Linux命令列使用技巧
