Nginx + Tomcat 负载均衡配置

互联网全栈架构

共 4850字,需浏览 10分钟

 ·

2021-05-24 21:38

准备两台虚拟机 192.168.56.9 和 192.168.56.10,以下软件的安装与配置需要在两台虚拟机上都执行一遍


0x01:Nginx 安装

Nginx安装可以参考Nginx系列文章 [ Nginx源码安装 ]


0x02:Tomcat安装

Tomcat 的启动依赖 JDK 运行环境,所以安装 Tomcat 之前,先需要安装 JDK。JDK 和 Tomcat 都是绿色软件,安装非常简单,只要解压即可。

  • 解压JDK

tar -zxvf jdk-8u161-linux-x64.tar.gz 
  • 配置 JAVA_HOME 环境变量

JAVA_HOME=/usr/jdk1.8.0_161
PATH=$JAVA_HOME/bin:$PATH
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export JAVA_HOME
export PATH
export CLASSPATH

可以配置到 /etc/profile 或者 .bash_profile 文件里。

  • 获取 Tomcat

wget https://mirrors.bfsu.edu.cn/apache/tomcat/tomcat-8/v8.5.64/bin/apache-tomcat-8.5.64.tar.gz
  • 解压 Tomcat

tar -zxvf apache-tomcat-8.5.64.tar.gz
  • 启动

./bin/startup.sh
  • 验证是否启动成功

192.168.56.10 虚拟机

192.168.56.9 虚拟机



0x03:配置负载均衡

Nginx配置大致如下

#user  nobody;
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

  upstream tomcat_server {
    server 192.168.56.10:8080 weight=1;
    server 192.168.56.9:8080 weight=1;
   } 

    sendfile        on;
    #tcp_nopush     on;
    #keepalive_timeout  0;
    keepalive_timeout  65;
    #gzip  on;
   server{   
        server_name  localhost;
        listen 80;
     location / {
          proxy_set_header Host $http_host;
         proxy_set_header X-Real-IP $remote_addr;
         proxy_set_header X-Forwarded-For $remote_addr;
         proxy_pass http://tomcat_server;
     }

      #设置400,404的跳转
    #在server节点
    error_page 400 = 400.html; #跳转400页面
    error_page 404 = 404.html; #跳转404页面
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

关键配置

配置负载均衡的两台 Tomcat

配置 Nginx 反向代理


0x04:验证

这里其实只需启动一台 Nginx + 两台 Tomcat 即可。另外,多安装一台 Nginx 是为了后续讲解 keepalived 的。比如只启动 192.168.56.10 虚拟机的 Nginx。

在 192.168.56.9 Tomcat 的 webapps/ROOT 目录下创建文件 a.html,内容:

<html>
     <body>
          <h1> Tomcat : 192.168.56.9 </h1>
     </body>
</html>

在 192.168.56.10 Tomcat 的 webapps/ROOT 目录下创建文件 a.html


<html>
     <body>
          <h1>Tomcat : 192.168.56.10</h1>
     </body>
</html>

同时启动两台 Tomcat ,直接访问 Tomcat

192.168.56.9  虚拟机

192.168.56.10 虚拟机

访问192.168.56.10 的 Nginx,有可能访问到 192.168.56.9 的Tomcat,也有可能访问到 192.168.56.10 的 Tomcat

另外可以测试,关闭一台 Tomcat ,访问也是没有问题的,达到负载均衡的目的,同时实现了 Tomcat 的高可用;Nginx 没有达到高可用,下篇讲解 Nginx + keepalived。


推荐阅读:
你管这破玩意儿叫 Token?
一举拿下高可用与分布式协调系统设计!

一文读懂微内核架构


互联网全栈架构


浏览 31
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报