Nginx+Tomcat负载均衡集群的实现示例


Posted in Servers onOctober 24, 2021

引言

通常情况下,一个 Tomcat 站点由于可能出现单点故障以及无法应付过多客户复杂多样的请求等问题,不能单独应用于生产环境中,所以需要一套更可靠的解决方案来完善 Web 站点架构。

一、案例概述

Nginx 是一款非常优秀的 http 服务器软件,它能够支持高达 50000 个并发连接数的响应,拥有强大的静态资源处理能力,运行十分的稳定,并且内存、CPU 等系统资源消耗非常低。

目前很多大型网站都应用 Nginx 服务器作为后端网站程序的反向代理及负载均衡器,来提升整个站点的负载并发能力

案例由 Nginx 作为负载均衡器,Tomcat 作为应用服务器的负载集群的设置方法,架构图如下

Nginx+Tomcat负载均衡集群的实现示例

二、环境部署

 案例环境如下

 

主机 操作系统 IP地址 主要软件
Nginx服务器 CentOS 7.4 x86_64 192.168.8.140 nginx-1.12.2.tar.gz
Tomcat服务器1 CentOS 7.4 x86_64 192.168.8.133 ①apache-tomcat-9.0.16.tar.gz / ②jdk-8u201-linux-x64.rpm
Tomcat服务器2 CentOS 7.4 x86_64 192.168.8.134 ①apache-tomcat-9.0.16.tar.gz / ② jdk-8u201-linux-x64.rpm

关闭防火墙,关闭开机自启

[root@ng133 ~]#systemctl stop firewalld.service            #关闭防火墙及开机自启功能
[root@ng133 ~]#systemctl status firewalld.service
[root@ng133 ~]#setenforce 0								#关闭安全增强系统
[root@ng133 ~]#setenforce: SELinux is disabled

三、Nginx 主机安装

安装 Nginx 服务,这里用的一键部署脚本

#!/bin/bash
iptables -F
yum -y install epel-release && yum clean all && yum makecache
yum -y install pcre-devel zlib-devel gcc gcc-c++ make wget
useradd -M -s /sbin/nologin nginx
wget http://nginx.org/download/nginx-1.12.2.tar.gz -P /opt
tar zxvf /opt/nginx-1.12.2.tar.gz -C /opt
cd /opt/nginx-1.12.2

./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module

cd /opt/nginx-1.12.2
make -j 4 && make install
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

cat > /usr/lib/systemd/system/nginx.service <<EOF
[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
EOF

chmod 754 /usr/lib/systemd/system/nginx.service
systemctl daemon-reload && systemctl start nginx.service && systemctl enable nginx.service

echo " "
pgrep "nginx" &> /dev/null
if [ $? -eq 0 ];then
        echo -e "\033[32mnginx服务运行正常,可 curl 查看\033[0m"
else
        echo -e "\033[31mnginx服务运行异常,请检查\033[0m"
fi

安装完成后查看结果

[root@ng140 /opt/nginx-1.12.2]#curl -I http://192.168.8.140
HTTP/1.1 200 OK
Server: nginx/1.12.2
Date: Fri, 15 Oct 2021 01:46:17 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Fri, 15 Oct 2021 01:45:34 GMT
Connection: keep-alive
ETag: "6168dd3e-264"
Accept-Ranges: bytes

Nginx+Tomcat负载均衡集群的实现示例

四、Tomcat 安装及配置

1. 安装 Tomcat

Tomcat 服务器1与 Tomcat 服务器2 配置方法基本相同

安装 JDK ,配置环境

[root@tm1133 ~]#cd /opt/									   #上传安装包到/opt 目录
[root@tm1133 /opt]#ls
apache-tomcat-9.0.16.tar.gz  jdk-8u201-linux-x64.rpm  
[root@tm1133 /opt]#rpm -ivh jdk-8u201-linux-x64.rpm			   #安装
[root@tomcat /opt]#vim /etc/profile.d/java.sh				   #/etc/profile.d/环境变量脚本目录	

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

[root@tm1133 /opt]#source /etc/profile.d/java.sh 			   #将脚本导入到环境变量中,使其生效
[root@tm1133 /opt]#java -version							   #查看版本
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.201-b09, mixed mode)

解包

[root@tm1133 /opt]#tar zxvf apache-tomcat-9.0.16.tar.gz  	    #解包
[root@tm1133 /opt]#mv apache-tomcat-9.0.16 /usr/local/tomcat	#转移包位置并改名

启动并优化管理 Tomcat(创建软连接,优化开启命令)

[root@tm1133 /opt]#ln -s /usr/local/tomcat/bin/startup.sh /usr/local/bin/
[root@tm1133 /opt]#ln -s /usr/local/tomcat/bin/shutdown.sh /usr/local/bin/
[root@tm1133 /opt]#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@tm1133 /opt]#netstat -antp |grep 8080					  #查看是否开启成功
tcp6       0      0 :::8080                 :::*                    LISTEN      2520/java

