Nginx + Tomcat 负载均衡配置
准备两台虚拟机 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。
欢迎关注微信公众号:互联网全栈架构,收取更多有价值的信息。