Nginx + Tomcat 负载均衡与动静分离的实验部署

tech2024-11-05  7

一、Tomcat与Nginx

Nginx用于处理静态的网页并做反向代理,Tomcat处理动态的网页。 具体安装与配置文件介绍请看我之前的博客 https://blog.csdn.net/weixin_47152389/article/details/108031845 https://blog.csdn.net/weixin_47152389/article/details/107927415

二、Nginx 负载均衡原理

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

三、Nginx 动静分离原理

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

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

四、部署

实验环境: 一台Nginx服务器:192.168.130.10 两台Tomcatweb服务器:192.168.130.20 、192.168.130.30 关闭防火墙实验步骤 动静分离配置 配置Nginx服务器 [root@localhost opt]# yum -y install pcre-devel gcc gcc-c++ make zlib-devel ##安装Nginx需要的环境包 [root@localhost opt]# useradd -s -M /sbin/nologin nginx ##创建一个管理用户 [root@localhost opt]# tar zvxf nginx-1.12.0.tar.gz ##将软件包复制进opt目录下,解压到当前 [root@localhost opt]# cd nginx-1.12.0/ [root@localhost nginx-1.12.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_ststus_module [root@localhost nginx-1.12.0]# make && make install [root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin [root@localhost nginx-1.12.0]# 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 [root@localhost nginx-1.12.0]# vim /usr/local/nginx/conf/nginx.conf server { location ~.*.jsp$ { proxy_pass http://192.168.130.20:8080; proxy_set_header Host $host; } ##转换 location ~.*\.(gif|jpg|jpeg|png|bmp|swf|css)$ { root html; expires 30d; } ##处理静态网页 [root@localhost nginx-1.12.0]# 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> [root@localhost nginx-1.12.0]# cd /usr/local/nginx/html/ [root@localhost nginx-1.12.0]# mkdir test [root@localhost nginx-1.12.0]# 复制一张图片进来 [root@localhost nginx-1.12.0]# Nginx ##开启服务

Tomcat01服务器配置

[root@localhost opt]# ls apache-tomcat-8.5.16.tar.gz jdk-8u91-linux-x64.tar.gz [root@localhost opt]# tar zvxf jdk-8u91-linux-x64.tar.gz -C /usr/local [root@localhost opt]# 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 [root@localhost opt]# source /etc/profile [root@localhost opt]# tar zvxf apache-tomcat-8.5.16.tar.gz -C /usr/local [root@localhost opt]# cd /usr/local [root@localhost local]# mv apache-tomcat-8.5.16 tomcat [root@localhost local]# ln -s /usr/local/tomcat/bin/startup.sh /usr/local/bin [root@localhost local]# ln -s /usr/local/tomcat/bin/shutdown.sh /usr/local/bin [root@localhost local]# mkdir /usr/local/tomcat/webapps/test [root@localhost local]# vim /usr/local/tomcat/webapps/test/inde.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/ html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>动态网页</title> </head> <body> <div>动态网页</div><br><img src="abc.jpg"> </body> </html> [root@localhost local]# startup.sh ##开启服务

测试: 负载均衡配置: Tomcat2服务器配置

安装Tomcat服务(同1服务器相同) [root@localhost /]# mkdir -pv /web/webapp1 [root@localhost /]# vim /web/webapp1/index.jsp ##创建一个站点 <%@ page language="java" import="java.util.*" pageEncoding='UTF-8'%> <html> <head> <title>JSP test1 page</title> </head> <body> <% out.println("welcome test1 web");%> </body> </html [root@localhost web]# vim /usr/local/tomcat/conf/server.xml 150行添加 <Context docBase="/web/webapp1" path="" reloadable="false"> </Context> ##指向站点目录 [root@localhost web]# scp webapp1/index.jsp root@192.168.130.20:/web/webapp1/ ##将配置文件推送到20主机上 [root@localhost web]# startup.sh

Tomcat1服务器相同配置,将网页的test1换成test2 便于区分访问的网页 修改30主机推送过来的index.jsp配置文件即可

Nginx服务器配置

[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf #gzip on; ##此行后添加 upstream tomcat_server { server 192.168.130.20:8080 weight=1; server 192.168.130.30:8080 weight=1; } ...... location / { root html; index index.html index.htm; proxy_pass http://tomcat_server; ##添加此行 } [root@localhost ~]# killall nginx ##关闭Nginx服务 [root@localhost ~]# nginx ##开启Nginx服务

测试:打开宿主机访问192.168.130.10,并刷新页面 进行测试

最新回复(0)