Nginx+Tomcat實作負載均衡、動靜分離集群
- 一、Nginx負載均衡原理
- 1)Nginx靜態處理優勢
- 二、Nginx動靜分離原理
- 二、Nginx配置反向代理主要引數
- 三、實驗(圖文詳解)
- 1.編譯安裝Nginx
- 2.部署2臺Tomcat 應用服務器
- 3.動靜分離配置
- 1)Tomcat Server1 配置
- 2)Tomcat Server2 配置
- 4.Nginx server 配置
- 5.驗證
一、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倍
二、Nginx動靜分離原理

服務端接收來自客戶端的請求中,既有靜態資源也有動態資源,靜態資源有Nginx提供服務,動態資源Nginx轉發至后端,
二、Nginx配置反向代理主要引數
配置后端服務器池,以提供回應資料
upstream 服務器名 {}
配置將訪問請求轉發給后端服務器池名
proxy_pass http://服務器名
三、實驗(圖文詳解)
1、Nginx+Tomcat負載均衡、動靜分離
2、Nginx作為負載均衡器,Tomcat作為應用服務器
3、所需安裝包:nginx-1.12.0.tar.gz / apache-tomcat-9.0.16.tar.gz / jdk-8u201-linux-x64.rpm
環境配置
| 主機 | 作業系統 | IP地址 | 所需軟體 |
|---|---|---|---|
| Nginx Server | CentOS7 | 192.168.190.11 | nginx-1.12.0.tar.gz |
| TomcatServer1 | CentOS7 | 192.168.190.12 | apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm |
| TomcatServer2 | CentOS7 | 192.168.190.13 | apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm |
1.編譯安裝Nginx
寫一個shell腳本將代碼復制進去,然后使用source或者. 執行腳本,等待一鍵安裝即可
#!/bin/bash
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
chmod +x tomcat.sh
./tomcat.sh
netstat -natp | grep 8080
java -version

3.動靜分離配置
1)Tomcat Server1 配置
mkdir /usr/local/tomcat/webapps/accp
vim /usr/local/tomcat/webapps/accp/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("動態頁面:this is server1");%>
</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/accp" path="" reloadable="true" />
</Host>
#重啟tomcat
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh

2)Tomcat Server2 配置
mkdir /usr/local/tomcat/webapps/accp
vim /usr/local/tomcat/webapps/accp/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("動態頁面:this is server2");%>
</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/accp" path="" reloadable="true" />
</Host>
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh

4.Nginx server 配置
#準備靜態頁面和靜態圖片
echo '<html><body><h1>這是默認目錄靜態頁面</h1></body></html>' > /usr/local/nginx/html/index.html
mkdir /usr/local/nginx/html/accp #圖片的存放目錄

#配置負載均衡的服務器串列,weight引數表示權重,權重越高,被分配到的概率越大
vim /usr/local/nginx/conf/nginx.conf
......
http {
......
#gzip on;
upstream tomcat_server { #反向代理模塊,定義后端服務器http模塊內,server模塊外添加
server 192.168.190.12:8080 weight=1;
server 192.168.190.13:8080 weight=1;
}
server {
listen 80;
server_name www.accp.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/accp;
expires 10d;
}
location / {
root html;
index index.html index.htm;
}
systemctl restart nginx.service

5.驗證


轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/281747.html
標籤:其他