2. Tomcat 服务器1配置

[root@tm1133 ~]#mkdir /usr/local/tomcat/webapps/gl          			 #创建一个测试的目录
[root@tm1133 ~]#vim /usr/local/tomcat/webapps/gl/index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>     #动态页面的配置
<html> 
<head>
<title>JSP test1 page </title>
</head>
<body>
<% out.println("动态页面 1,http://www.test1.com");%>
</body>
</html>


#编辑tomcat主配置文件,添加虚拟主机配置,这里要先删掉原先的主机名等配置
[root@tm2134 /opt]#vim /usr/local/tomcat/conf/server.xml			   
-------------------------------------------------------------------------------------------------
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" 
#找到这个先删掉,否则最后会出错
-------------------------------------------------------------------------------------------------
#在行尾162行处插入下面配置,需注意结尾的</Host>
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
     <Context docBase="/usr/local/tomcat/webapps/gl" path="" reloadable="true" />
</Host>
-------------------------------------------------------------------------------------------------
[root@tm2134 /opt]#shutdown.sh		
[root@tm2134 /opt]#startup.sh			 								#重启服务

3. Tomcat 服务器2配置

[root@tm2134 /opt]#mkdir /usr/local/tomcat/webapps/gl				#创建一个测试的目录
[root@tm2134 /opt]#vim /usr/local/tomcat/webapps/gl/index.jsp			#动态页面的配置
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page </title>
</head>
<body>
<% out.println("动态页面 2,http://www.test2.com");%>
</body>
</html>


#编辑tomcat主配置文件,添加虚拟主机配置,这里要先删掉原先的主机名等配置
[root@tm2134 /opt]#vim /usr/local/tomcat/conf/server.xml			   
-------------------------------------------------------------------------------------------------
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" 
#找到这个先删掉,否则最后会出错
-------------------------------------------------------------------------------------------------
#在行尾162行处插入下面配置,需注意结尾的</Host>
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
     <Context docBase="/usr/local/tomcat/webapps/gl" path="" reloadable="true" />
</Host>
-------------------------------------------------------------------------------------------------
[root@tm2134 /opt]#shutdown.sh		
[root@tm2134 /opt]#startup.sh			 								#重启服务

五、Nginx server 配置

静态页面配置

[root@ng140 ~]#echo '<html><body><h1>this is static</h1></body></html>' > /usr/local/nginx/html/index.html
[root@ng140 ~]#cat /usr/local/nginx/html/index.html 
<html><body><h1>this is static</h1></body></html>

[root@ng140 /usr/local/nginx/html]#mkdir /usr/local/nginx/html/picture		#上传图片
[root@ng140 /usr/local/nginx/html]#cd picture/
[root@ng140 /usr/local/nginx/html/picture]#rz -E
rz waiting to receive.
[root@ng140 /usr/local/nginx/html/picture]#ls
ha.jpg
#主配置文件57行下添加下面配置参数,让页面能够加载图片
[root@ng140 /usr/local/nginx/html/picture]#vim /usr/local/nginx/conf/nginx.conf
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ {
root /usr/local/nginx/html/picture;
expires 10d;
 }
[root@ng140 /usr/local/nginx/html/picture]#nginx -t
[root@ng140 /usr/local/nginx/html/picture]#systemctl restart nginx.service

配置nginx主配置文件

[root@ng140 ~]#vim /usr/local/nginx/conf/nginx.conf
......
#配置负载均衡的服务器列表,weight参数表示权重,权重越高,被分配到的概率越大

#gzip  on;													#33行下面加入以下内容
upstream tomcat_server {
server 192.168.8.133:8080 weight=1;
server 192.168.8.134:8080 weight=1;
}  


															#45行下加入下面配置参数
 45			#access_log  logs/host.access.log  main;

 46         location ~ .*\.jsp$ {
 47         proxy_pass http://tomcat_server; 
 48         proxy_set_header HOST $host;
 49         proxy_set_header X-Real-IP $remote_addr;                
 50         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 51        }

添加参数解析

