一、Nginx
1、Nginx應用
■Nginx是一款非常優秀的HTTP服務器軟體
●支持高達50 000個并發連接數的回應
●擁有強大的靜態資源處理能力
●運行穩定
●記憶體、CPU等系統資源消耗非常低
■目前很多大型網站都應用Nginx服務器作為后端網站程式的反向代理及負載均衡器,提升整個站點的負載并發能力
2、負載均衡實作原理
1、Nginx實作負載均衡是通過反向代理實作
2、反向代理原理:
反向代理(Reverse Proxy)方式是指以代理服務器來接受Internet上的連接請求,然后將請求轉發給內部網路上的服務器;
并將從服務器上得到的結果回傳給Internet上請求連接的客戶端,此時代理服務器對外就表現為一個服務器,
(Nginx服務器將請求轉發給Tomcat服務器,然后Tomcat服務器再通過Nginx服務器回傳)

3、Nginx配置反向代理的主要引數
Nginx配置反向代理的主要引數
●upstream 服務池名{ }
配置后端服務器池,以提供回應資料
●proxy_ pass http://服務池名
配置將訪問請求轉發給后端服務器池的服務器處理
4、動靜分離原理
●服務端接收來自客戶端的請求中,既有靜態資源也有動態資源,靜態資源由Nginx提供服務,動態資源Nginx轉發至后端

