Nginx+Tomcat动静分离&&负载均衡

时间:2020-9-6 作者:admin


Nginx+Tomcat动静分离&&负载均衡

文章目录

1. Tomcat简介

  • 最初是由Sun的软件构架师詹姆斯·邓肯·戴维森开发
  • 安装Tomcat后,安装路径下面的目录和文件,是使用或者配置Tomcat的重要文件

2. Tomcat重要目录

  • bin :存放启动和关闭Tomcat脚本
  • conf :存放Tomcat不同的配置文件
  • doc:存放Tomcat文档
  • lib:存放Tomcat运行需要的库文件
  • logs:存放Tomcat执行时的LOG文件
  • src:存放Tomcat的源代码
  • webapps:Tomcat的主要Web发布目录
  • work:存放jsp编译后产生的class文件

3. Nginx应用

  • Nginx是一款非常优秀的HTTP服务器软件
  • 支持高达50 000个并发连接数的响应
  • 拥有强大的静态资源处理能力
  • 运行稳定
  • 内存、CPU等系统资源消耗非常低
  • 目前很多大型网站都应用Nginx服务器作为后端网站程序的反向代理及负载均衡器,提升整个站点的负载并发能力
  • 只能静态页面处理。
  • Apache可以处理动态和静态页面的处理。
  • Tomcat 支持动态页面处理。
  • Nginx负载均衡实现原理
  • Nginx实现负载均衡是通过反向代理实现

4. 反向代理原理

  • Nginx负载均衡实现原理
  • Nginx配置反向代理的主要参数
  • upstream 服务池名 { }
  • 配置后端服务器池,以提供响应数据
  • proxy_pass http://服务池名
  • 配置将访问请求转发给后端服务器池的服务器处理

5. 动静分离原理

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

6. Nginx静态处理优势

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

7. 实验要求

  • 要求部署两台后端Tomcat服务器
  • 为了进行测试,搭建两个内容不同的网站
  • Tomcat部署与网站搭建步骤
  • 关闭firewall防火墙
  • 安装JDK,配置JAVA环境
  • 安装配置Tomcat
  • 创建/web/webapp1目录,修改server.xml,将网站文件目录更改到/web/webapp1/路径下
    /web/webapp1/下建立测试页面index.jsp,并进行测试

8. 实验环境

  • 一台:Nginx 作为反向代理动静分离的静态页面 192.168.75.166
  • 一台:tomcat 作为动态页面处理的 192.168.75.134
  • 一台:tomcat 作为动态页面处理的 192.168.75.144

Nginx+Tomcat动静分离&&负载均衡

9. 实验步骤

9.1 Nginx反向代理的配置 192.168.75.166

  • Nginx服务基础
  • Nginx:稳定性高
  • 系统资源消耗低
  • 对HTTP并发连接的处理能力高(能处理高并发 活到现在的核心)
  • 单台物理服务器可支持30000~50000个并发请求
yum -y install pcre-devel zlib-devel gcc gcc-c++  pcre  make

pcre-devel : 支持正则表达式
pcre   正则表达式

zlib-devel : 压缩功能

tar zxvf nginx-1.12.2.tar.gz 
cd  nginx-1.12.2
[root@localhost nginx-1.12.2]# useradd -M -s /sbin/nologin nginx

./configure  --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make install
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/


设置Nginx系统引导启动   systemctl

在/etc/init.d 目录下新建Nginx文件为启动脚本

[root@localhost init.d]# vim nginx


#!/bin/bash
#chkconfig:-  99 20
#description:Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
case "$1" in
 start)
  $PROG
 ;;
stop)
   kill -s QUIT $(cat $PIDF)
 ;;
restart)
 $0 stop
 $0 start
 ;;
reload)
 kill -s HUP $(cat $PIDF)
 ;;
 *)
   echo "Usage:$0{start|stop|restart|reload}"
   exit 1
esac
exit 0
[root@localhost init.d]# chmod +x nginx   //添加权限

[root@localhost init.d]# chkconfig --add nginx   //添加到systemctl启动文件设置中

[root@localhost init.d]# service nginx stop   


9.2 Tomcat 1配置192.168.75.134


iptbales -F    
setenforce 0
准备JDK安装包

tar zxvf jdk-8u91-linux-x64.tar.gz -C /usr/local

 vim /etc/profile

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

 

java -version   //查看版本号


部署Tomcat


[root@promote opt]# tar zxvf apache-tomcat-9.0.16.tar.gz  -C /usr/local/
[root@promote opt]# cd /usr/local/
[root@promote local]# ls
apache-tomcat-9.0.16  etc    include  lib64    sbin   src
bin                   games  lib      libexec  share
[root@promote local]# mv apache-tomcat-9.0.16/ tomcat
[root@promote local]# cd tomcat/
[root@promote tomcat]# ll
总用量 124
drwxr-x--- 2 root root  4096 813 09:53 bin
-rw-r----- 1 root root 19203 25 2019 BUILDING.txt
drwx------ 2 root root   238 25 2019 conf
-rw-r----- 1 root root  6095 25 2019 CONTRIBUTING.md
drwxr-x--- 2 root root  4096 813 09:53 lib
-rw-r----- 1 root root 57092 25 2019 LICENSE
drwxr-x--- 2 root root     6 25 2019 logs
-rw-r----- 1 root root  2333 25 2019 NOTICE
-rw-r----- 1 root root  3255 25 2019 README.md
-rw-r----- 1 root root  6854 25 2019 RELEASE-NOTES
-rw-r----- 1 root root 16262 25 2019 RUNNING.txt
drwxr-x--- 2 root root    30 813 09:53 temp
drwxr-x--- 7 root root    81 25 2019 webapps
drwxr-x--- 2 root root     6 25 2019 work
[root@promote tomcat]# cd bin/
[root@promote bin]# ln -s /usr/local/tomcat/bin/startup.sh /usr/bin/
[root@promote bin]# ln -s /usr/local/tomcat/bin/shutdown.sh /usr/bin/

