准备两台虚拟机 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,内容:
Tomcat : 192.168.56.9
在 192.168.56.10 Tomcat 的 webapps/ROOT 目录下创建文件 a.html
Tomcat : 192.168.56.10
同时启动两台 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。
喜欢,在看