Nginx+Tomcat的负载均衡动静分离群集

x33g5p2x  于2021-12-06 转载在 其他  
字(5.7k)|赞(0)|评价(0)|浏览(327)

一、Tomcat简介

最初是由Sun的软件构架师詹姆斯邓肯戴维森开发

安装Tomcat后,安装路径下面的目录和文件,是使用或者配置Tomcat的重要文件

Tomcat重要目录

bin:存放启动和关闭Tomcat脚本

conf:存放Tomcat不同的配置文件

doc:存放Tomcat文档

lib:存放Tomcat运行需要的库文件

logs:存放Tomcat执行时的log文件

src:存放tomcat的源代码

webapps:Tomcat的主要web发布目录

work:存放jsp编译后产生的class文件

Nginx应用:

Nginx是一款非常优秀的HTTP服务器软件

支持高达50000个并发连接数的响应

拥有强大的静态资源处理能力

运行稳定

内存,CPU等系统资源消耗非常低

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

二、Nginx负载均衡,动静分离原理

图解:

standalone模式,Tomcat单独运行,直接接受用户的请求,不推荐。

反向代理,单机运行,提供了一个Nginx作为反向代理,可以做到静态由nginx提供响应,动态jsp

代理给Tomcat

LNMT:Linux + Nginx + MySQL + Tomcat

LAMT:Linux + Apache(Httpd)+ MySQL + Tomcat

前置一台Nginx,给多台Tomcat实例做反向代理和负载均衡调度,Tomcat上部署的纯动态页面更

适合

LNMT:Linux + Nginx + MySQL + Tomcat

多级代理

LNNMT:Linux + Nginx + Nginx + MySQL + Tomcat

动态服务器的问题,往往就是并发能力太弱,往往需要多台动态服务器一起提供服务。如何把并发的压力分摊,这就需要调度,采用一定的调度策略,将请求分发给不同的服务器,这就是Load Balance负载均衡。

当单机Tomcat,演化出多机多级部署的时候,一个问题便凸显出来,这就是Session。而这个问题的由来,都是由于HTTP协议在设计之初没有想到未来的发展。

三、部署ngnix负载均衡器

用三台主机搭建环境:

nginx:192.168.187.160

tomcat1:192.168.187.170

tomcat2:192.168.187.180

1,安装nginx

关闭防火墙和setenforce

  1. systemctl stop firewalld.service
  2. setenforce 0

安装依赖关系包

  1. [root@localhost opt]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make

上传安装包并解压

  1. cd /opt
  2. [root@localhost opt]# rz -E
  3. rz waiting to receive.
  4. [root@localhost opt]# ls
  5. nginx-1.12.0.tar(1).gz rh
  6. [root@localhost opt]# tar zxf nginx-1.12.0.tar\(1\).gz
  7. [root@localhost opt]# ls
  8. nginx-1.12.0 nginx-1.12.0.tar(1).gz rh

进入目录进行编译安装

  1. #配置参数解释
  2. ./configure \
  3. --prefix=/usr/local/nginx \
  4. #安装路径
  5. --user=nginx \
  6. #指定用户名
  7. --group=nginx \
  8. #指定用户组
  9. --with-http_stub_status_module
  10. #启用此模块支持状态统计
  11. --with-file-aio
  12. #启用文件修改支持
  13. --with-http_gzip_static_module
  14. #启用gzip静态压缩
  15. --with-http_flv_module
  16. #启用flv模块,提供对flv视频流的支持
  17. --with-http_ssl_module
  18. #启用ssl模块,提供ssl加密功能
  19. --without
  20. #进入目录编译安装
  21. cd /opt/nginx-1.12.0
  22. ##编译
  23. ./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
  24. ##安装
  25. make && make install

新建用户以便于管理

  1. [root@localhost nginx-1.12.0]# useradd -M -s /sbin/nologin nginx

建立软链接