Nginx靜態處理優勢
●Nginx處理靜態頁面的效率遠高于Tomcat的處理能力若Tomcat的請求量為1000次,則Nginx的請求量為6000次
●Tomcat每秒的吞吐量為0.6M,Nginx的每秒吞吐量為3.6M
●Nginx處理靜態資源的能力是Tomcat處理的6倍
二、實驗部署(準備3臺服務器)
Nginx 服務器:192.168.100.6:80
Tomcat服務器1: 192.168.100.101:80
Tomcat服務器2: 192.168.100.60:8080 192.168.100.60:8081
1、部署Nginx 負載均衡器
1、關閉防火墻
systemctl stop firewalld
setenforce 0
2、安裝環境
yum -Y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make
3、添加用戶
useradd -M -s /sbin/nologin nginx
4、上傳壓縮包并解壓
cd /opt
tar zxvf nginx-1.12.0.tar.gz -C /opt/
5、編譯安裝模塊
[root@localhost opt]# cd nginx-1.12.0/
[root@localhost nginx-1.12.0]# ls
auto CHANGES CHANGES.ru conf configure contrib html LICENSE man README src
[root@localhost nginx-1.12.0]# ./configure \
> --prefix=/usr/local/nginx \
> --user=nginx \
> --group=nginx \
> --with-file-aio \ #啟用檔案修改支持
> --with-http_stub_status_module \ #啟用狀態統計
> --with-http_gzip_static_module \ #啟用gzip靜態壓縮
> --with-http_flv_module \ #啟用flv模塊, 提供對flv 視頻的偽流支持
> --with-http_ssl_module \ #啟用ssL模塊,提供ssL加密功能
> --with-stream #啟用stream模塊, 提供4層調度
make && make install
[root@localhost nginx-1.12.0]# ./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 --with-http_ssl_module --with-stream
make && make install
6、優化路徑
讓系統識別到.
[root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
7、添加 Nginx 系統服務
vim /lib/systemd/system/nginx.service
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
給與權限,開啟服務
chmod 754 /lib/systemd/system/nginx.service
systemctl start nginx.service
systemctl enable nginx.service
注:忘記創建用戶的話,服務開啟會失敗,
2、部署2臺Tomcat應用服務器
Tomcat1
1、關閉防火墻
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
2、添加環境變數
vim /etc/profile.d/java.sh
#添加下面內容
export JAVA_HOME=/usr/local/jdk1.8.0_91
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib
export PATH=$JAVA_HOME/bin:$PATH
source /etc/profile.d/java.sh
3、安裝并啟動Tomcat
將安裝包上傳到opt目錄中
cd /opt
tar apache-tomcat-9.0.16.tar.gz
mv /opt/apache-tomcat-9.0.16/ /usr/local/tomcat
啟動Tomcat
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/start.sh
驗證是否啟動成功
[root@localhost ~]# netstat -natp | grep 8080
tcp6 0 0 :::8080 :::* LISTEN 1696/java
Tomcat2
2臺實體部署:Tomcat多實體部署
3、動靜分離配置
3.1 Tomcat1 server 配置
mkdir /usr/local/tomcat/webapps/test #創建配置路徑
vim /usr/local/tomcat/webapps/test/index.jsp #創建測驗網頁
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test1 page</title> #指定為 test1 頁面
</head>
<body>
<% out.println("動態頁面 1,http://www.test1.com");%>
</body>
</html>
修改服務組態檔
vim /usr/local/tomcat/conf/server.xml
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNa mespaceAware="false">
<Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true" >
</Context>
</Host>

重新啟動Tomcat
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/start.sh
3.1 Tomcat2 server 配置
Tomcat2中的Tomcat1配置
mkdir /usr/local/tomcat/tomcat1/webapps/test /usr/local/tomcat/tomcat2/webapps/test #創建網頁目錄
[root@localhost ~]# vim /usr/local/tomcat/tomcat1/webapps/test/index.jsp #創建網頁檔案
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title> #指定為 test2 頁面
</head>
<body>
<% out.println("動態頁面 2,http://www.test2.com");%>
</body>
</html>
修改服務組態檔
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNa mespaceAware="false">
<Context docBase="/usr/local/tomcat/tomcat1/webapps/test" path="" reloadable="true" >
</Context>
</Host>

重啟Tomcat 1
/usr/local/tomcat/tomcat1/bin/shutdown.sh
/usr/local/tomcat/tomcat1/bin/startup.sh
Tomcat2中的Tomcat2配置
創建配置網頁
[root@localhost ~]# vim /usr/local/tomcat/tomcat2/webapps/test/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test3 page</title> #指定為 test3頁面
</head>
<body>
<% out.println("動態頁面 3,http://www.test3.com");%>
</body>
</html>
修改配置服務
vim /usr/local/tomcat/tomcat2/conf/server.xml
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Context docBase="/usr/local/tomcat/tomcat2/webapps/test" path="" reloadable="true" >
</Context>
</Host>

重啟Tomcat2
/usr/local/tomcat/tomcat2/bin/shutdown.sh
/usr/local/tomcat/tomcat2/bin/start.sh
三、Nginx server 配置
1、準備靜態頁面和靜態圖片
[root@localhost ~]# echo '<html><body><h1>這是靜態頁面</h1></body></html>' > /usr/local/nginx/html/index.html
[root@localhost ~]# mkdir /usr/local/nginx/html/img
[root@localhost ~]# cd /usr/local/nginx/html/img/
[root@localhost img]# ls
ganyu.png
2、nginx.conf 檔案配置
vim /usr/local/nginx/conf/nginx.conf
upstream tomcat_server {
server 192.168.100.101:8080 weight=1;
server 192.168.100.60:8080 weight=1;
server 192.168.100.60:8081 weight=1;
}
location ~* .*\.jsp$ {
proxy_pass http://tomcat_server;
proxy_set_header HOST $host;
}
location ~* .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ {
root /usr/local/nginx/html/img;
expires 1d;

檢查配置是否有誤
[root@localhost ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
重啟Nginx服務
systemctl restart nginx.service
瀏覽器驗證:
訪問Nginx主頁

訪問圖片:

訪問動態頁面(默認快取60秒,過60秒后重繪就會跳到下一個服務器)

60秒后:

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/295140.html
標籤:其他
上一篇:Vue從開發到部署
下一篇:leetcode刷題--移除元素
