查看原文
其他

使用 Tomcat + Nginx 实现负载均衡

康熙 终码一生 2022-09-22

点击“终码一生”,关注,置顶公众号

每日技术干货,第一时间送达!



1

Tomcat 简介


  • Tomcat 是一个免费的开源的 Serlvet 容器,它是 Apache 基金会的 Jakarta 项目中的一个核心项目;
  • 由 Apache,Sun 和其它一些公司及个人共同开发而成。
  • 与传统的桌面应用程序不同,Tomcat 中的应用程序是一个 WAR(Web Archive)文件。
  • WAR 是 Sun 提出的一种 Web 应用程序格式,与 JAR 类似,也是许多文件的一个压缩包。


2

安装 Tomcat 服务


准备工作:

主机名操作系统IP地址
Tomcat-ACentOS 7.x192.168.1.1

1.安装配置 Tomcat

1)安装 JDK:下载地址(需要创建 Oracle 账号)

[root@Tomcat-A ~]# ls
anaconda-ks.cfg apache-tomcat-8.5.16.tar.gz jdk-8u91-linux-x64.tar.gz
[root@Tomcat-A ~]# tar zxf jdk-8u91-linux-x64.tar.gz
[root@Tomcat-A ~]# mv jdk1.8.0_91/ /usr/local/java
[root@Tomcat-A ~]# cat <<END >> /etc/profile
export JAVA_HOME=/usr/local/java
export PATH=$PATH:/usr/local/java/bin
END
[root@Tomcat-A ~]# source /etc/profile
[root@Tomcat-A ~]# java -version# 查看 Java 版本号


2)安装 Tomcat 软件:


[root@Tomcat-A ~]# wget https://archive.apache.org/dist/tomcat/tomcat-8/v8.5.16/bin/apache-tomcat-8.5.16.tar.gz
[root@Tomcat-A ~]# tar zxf apache-tomcat-8.5.16.tar.gz
[root@Tomcat-A ~]# mv apache-tomcat-8.5.16 /usr/local/tomcat8
[root@Tomcat-A ~]# /usr/local/tomcat8/bin/startup.sh # 启动 Tomcat
[root@Tomcat-A ~]# netstat -anpt | grep 8080 # Tomcat 的工作端口
[root@Tomcat-A ~]# netstat -anpt | grep java # 查看 Java 端口号



注解:

  • 8005端口:用 shutdown.sh 关闭 Tomcat 的时候需要用到的端口号,如果此端口没启动,Tomcat 不能用 shutdown 命令关闭。
  • 8009端口:是 Tomcat 负责和其他的 HTTP 服务器建立连接的端口,如 Nginx 和 Apache 互通时使用。(AJP/1.3 协议)
  • 8080端口:HTTP 访问时使用的端口。(HTTP/1.1 协议)

2.验证


3.配置 Java 的 Web 目录

[root@Tomcat-A ~]# mkdir -p /web/tomcat
[root@Tomcat-A ~]# echo "192.168.1.1:Tomcat-A" > /web/tomcat/index.jsp


4.修改 Tomcat 主配置文件

[root@Tomcat-A ~]# vim /usr/local/tomcat8/conf/server.xml
在148-151行添加:
<Context docBase="/web/tomcat" path="" reloadable="false">
</Context>



注解:

  • unpackWARs="true":配置自动识别 war 包。
  • autoDeploy="true":开启自动部署。
  • Context docBase="/web/tomcat":网页根目录。
  • path="":设置网页;相当于是 Nginx 中的 Location。
  • reloadble="false":不会自动重新加载 Web 应用,配置为 true 则会根据文件被改动后自动重新加载。

重启 Tomcat 服务

[root@Tomcat-A ~]# /usr/local/tomcat8/bin/shutdown.sh
[root@Tomcat-A ~]# /usr/local/tomcat8/bin/startup.sh


验证:

 


3

负载均衡


准备工作:

主机名操作系统IP地址
Tomcat-ACentOS 7.x192.168.1.1
Tomcat-BCentOS 7.x192.168.1.2
Nginx-ServerCentOS 7.x192.168.1.3

注意:

  • Tomcat-A 可以用上面配置;
  • Tomcat-B 跟 Tomcat-A 步骤一样,但页面要区分开,方便测试;

1.部署 Nginx 服务器

1)安装 Nginx 服务

[root@Nginx-Server ~]# yum -y install pcre-devel zlib-devel popt-devel openssl-devel openssl
[root@Nginx-Server ~]# wget http://www.nginx.org/download/nginx-1.18.0.tar.gz
[root@Nginx-Server ~]# ls
anaconda-ks.cfg nginx-1.18.0.tar.gz
[root@Nginx-Server ~]# tar zxf nginx-1.18.0.tar.gz -C /usr/src/
[root@Nginx-Server ~]# cd /usr/src/nginx-1.18.0/
[root@Nginx-Server nginx-1.18.0]# useradd -M -s /sbin/nologin nginx
[root@Nginx-Server nginx-1.18.0]# ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
[root@Nginx-Server nginx-1.18.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

2)配置 Nginx 主配置文件

[root@Nginx-Server ~]# vim /usr/local/nginx/conf/nginx.conf
在 32 行增加:
upstream tomcat_server {
    server 192.168.1.1:8080 weight=1;
    server 192.168.1.2:8080 weight=1;
}
在 49 行添加:
proxy_pass http://tomcat_server;



[root@Nginx-Server ~]# nginx -t# 检查 Nginx 配置文件是否正确
[root@Nginx-Server ~]# nginx# 启用 Nginx 服务
[root@Nginx-Server ~]# ps aux | grep nginx# 查看 Nginx 服务进程
[root@Nginx-Server ~]# netstat -anpt | grep nginx# 查看 Nginx 端口号和进程号


2.验证

使用浏览器访问 Nginx 服务器 IP 地址:


不断刷新页面,观察页面变化:


使用脚本查看效果:


[root@Nginx-Server ~]# for i in $(seq 10);do curl http://192.168.1.3;done



来源:blog.csdn.net/weixin_46902396/article/details/122574996

PS:防止找不到本篇文章,可以收藏点赞,方便翻阅查找哦。

往期推荐



Java 8 的 Stream 不好调试?别逗了!IDEA 调试就能轻松搞定!!

又来一个 IDEA 实用小技巧,工作效率提升不少

断言+异常处理类,代码更简洁了

7-Zip 工具遭抵制,作者来自俄罗斯!

还在用 System.currentTimeMillis() 统计代码耗时?太 Low 啦...

Redis分布式锁故障,我忍不住想爆粗...


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存