[root@promote bin]# startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/java/jdk1.8.0_201-amd64
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[root@promote bin]# netstat -natp | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      13752/java          
[root@promote bin]#     

9.3 Nginx配置

  • Nginx 处理静态图片,Tomcat处理动态图片 nginx 配置
  • 代码是动态的
  • 图片是静态的
  • 动态分离配置
  • nginx 服务器的配置 192.168.75.166
  • proxy_pass 模块功能跳转到另一个服务器

vim /usr/local/nginx/conf/nginx.conf


         location ~.*.jsp$ {
         proxy_pass http://192.168.75.134:8080;
        proxy_set_header Host $host;
}



 vim /usr/local/nginx/html/index.html 

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>静态页面</title>
<style>
body {
width: 35em;
margin: 0 auto;
font-family:Tahoma,Verdana,Arial,sans-serif;
}
</style>
</head>
<body>
<h1>静态页面</h1>
<p>这是个静态页面</p >
</body>
</html>


9.4 Tomcat 1 192.168.75.134 配置

  • Tomcat的test /indexJSP 和Nginx存放的图片路径要相同不然无法显示图片

[root@localhost bin]# mkdir /usr/local/tomcat/webapps/test

[root@localhost bin]# vim /usr/local/tomcat/webapps/test/index.jsp

<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import="java.util.Date" %>
<%@ page import="java.text.SimpleDateFormat" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/ html14/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>动态页面</title>
</head>
<body>
<div>动态页面</div>
</body>
</html>

9.5 Nginx配置 192.168.75.166

  • 图片属于静态资源,因为Nginx处理的是静态页面。所以图片应该放在Nginx目录中,但是要与Tomcat的JSP文件的路径相对应
vim /usr/local/nginx/conf/nginx.conf

location ~.*\.(gif|jpg|jpeg|png|bmg|swf|css)$ {
        root html;
        expires 30d;
        }

cd /usr/local/nginx/html

mkdir test
将图片放入 /usr/local/nginx/html/test 目录下因为需要和tomcat 1 相对应
  • Tomcat 1 192.168.75.134 配置
vim /usr/local/tomcat/webapps/test/index.jsp


<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import="java.util.Date" %>
<%@ page import="java.text.SimpleDateFormat" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/ html14/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>动态页面</title>
</head>
<body>
<div>动态页面</div>
<img src="22.jpg"width=250>   //添加
</body>
</html>

9.6 验证 图片验证动静分离

  • 访问静态页面
  • http://192.168.75.166
  • 访问动态页面
  • http://192.168.75.166/test/index.jsp

Nginx+Tomcat动静分离&&负载均衡

Nginx+Tomcat动静分离&&负载均衡

  • 图片验证动静分离

Nginx+Tomcat动静分离&&负载均衡

10 . 实验二:负载均衡

10.1 实验环境

  • Nginx 192.168.75.166 作为负载均衡服务器
  • Tomcat1 192.168.75.134
  • Tomcat 2 192.168.75.144 作为后端web服务器
  • 以Nginx作为负载均衡器,Tomcat作为应用服务器

10.2 Tomcat 2 192.168.75.144 配置

  • 安装Tomcat 服务
  • 像之前Tomcat1 一样的步骤,详情看Tomcat1
  • 因为之前Tomcat1已经部署Tomcat,所以只需要部署Tomcat2 服务器内容详情如下

mkdir -pv /web/webapp1
cd /web/webapp1
vim index.jsp

<!DOCTYPE html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import="java.util.Date" %>
<%@ page import="java.text.SimpleDateFormat" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/ html14/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>web   web   web   web   web  webb   !!!!</title>
</head>
<body>
<div>web   web   web   web   web  webb   !!!!</div>
</body>
</html>

************修改配置文件***************

 vim /usr/local/tomcat/conf/server.xml 


<Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
        <Context docBase="/web/webapp1" path="" reloadable="false">  //添加
        </Context>  //添加
        <!-- SingleSignOn valve, share authentication between web applications
             Documentation at: /docs/config/valve.html -->
        <!--
        <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
        -->

10.3 Nginx服务器配置192.168.75.166

  • 部署Nginx 详情看目录9.1

vim /usr/local/nginx/conf/nginx.conf

******在http的全局添加*******

 upstream tomcat_server {
    server 192.168.75.134:8080 weight=1;
    server 192.168.75.144:8080 weight=5;  //权重越高越优先
   }

*****在server中添加*****
 location / {
            root   html;
            index  index.html index.htm;
            proxy_pass http://tomcat_server;  //添加
        }

10.4 验证

  • 192.168.75.166

Nginx+Tomcat动静分离&&负载均衡
Nginx+Tomcat动静分离&&负载均衡

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。