[root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

配置system

  1. [root@localhost nginx-1.12.0]# vim /lib/systemd/system/nginx.service
  2. 配置参数
  3. [Unit]
  4. Description=nginx
  5. After=network.target
  6. [Service]
  7. Type=forking
  8. PIDFile=/usr/local/nginx/logs/nginx.pid
  9. ExecStart=/usr/local/nginx/sbin/nginx
  10. ExecReload=/usr/bin/kill -s HUP $MAINPID
  11. ExecStop=/usr/bin/kill -s QUIT $MAINPID
  12. PrivateTmp=true
  13. [Install]
  14. WantedBy=multi-user.target

开启服务并查看

  1. ##如果之前没启动过就打这一步
  2. systemctl daemon-reload
  3. systemctl start nginx.service
  4. ss -napt | grep 80

在网页上测试nginx

2.安装部署tomcat

服务器192.168.187.170上安装配置

关闭防火墙和setenforce

  1. systemctl stop firewalld.service
  2. setenforce 0

cd /opt 将软件包拖进来

安装jdk环境

  1. rpm -ivh jdk-8u201-linux-x64.rpm

添加环境变量

  1. vim /etc/profile
  2. #加在最后一行
  3. export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
  4. export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
  5. export PATH=$JAVA_HOME/bin:$PATH
  6. #刷新配置文件
  7. source /etc/profile

解压压缩包

  1. tar zxf apache-tomcat-9.0.16.tar.gz

复制文件到指定位置

  1. cp -a apache-tomcat-9.0.16 /usr/local/tomcat

开启服务并查看

  1. /usr/local/tomcat/bin/startup.sh
  2. ss -napt |grep 8080

在网页测试

动静分离配置

  1. [root@localhost opt]# cd /usr/local/tomcat/webapps/
  2. [root@localhost webapps]# ls
  3. docs examples host-manager manager ROOT
  4. [root@localhost webapps]# mkdir test
  5. [root@localhost webapps]# vim test/index.jsp
  6. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  7. <html>
  8. <head>
  9. <title>JSP test1 page </title>
  10. </head>
  11. <body>
  12. <% out.println("动态页面1,http://www.test1.com");%>
  13. </body>
  14. </html>

修改配置文件

  1. [root@localhost webapps]# cd ..
  2. [root@localhost tomcat]# vim conf/server.xml

重新编写内容

  1. <Host name="localhost" appBase="webapps"
  2. unpackWARs="true" autoDeploy="true" xmlValidation="false"
  3. xmlNamespaceAware="false">
  4. <Context docBase="/usr/local/tomcat/webapps/test"
  5. path="" reloadable="true" />
  6. </Host>

重新加载服务

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

网页测试

同样的方法配置服务器192.168.187.180上的配置

关闭防火墙和setenforce

  1. systemctl stop firewalld.service
  2. setenforce 0

cd /opt 将软件包拖进来

安装jdk环境

  1. [root@localhost opt]# rpm -ivh jdk-8u201-linux-x64.rpm

添加环境变量

  1. [root@localhost opt]# vim /etc/profile
  2. ##在行尾插入
  3. export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
  4. export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
  5. export PATH=$JAVA_HOME/bin:$PATH
  6. [root@localhost opt]# source /etc/profile #刷新配置文件

解压压缩包

  1. [root@localhost opt]# tar zxf apache-tomcat-9.0.16.tar.gz

复制文件到指定位置

  1. cp -a apache-tomcat-9.0.16 /usr/local/tomcat

开启服务并查看

  1. /usr/local/tomcat/bin/startup.sh
  2. ss -napt |grep 8080

在网页测试

动静分离配置

  1. 进入站点准备动态网页
  2. [root@localhost opt]# cd /usr/local/tomcat/webapps/
  3. [root@localhost webapps]# ls
  4. docs examples host-manager manager ROOT
  5. [root@localhost webapps]# mkdir test
  6. [root@localhost webapps]# vim test/index.jsp
  7. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  8. <html>
  9. <head>
  10. <tile>JSP test2 page </title>
  11. </head>
  12. <boby>
  13. <% out.println("动态页面2,http://www.test2.com");%>
  14. </boby>
  15. </html>

修改配置文件

  1. [root@localhost webapps]# cd /usr/local/tomcat/conf/
  2. [root@localhost tomcat]# vim server.xml

到行尾

重新编写内容

  1. <Host name="localhost" appBase="webapps"
  2. unpackWARs="true" autoDeploy="true" xmlValidation="false"
  3. xmlNamespaceAware="false">
  4. <Context docBase="/usr/local/tomcat/webapps/test"
  5. path="" reloadable="true" />
  6. </Host>

重新加载服务

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

网页测试

3.nginx 配置

准备静态网页和图片

创建一个静态网页的文件夹

  1. [root@localhost ~]# cd /usr/local/nginx/html/
  2. mkdir test

将一个静态图片放入

创建一个静态网页

  1. vim /test.html

编辑配置文件

  1. [root@localhost test]# vim /usr/local/nginx/conf/nginx.conf

重启nginx服务

[root@localhost html]# systemctl restart nginx.service

测试网页

http://192.168.187.160/1.jpg

http://192.168.187.160/index.jsp

重新刷新网页

以上测试实现了静态网页在nginx服务上而动态网页在tomcat上,而且在tomcat上实现了负载均衡。每一次刷新都会改变一个服务器。

相关文章