Linux系统架构-----Nginx与Tomcat实现负载均衡群集

一.实验分析

  • 通常,一个tomcat站点由于可能出现单点故障以及无法应付过多的客户复杂多样的请求等问题,不能单独应用于生产环境下,所以我们需要一套更可靠的解决方案来完善web站点架构
  • Nginx是一款性能优越的http服务器软件,它能够支持高达50000个并发连接数的响应,拥有强大的静态资源处理能力,运行稳定,并且内存、CPU等系统资源消耗非常低。目前很多大型网站都应用Nginx服务器作为后端网站程序的反向代理以及负载均衡器,来提升整个站点的负载并发能力

二.网络拓扑图以及实验环境

Linux系统架构-----Nginx与Tomcat实现负载均衡群集_第1张图片

类型 IP地址 系统 软件包
Nginx服务器 192.168.43.104

centos7

 nginx-1.12.2.tar.gz
Tomcat服务器1 192.168.43.102

apache-tomcat-8.5.50.tar.gz

jdk-8u231-linux-x64.tar.gz

Tomcat服务器2 192.168.43.103
客户机 192.168.43.101  

三.具体操作步骤以及验证

  • Tomcat服务器的配置
一.第一台Tomcat服务器配置
1.解压jdk的压缩包
tar xzvf jdk-8u231-linux-x64.tar.gz -C /usr/local
2.配置JAVA环境变量
vim /etc/profile  //追加到末尾
export JAVA_HOME=/usr/local/jdk1.8.0_231
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
3.加载JAVA环境变量
source /etc/profile
4.解压tomcat软件包
tar xzvf apache-tomcat-8.5.50.tar.gz -C /usr/local
5.修改目录名,便于操作
cd /usr/local
mv apache-tomcat-8.5.50/ tomcat/
6.创建软链接,优化服务控制方式
ln -s /usr/local/tomcat/bin/startup.sh /usr/local/bin/
ln -s /usr/local/tomcat/bin/shutdown.sh /usr/local/bin/
7.创建web站点,编辑站点内容
 mkdir -pv /web/webapp1
 vim index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

 
  JSP test1 page
 
 
  <% out.println("Welcome Tomcat 01");%>
 

~      
8.修改Tomcat的server.xml文件,定义一个虚拟主机,并且将网站文件路径指向已经建立的/web/webapp1,在hos段增加context段
[root@localhost ~]# vim /usr/local/tomcat/conf/server.xml
      
        
        

9.关闭安全性功能,开启服务
startup.sh 
systemctl stop firewalld
setenforce 0

二.第二台Tomcat服务器的配置
1.解压jdk的压缩包
tar xzvf jdk-8u231-linux-x64.tar.gz -C /usr/local
2.配置JAVA环境变量
vim /etc/profile  //追加到末尾
export JAVA_HOME=/usr/local/jdk1.8.0_231
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
3.加载JAVA环境变量
source /etc/profile
4.解压tomcat软件包
tar xzvf apache-tomcat-8.5.50.tar.gz -C /usr/local
5.修改目录名,便于操作
cd /usr/local
mv apache-tomcat-8.5.50/ tomcat/
6.创建软链接,优化服务控制方式
ln -s /usr/local/tomcat/bin/startup.sh /usr/local/bin/
ln -s /usr/local/tomcat/bin/shutdown.sh /usr/local/bin/
7.创建web站点,编辑站点内容
 mkdir -pv /web/webapp1
 vim index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

 
  JSP test1 page
 
 
  <% out.println("Welcome Tomcat 02");%>
 

~      
8.修改Tomcat的server.xml文件,定义一个虚拟主机,并且将网站文件路径指向已经建立的/web/webapp1,在hos段增加context段
[root@localhost ~]# vim /usr/local/tomcat/conf/server.xml
      
        
        

9.关闭安全性功能,开启服务
startup.sh 
systemctl stop firewalld
setenforce 0
  • Nginx服务器的配置
1.解压软件包
tar xzvf nginx-1.12.2.tar.gz -C /opt
2.下载相关软件包
yum install pcre-devel zlib-devel gcc gcc-c++ make -y
3.创建nginx的用户
useradd -M -s /sbin/nologin nginx
4.编译安装nginx
cd /opt/nginx-1.12.2/
./configure \
--prefix=/usr/local/nginx \
--user=nginx --group=nginx \
--with-http_stub_status_module \    //启用状态统计
--with-http_gzip_static_module \    //启用gzip静态压缩
--with-http_flv_module     //启用flv模块,提供寻求内存使用基于时间的偏移量文件

make && make install

4.编辑nginx的主配置文件
vim /usr/local/nginx/conf/nginx.conf
 #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
    upstream tomcatserver {              //upstream函数,配置tomcat服务器池
        server 192.168.43.102:8080 weight=1;   //weight代表权重
        server 192.168.43.103:8080 weight=1;
        }

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass http://tomcatserver;    //反向代理到设置的tomcat服务器池
        }

5.优化服务控制方式
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin

6.检查语法,是否配置正确
[root@localhost ~]# 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 ~]# 

7.关闭安全性功能,开启nginx服务
systemctl stop firewalld
setenforce 0
nginx
  • 验证群集功能

Linux系统架构-----Nginx与Tomcat实现负载均衡群集_第2张图片

​​Linux系统架构-----Nginx与Tomcat实现负载均衡群集_第3张图片

注:通常,现网中的nginx与tomcat的群集,会有Nginx与keepalived的双机热备,还有tomcat与nginx动静分离

 

 

 

 

你可能感兴趣的:(群集,Linux系统架构)