Nginx+Tomcat实现负载均衡、动静分离的原理解析


Posted in Servers onMarch 31, 2021

一、Nginx 负载均衡实现原理

1、Nginx 实现负载均衡是通过反向代理实现

反向代理(Reverse Proxy) 是指以 代理服务器(例:Nginx) 来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器(例:Tomcat),并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器(例:Nginx)对外就表现为一个反向代理服务器。
我们从客户端的视野来看,实际上客户端并不知道真实的服务提供者是哪台服务器,它只知道它请求了反向代理服务器。因此反向代理这种方式又对外隐藏了真实服务器的地址,从一定程度上降低了安全隐患。

2、Nginx 配置反向代理的主要参数 upstream 服务池名 {}

作用:配置后端服务器池,以提供响应数据

proxy_pass http:// 服务池名

作用:配置将访问请求转发给后端服务器池的服务器处理

二、Nginx 动静分离实现原理

1、动静分离原理

服务端接收来自客户端的请求中,既有静态资源也有动态资源,静态资源由 Nginx 提供服务,动态资源由 Nginx 转发至后端。

2、Nginx 静态处理优势

Nginx 处理静态页面的效率远高于 Tomcat 的处理能力
若 Tomcat 的请求量为1000次,则 Nginx 的请求量为6000次
Tomcat 每秒的吞吐量为0.6M,Nginx 的每秒吞吐量为3.6M
Nginx 处理静态资源的能力是 Tomcat 处理的6倍

三、Nginx + Tomcat 动静分离、负载均衡配置步骤 环境准备

 

主机 操作系统 IP地址 所需软件
Nginx Server CentOS7 192.168.109.7 nginx-1.12.0.tar.gz
Tomcat Server1 CentOS7 192.168.109.22 apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm
Tomcat Server2 CentOS7 192.168.109.23 apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm

1、部署 Nginx 负载均衡服务器

Nginx+Tomcat实现负载均衡、动静分离的原理解析

#!/bin/bash
#脚本说明:编译安装nginx服务
#注意:使用前请将nginx-1.12.0.tar.gz放入/opt目录下

#关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
setenforce 0

#安装所需开发包和编译环境、编译器
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/

#编译安装nginx;指定安装路径、指定用户名、组名、启用模块以支持统计状态
cd /opt/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 restart nginx.service
systemctl enable nginx.service

Nginx+Tomcat实现负载均衡、动静分离的原理解析
Nginx+Tomcat实现负载均衡、动静分离的原理解析

2、部署两台 Tomcat 应用服务器

Nginx+Tomcat实现负载均衡、动静分离的原理解析

#!/bin/bash
#安装Tomcat服务

#关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
setenforce 0

#安装JDK
cd /opt
rpm -ivh jdk-8u201-linux-x64.rpm

#设置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

Nginx+Tomcat实现负载均衡、动静分离的原理解析

3、动静分离配置

请看tomcat

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>
</head>
<body>
<% out.println("动态页面 1:www.test1.com");%>
</body>
</html>

Nginx+Tomcat实现负载均衡、动静分离的原理解析

#修改配置文件
vim /usr/local/tomcat/conf/server.xml
<Host name="192" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
	<Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true" />
</Host>

/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh

Nginx+Tomcat实现负载均衡、动静分离的原理解析
Nginx+Tomcat实现负载均衡、动静分离的原理解析

2)Tomcat2 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 test2 page</title>
</head>
<body>
<% out.println("动态页面 1:www.test2.com");%>
</body>
</html>

Nginx+Tomcat实现负载均衡、动静分离的原理解析

#修改配置文件
vim /usr/local/tomcat/conf/server.xml
<Host name="192" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
	<Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true" />
</Host>

/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh

Nginx+Tomcat实现负载均衡、动静分离的原理解析
Nginx+Tomcat实现负载均衡、动静分离的原理解析

3)Nginx server 配置

#准备静态页面和静态图片
echo '<html><body><h1>this is static</h1></body></html>' > /usr/local/nginx/html/index.html
mkdir /usr/local/nginx/html/long
cd /usr/local/nginx/html/long

Nginx+Tomcat实现负载均衡、动静分离的原理解析