location ~ .*\.jsp$ {			
#把nginx接收到的客户端的ip地址赋值给跳转到tomcat请求中的源ip,识别客户的真实ip,并且赋值与跳转
proxy_pass http://tomcat_server; 

proxy_set_header HOST $host;	
#设定后端的web服务器接收到的请求访问的主机名(域名或ip、端口),默认host的值为proxy_pass直连设置的主机名

proxy_set_header X-Real-IP $remote_addr;		
#把$remote_addr复制给X-Real-IP(自定义),来回去源IP

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;		
#在nginx最为代理服务器时,设置的IP列表,会把经过的及其ip,代理及其ip都记录下来

检查主配置文件语法并重启服务

[root@ng140 ~]#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@ng140 ~]#systemctl restart nginx.service

六、验证结果

用火狐浏览器测试静态页面的效果

Nginx+Tomcat负载均衡集群的实现示例

Nginx+Tomcat负载均衡集群的实现示例

测试负载均衡是否生效,刷新网页可以看到在动态页面1和2之间来回切换

http://192.168.8.140/index.jsp

Nginx+Tomcat负载均衡集群的实现示例

Nginx+Tomcat负载均衡集群的实现示例

总结

可将两个或多个Tomcat server 放到 Nginx 的 upstream 中组成一个负载均衡集群,然后通过 proxy_pass 这种 Web 代理的方式在 location 中设置集群站点,然后再通过 weight 值来分别对 Tomcat server 进行权重的设置。

在生产环境中,Tomcat server 的硬件配置可能不尽相同,可以通过修改相应服务器的 weight 值,对配置较高或配置较低的服务器的访问请求进行分配控制。

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

Servers 相关文章推荐
nginx 设置多个站跨域
Mar 09 Servers
Apache压力测试工具的安装使用
Mar 31 Servers
Nginx域名转发使用场景代码实例
Mar 31 Servers
扩展多台相同的Web服务器
Apr 01 Servers
Nginx location 和 proxy_pass路径配置问题小结
Sep 04 Servers
详解Nginx 被动检查服务器的存活状态
Oct 16 Servers
iSCSI服务器CHAP双向认证配置
Apr 01 Servers
在Docker容器中部署SQL Server
Apr 11 Servers
Nginx反向代理、重定向
Apr 13 Servers
Windows server 2012搭建FTP服务器
Apr 29 Servers
服务器SVN搭建图文安装过程
Jun 21 Servers
windows server2008 开启端口的实现方法
Jun 25 Servers
Nginx反向代理学习实例教程
使用Nginx搭载rtmp直播服务器的方法
Oct 16 #Servers
详解Nginx 被动检查服务器的存活状态
Oct 16 #Servers
教你利用Nginx 服务搭建子域环境提升二维地图加载性能的步骤
Sep 25 #Servers
Nginx进程调度问题详解
解决使用了nginx获取IP地址都是127.0.0.1 的问题
Sep 25 #Servers
关于nginx 实现jira反向代理的问题
You might like
PHP COOKIE设置为浏览器进程
2009/06/21 PHP
php access 数据连接与读取保存编辑数据的实现代码
2010/05/12 PHP
thinkPHP5 ACL用户权限模块用法详解
2017/05/10 PHP
PHP实现的折半查询算法示例
2017/10/09 PHP
laravel-admin的图片删除实例
2019/09/30 PHP
动态载入/删除/更新外部 JavaScript/Css 文件的代码
2010/07/03 Javascript
基于jquery的使ListNav兼容中文首字拼音排序的实现代码
2011/07/10 Javascript
js动态生成指定行数的表格
2013/07/11 Javascript
输入自动提示搜索提示功能的使用说明:sugggestion.txt
2013/09/02 Javascript
Javascript学习笔记之 对象篇(四) : for in 循环
2014/06/24 Javascript
JavaScript函数定义的常见注意事项小结
2014/09/16 Javascript
基于jquery实现左右按钮点击的图片切换效果
2021/01/27 Javascript
JavaScript中的继承之类继承
2016/05/01 Javascript
js提交form表单,并传递参数的实现方法
2016/05/25 Javascript
将html页面保存成图片,图片写入pdf的实现方法(推荐)
2016/09/17 Javascript
canvas绘图不清晰的解决方案
2017/02/28 Javascript
微信小程序 实现动态显示和隐藏某个控件
2017/04/27 Javascript
如何对react hooks进行单元测试的方法
2019/08/14 Javascript
手把手教您实现react异步加载高阶组件
2020/04/07 Javascript
python实现获取序列中最小的几个元素
2014/09/25 Python
Python中处理字符串的相关的len()方法的使用简介
2015/05/19 Python
python生成器generator用法实例分析
2015/06/04 Python
彻底搞懂Python字符编码
2018/01/23 Python
Tensorflow 利用tf.contrib.learn建立输入函数的方法
2018/02/08 Python
Python实现随机生成手机号及正则验证手机号的方法
2018/04/25 Python
Python之列表的插入&amp;替换修改方法
2018/06/28 Python
如何理解python对象
2020/06/21 Python
用CSS3的box-reflect设置文字倒影效果的方法讲解
2016/03/07 HTML / CSS
考试退步检讨书
2014/01/15 职场文书
八项规定整改方案
2014/02/21 职场文书
《蒙娜丽莎之约》教学反思
2014/02/27 职场文书
教师三严三实学习心得体会
2014/10/11 职场文书
学校端午节活动总结
2015/02/11 职场文书
导游词之镇江-金山寺
2019/10/14 职场文书
Java9新特性之Module模块化编程示例演绎
2022/03/16 Java/Android
进行数据处理的6个 Python 代码块分享
2022/04/06 Python