vim /usr/local/nginx/conf/nginx.conf
......
http {
......
#gzip on;

upstream tomcat_server {
  server 192.168.109.22:8080 weight=1;
  server 192.168.109.23:8080 weight=1;
}

server {
	listen 80;
	server_name www.long.com;

  #charset koi8-r;

	#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/img/;
		expires 10d;
	}
    location / {
      root html;
      index index.html index.htm;
    }


systemctl restart nginx.service

Nginx+Tomcat实现负载均衡、动静分离的原理解析
Nginx+Tomcat实现负载均衡、动静分离的原理解析

Nginx+Tomcat实现负载均衡、动静分离的原理解析

4、访问测试

测试静态页面效果
浏览器访问 http://192.168.109.7/
浏览器访问 http://192.168.109.7/long.jpg

Nginx+Tomcat实现负载均衡、动静分离的原理解析

测试负载均衡效果,不断刷新浏览器测试
浏览器访问 http://192.168.109.7/test/index.jsp

Nginx+Tomcat实现负载均衡、动静分离的原理解析
Nginx+Tomcat实现负载均衡、动静分离的原理解析

到此这篇关于Nginx+Tomcat实现负载均衡、动静分离的原理解析的文章就介绍到这了,更多相关Nginx负载均衡、动静分离内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Servers 相关文章推荐
Nginx 负载均衡是什么以及该如何配置
Mar 31 Servers
nginx搭建图片服务器的过程详解(root和alias的区别)
Mar 31 Servers
Nginx域名转发https访问的实现
Mar 31 Servers
Nginx下配置Https证书详细过程
Apr 01 Servers
nginx限制并发连接请求数的方法
Apr 01 Servers
Nginx设置HTTPS的方法步骤 443证书配置方法
Mar 21 Servers
Apache SeaTunnel实现 非CDC数据抽取
May 20 Servers
windows server 2012安装FTP并配置被动模式指定开放端口
Jun 10 Servers
Docker与K8s关系介绍不会Docker也可以使用K8s
Jun 25 Servers
Python安装及建立虚拟环境的完整步骤
Jun 25 Servers
TaiShan 200服务器安装Ubuntu 18.04的图文教程
Jun 28 Servers
VMware虚拟机安装 Windows Server 2022的详细图文教程
Sep 23 Servers
使用nginx动态转换图片大小生成缩略图
Mar 31 #Servers
Nginx反向代理多个服务器的实现方法
基于nginx实现上游服务器动态自动上下线无需reload的实现方法
为什么 Nginx 比 Apache 更牛逼
Mar 31 #Servers
Nginx的rewrite模块详解
Mar 31 #Servers
nginx常用命令放入shell脚本详解
Mar 31 #Servers
详解如何修改nginx的默认端口
You might like
PHP simple_html_dom.php+正则 采集文章代码
2009/12/24 PHP
Yii2下session跨域名共存的解决方案
2017/02/04 PHP
如何直接访问php实例对象中的private属性详解
2017/10/12 PHP
javascript dom追加内容实现示例
2013/09/21 Javascript
21个JavaScript事件(Events)属性汇总
2014/12/02 Javascript
jQuery中DOM操作实例分析
2015/01/23 Javascript
Bootstrap每天必学之面板
2015/11/30 Javascript
JQuery的attr 与 val区别
2016/06/12 Javascript
NodeJS使用七牛云存储上传文件的方法
2017/07/24 NodeJs
vue的常用组件操作方法应用分析
2018/04/13 Javascript
JavaScript笛卡尔积超简单实现算法示例
2018/07/30 Javascript
vue.js单文件组件中非父子组件的传值实例
2018/09/13 Javascript
Vue多组件仓库开发与发布详解
2019/02/28 Javascript
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
2019/06/10 jQuery
JavaScript HTML DOM元素 节点操作汇总
2019/07/29 Javascript
利用JavaScript模拟京东按键输入功能
2020/12/01 Javascript
Nodejs 微信小程序消息推送的实现
2021/01/20 NodeJs
[40:03]RNG vs VG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
基于Python数据可视化利器Matplotlib,绘图入门篇,Pyplot详解
2017/10/13 Python
python3写爬取B站视频弹幕功能
2017/12/22 Python
值得收藏的10道python 面试题
2019/04/15 Python
Tensorflow 实现释放内存
2020/02/03 Python
在pycharm中为项目导入anacodna环境的操作方法
2020/02/12 Python
django从后台返回html代码的实例
2020/03/11 Python
python如何处理程序无法打开
2020/06/16 Python
python+selenium 简易地疫情信息自动打卡签到功能的实现代码
2020/08/22 Python
字中字效果的实现【html5实例】
2016/05/03 HTML / CSS
Html5调用手机摄像头并实现人脸识别的实现
2018/12/21 HTML / CSS
全球知名的珠宝首饰品牌:Kay Jewelers
2018/02/11 全球购物
经济担保书范文
2014/04/02 职场文书
《地震中的父与子》教学反思
2014/04/10 职场文书
一年级评语大全
2014/04/23 职场文书
水污染治理工程专业自荐信
2014/06/21 职场文书
2015年幼儿园中班工作总结
2015/04/25 职场文书
幼儿园园长六一致辞
2015/07/31 职场文书
淡雅古典唯美少女娇媚宁静迷人写真
2022/03/21 杂记