部署Tomcat及其负载均衡
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。一般来说,Tomcat虽然和Apache或者Nginx这些Web服务器一样,具有处理HTML页面的功能,然而由于其处理静态HTML的能力远不及Apache或者Nginx,所有Tomcat通常是作为一个Servlet和JSP容器,单独运行在后端。
1、案例实施
1.1、实施准备
1)关闭firewalld防火墙。
[root@localhost ~]# systemctl stop firewalld
2)在安装Tomcat之前必须先安装JDK。JDK 的全称是 Java Development Kit,是Sun公司免费
提供的Java语言的软件开发工具包,其中包含Java虚拟机(JVM)。编写好的Java源程序经过编译
可形成Java字节码,只要安装了JDK,就可以利用JVM解释这些字节码文件,从而保证了Java的跨平台性。
在平台兼容性方面,JDK作为解释字节码文件并据此调用操作系统API实现对应功能的 Java虚拟机,与操作系统类型和平台位数密切相关,因此存在不同类型的版本,而Tomcat也具有上述特征,默认情况下JDK已经安装,所以需要预先下载 Tomcat,本章中所使用的 Tomcat 软件的源码包为apache-tomcat-8.5.16.tar.gz。
1.2、查看JDK是否安装
运行java -version命令查看java是否安装。如果没有安装需要自行下载安装。
[root@localhost ~]# java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
1.3、安装配置Tomcat
1)解压apache-tomcat-8.5.16.tar.gz包。
[root@localhost ~]# tar xf apache-tomcat-8.5.16.tar.gz
2)解压后生成apache-tomcat-8.5-16文件夹,将该文件夹移动到/usr/local/下,并改名为tomcat8。
[root@localhost ~]# mv apache-tomcat-8.5.16/ /usr/local/tomcat8
3)启动tomcat。
[root@localhost ~]# /usr/local/tomcat8/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat8
Using CATALINA_HOME: /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
Tomcat started.
Tomcat默认运行在8080端口,运行netstat命令查看8080端口监听的信息。
[root@localhost ~]# netstat -anpt | grep 8080
tcp6 0 0 :::8080 :::* LISTEN 63339/java
4)打开浏览器访问测试:http://192.168.136.21:8080/,如果出现以下界面则表示Tomcat已经启动成功。
如果想关闭Tomcat,则运行/usr/local/tomcat8/bin/shutdown.sh命令。
1.4、Tomcat配置相关说明
tomcat的主目录为/usr/local/tomcat8/。
[root@localhost ~]# cd /usr/local/tomcat8/
[root@localhost tomcat8]# ll
总用量 92
drwxr-x--- 2 root root 4096 1月 13 14:36 bin
drwx------ 3 root root 254 1月 13 16:06 conf
drwxr-x--- 2 root root 4096 1月 13 14:36 lib
-rw-r----- 1 root root 57092 6月 22 2017 LICENSE
drwxr-x--- 2 root root 197 1月 13 14:37 logs
-rw-r----- 1 root root 1723 6月 22 2017 NOTICE
-rw-r----- 1 root root 7064 6月 22 2017 RELEASE-NOTES
-rw-r----- 1 root root 15946 6月 22 2017 RUNNING.txt
drwxr-x--- 2 root root 30 1月 13 14:36 temp
drwxr-x--- 7 root root 81 6月 22 2017 webapps
drwxr-x--- 3 root root 22 1月 13 14:37 work
1)主要目录说明。
I --- bin/:存放Windows或Linux平台上启动和关闭Tomcat的脚本文件。
I --- conf/:存放Tomcat服务器的各种全局配置文件,其中最重要的是server.xml和web.xml。
I --- lib/:存放Tomcat运行需要的库文件(JARS)。
| --- logs:存放Tomcat执行时的LOG文件。
| --- webapps:Tomcat的主要Web发布目录(包括应用程序示例)。
|-- work:存为JSP编译后产生的class 文件
2)配置文件说明。
[root@localhost tomcat8]# ll conf/
总用量 224
drwxr-x--- 3 root root 23 1月 13 14:37 Catalina
-rw------- 1 root root 13816 6月 22 2017 catalina.policy
-rw------- 1 root root 7376 6月 22 2017 catalina.properties
-rw------- 1 root root 1338 6月 22 2017 context.xml
-rw------- 1 root root 1149 6月 22 2017 jaspic-providers.xml
-rw------- 1 root root 2358 6月 22 2017 jaspic-providers.xsd
-rw------- 1 root root 3622 6月 22 2017 logging.properties
-rw------- 1 root root 7607 1月 13 16:06 server.xml
-rw------- 1 root root 2164 6月 22 2017 tomcat-users.xml
-rw------- 1 root root 2633 6月 22 2017 tomcat-users.xsd
-rw------- 1 root root 168251 6月 22 2017 web.xml
catalina.policy:权限控制配置文件。
catalina.properties:Tomcat 属性配置文件.
context.xml:上下文配置文件。
logging.properties:日志log相关配置文件。
server.xml:主配置文件。
tomcat-users.xml:manager-gui 管理用户配置文件(Tomcat安装后提供一个manager-gui的管理界面,通过配置该文件可以开启访问)。
web.xml:Tomcat的servlet,servlet-mapping.filter、MIME等相关配置。
1.5、Tomcat主配置文件说明
server.xml为Tomcat的主要配置文件,通过配置该文件,可以修改Tomcat的启动端口、网站目录、虚拟主机、开启https等重要功能。
整个server.xml由以下结构构成:< Server>、<Service>、< Connector/>、< Engine>、<Host>、<Context>、</Context>、</Host>、</Engine>、</Service>和</Server>。
其中<!-- -->内的内容是注释信息,黑色斜体部分是我们需要注意和需要经常更改的部分。
1.6、Tomcat Server的组成部分说明
1)Server
Server元素代表了整个Catalina的servlet容器
2) Service
Service 是这样一个集合:它由一个或者多个Connector,以及一个Engine(负责处理所有Connector所获得的客户请求)组成。
3) Connector
一个Connector 在某个指定端口上侦听客户请求,并将获得的请求交给Engine来处理,从Engine
处获得回应并返回客户。
Tomcat 有两个典型的 Connector,一个直接侦听来自 browser 的 http 请求,一个侦听来自其他WebServer 的请求.
Coyote Http/1.1 Connector 在端口8080处侦听来自客户browser的http请求。
Coyote JK2 Connector 在端口8009处侦听来自其他WebServer(Apache)的servlet/jsp代理请求。
4) Engine
Engine下可以配置多个虚拟主机 Virtual Host,每个虚拟主机都有一个域名。
当Engine获得一个请求时,它把该请求匹配到某个Host上,然后把该请求交给该Host来处理。
Engine有一个默认虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来
处理。
5) Host
Host 代表一个Virtual Host,即虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配。
每个虚拟主机下都可以部署(deploy)一个或者多个Web App,每个Web App对应于一个Context,
有一个Context path。
当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context 来处理,匹配的方法是“最长匹配”,所以一个path == I"的Context将成为该Host的默认Context。
所有无法和其他Context的路径名匹配的请求都将最终和该默认Context匹配。
6) Context
一个Context对应于-个Web Application,一个Web Application由一个或者多个Servlet 组成。
1.7、建立java的Web站点
1)在根目录下建立一个web目录,并在里面建立一个webapp1目录,用于存放网站文件。
[root@localhost ~]# mkdir -pv /web/webapp1
2)在webapp1目录下建立一个index.jsp的测试页面。
[root@localhost ~]# vim /web/webapp1/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html><head><title>JSP test1 page</title></head><body><% out.println("Welcom to test site,http:www.test1.com");%></body>
</html>
3)修改Tomcat的server.xml文件。
定义一个虚拟主机,并将网站文件路径指向已经建立的/web/webapp1,在host段增加context段。
[root@localhost ~]# vim /usr/local/tomcat8/conf/server.xml <Host name="localhost" appBase="webapps"unpackWARs="true" autoDeploy="true"><Context docBase="/web/webapp1" path="" reloadable="false" ></Context>
4)关闭Tomcat,再重新启动。080
[root@localhost ~]# /usr/local/tomcat8/bin/shutdown.sh
Using CATALINA_BASE: /usr/local/tomcat8
Using CATALINA_HOME: /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
[root@localhost ~]# /usr/local/tomcat8/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat8
Using CATALINA_HOME: /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
Tomcat started.
5)通过浏览器访问http://192.168.136.21:8080/,出现下图则说明该Tomcat站点已经配置成功,并且已经能够运行JSP了。
2、案例:Nginx+Tomcat负载均衡群集
2.1、Tomcat2 server配置
Tomcat2 server配置方法与tomcat1基本相同,其中包括:
1)关闭防火墙。
2)确认是否安装JDK、JAVA版本与Tomcat1 server保持一致。
3)安装配置Tomcat,版本与Tomcat1 server保持一致。
4)创建/web/webapp1目录,修改Tomcat配置文件server.xml,将网站文件目录更改到/web/webapp1/路径下。
5)在/web/webapp1/路径下建立index.jsp,为了区别测试将测试页面index.jsp的内容更改如下。
[root@localhost ~]# vim /web/webapp1/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html><head><title>JSP test2 page</title></head><body><% out.println("Welcom to test site,http:www.test2.com");%></body>
</html>
6)启动Tomcat,浏览器访问Tomcat2 server,测试http://192.168.136.22:8080/。
http {
···//省略内容#gzip on;upstream tomcat_server {server 192.168.136.21:8080 weight=1;server 192.168.136.22: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://tomcat_server;}
2.2、Nginx服务器配置
在Nginx服务器192.168.136.24上安装Nginx,反向代理两个Tomcat站点,并实现放在均衡。
1)关闭防火墙。
2)安装相关软件包。
[root@localhost ~]# yum -y install pcre-devel zlib-devel openssl-devel
3)解压并安装Nginx。
[root@localhost ~]# groupadd www
[root@localhost ~]# useradd -g www www -s /bin/false
[root@localhost ~]# tar xf nginx-1.12.0.tar.gz
[root@localhost ~]# cd nginx-1.12.0/
[root@localhost nginx-1.12.0]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-file-aio --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module
[root@localhost nginx-1.12.0]# make
[root@localhost nginx-1.12.0]# make install
4)配置nginx.conf。
http {
···//省略内容#gzip on;upstream tomcat_server { //配置负载均衡组server 192.168.136.21:8080 weight=1;server 192.168.136.22: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://tomcat_server; //加上此配置代理设定好的tomcat_server负载均衡组}
5)测试Nginx配置文件是否正确。
[root@localhost ~]# /usr/local/nginx/sbin/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
6)启动Nginx服务。
[root@localhost ~]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
7)查看Nginx服务进程。
[root@localhost ~]# ps aux | grep nginx
root 10476 0.0 0.0 20548 612 ? Ss 15:16 0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
www 10477 0.0 0.1 23080 1640 ? S 15:16 0:00 nginx: worker process
root 69146 0.0 0.0 112724 988 pts/0 S+ 16:56 0:00 grep --color=auto nginx
8)查看端口号及PID进程号。
[root@localhost ~]# netstat -anpt | grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 10476/nginx: master
2.3、测试负载均衡效果
1)打开浏览器访问:http://192.168.136.24/
2)不断刷新浏览器测试,可以看到由于权重相同,页面会反复在以下两个页面来回切换。
第一次访问,出现test1的测试页面;刷新后,第二次访问,则会出现test2的测试页面。这说明负载均衡群集搭建成功,已经可以在两个Tomcat server站点进行切换了。
相关文章:

部署Tomcat及其负载均衡
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。一般来说,Tomcat虽然和Apache或者Nginx这些Web服务器一样…...
C++ 类、结构体
C 类、结构体 类可以将变量、数组和函数完美地打包在一起。 类与结构体 类的定义: class Person {private:int age,height;double money;string books[100];public:string name;void say(){cout<<"Im"<<name<<endl;}int get_age(){…...

数据结构(三)堆和哈希表
目录 哈希表和堆什么是哈希表 ?什么是堆 ?什么是图 ?案例一:使用python实现最小堆案例二 : 如何用Python通过哈希表的方式完成商品库存管理闯关题 (包含案例三:python实现哈希表) 本…...

李宏毅LLM——ChatGPT原理剖析
文章目录 Chat-GPT引言关键技术——预训练研究问题玩文字冒险游戏 ChatGPT原理剖析 Chat-GPT引言 直观感受:结果有模有样、每次输出结果都不同、可以追问、幻想出的答案误解:罐头回答、答案是网络搜索的结果真正做的事:文字接龙,…...
让Windows上vscode的C语言scanf函数可以读取中文字符
windows的默认字符集保存为GBK不要修改 区域设置–时钟和区域–区域–管理–更系统区域设置–(不要勾选)使用UTF-8。 查看验证当前字符集: cmdchcp 活动代码页: 936936就是简体中文GBK vscode的setting.json文件添加如下代码 点击左下角…...

Linux命令(3)
一. tr 对字符进行处理: tr 命令用于字符转换、替换和删除,主要用于删除文件中的控制符或进行字符串转换等。 将a转换成1 将小写字母转换成大写 压缩: tr -s 将a压缩成一个a 将空格压缩成一个 删除: tr -d 补集: 用字符串中的字符集的补…...
安卓MediaRecorder(3)音频采集编码写入详细源码分析
文章目录 前言音频采集音频初始化AudioRecord 分析AudioSource 采集到音频 音频编码音频编码后数据处理MPEG4Writer写入音频编码后数据到文件MPEG4Writer::Track 取编码后的音频编数据结语 本文首发地址 https://blog.csdn.net/CSqingchen/article/details/134896808 最新更新地…...
2024年网络安全竞赛—网络安全事件分析应急响应解析(包含FLAG)
网络安全事件分析应急响应 目录 网络安全事件分析应急响应 解析如下:...

FineBI实战项目一(22):各省份订单个数及订单总额分析开发
点击新建组件,创建各省份订单个数及订单总额组件。 选择自定义图表,将province拖拽到横轴,将cnt和total拖拽到纵轴。 调节纵轴的为指标并列。 修改横轴和纵轴的标题。 修改柱状图样式: 将组件拖拽到仪表板。 结果如下:…...
2024.1.16 调用tinyspline样条曲线拟合库时报 stack smashing detected,CMakeLists.txt中屏蔽该异常
在函数中调用第三方库api拟合样条曲线,函数中一切正常,可以打印所有数组变量,重复执行该函数,某一次函数return时报 stack smashing deteced (unknown) ,原因可能是第三方库内部的函数有栈溢出风…...

Leetcode202快乐数(java实现)
今天分享的题目是快乐数: 快乐数的定义如下: 快乐数(Happy Number)是指一个正整数,将其替换为各个位上数字的平方和,重复这个过程直到最后得到的结果为1,或者无限循环但不包含1。如果最终结果为…...
50天精通Golang(第13天)
反射reflect 一、引入 先看官方Doc中Rob Pike给出的关于反射的定义: Reflection in computing is the ability of a program to examine its own structure, particularly through types; it’s a form of metaprogramming. It’s also a great source of confus…...
大数据 - Doris系列《三》- 数据表设计之表的基本概念
目录 🐶3.1 字段类型 🐶3.2 表的基本概念 3.2.1 Row & Column 3.2.2 分区与分桶 🥙3.2.2.1 Partition 1. Range 分区 2. List 分区 进阶:复合分区与单分区的选择 3.2.3 PROPERTIES 🥙3.2.3.1 分片副本数 …...
数据库mysql no.3
1.排序查询 order by 排序列表 【asc/desc】 排序列表:可以是单个字段、多个字段、表达式、函数、别名。 asc 升序 desc 降序 如果没有写那就是默认升序 2.常见函数 select 函数名(); 定义:函…...

数据结构实战:变位词侦测
文章目录 一、实战概述二、实战步骤(一)逐个比较法1、编写源程序2、代码解释说明(1)函数逻辑解释(2)主程序部分 3、运行程序,查看结果4、计算时间复杂度 (二)排序比较法1…...

C++核心编程之类和对象---C++面向对象的三大特性--多态
目录 一、多态 1. 多态的概念 2.多态的分类: 1. 静态多态: 2. 动态多态: 3.静态多态和动态多态的区别: 4.动态多态需要满足的条件: 4.1重写的概念: 4.2动态多态的调用: 二、多态 三、多…...

基于PyQT的图片批处理系统
项目背景: 随着数字摄影技术的普及,人们拍摄和处理大量图片的需求也越来越高。为了提高效率,开发一个基于 PyQt 的图片批处理系统是很有意义的。该系统可以提供一系列图像增强、滤波、水印、翻转、放大缩小、旋转等功能,使用户能够…...
vscode文件配置
lanuch.json {"version": "0.2.0","configurations": [{"name": "(gdb) 启动","type": "cppdbg","request": "launch",// "program": "输入程序名称,例…...

C++学习笔记——SLT六大组件及头文件
目录 一、C中STL(Standard Template Library) 二、 Gun源代码开发精神 三、 实现版本 四、GNU C库的头文件分布 bits目录 ext目录 backward目录 iostream目录 stdexcept目录 string目录 上一篇文章: C标准模板库(STL&am…...

Spring之AOP源码(二)
书接上文 文章目录 一、简介1. 前文回顾2. 知识点补充 二、ProxyFactory源码分析1. ProxyFactory2. JdkDynamicAopProxy3. ObjenesisCglibAopProxy 三、 Spring AOP源码分析 一、简介 1. 前文回顾 前面我们已经介绍了AOP的基本使用方法以及基本原理,但是还没有涉…...
vscode里如何用git
打开vs终端执行如下: 1 初始化 Git 仓库(如果尚未初始化) git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

C++实现分布式网络通信框架RPC(3)--rpc调用端
目录 一、前言 二、UserServiceRpc_Stub 三、 CallMethod方法的重写 头文件 实现 四、rpc调用端的调用 实现 五、 google::protobuf::RpcController *controller 头文件 实现 六、总结 一、前言 在前边的文章中,我们已经大致实现了rpc服务端的各项功能代…...
椭圆曲线密码学(ECC)
一、ECC算法概述 椭圆曲线密码学(Elliptic Curve Cryptography)是基于椭圆曲线数学理论的公钥密码系统,由Neal Koblitz和Victor Miller在1985年独立提出。相比RSA,ECC在相同安全强度下密钥更短(256位ECC ≈ 3072位RSA…...

从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...

家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...

Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...

Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...
Rapidio门铃消息FIFO溢出机制
关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系,以下是深入解析: 门铃FIFO溢出的本质 在RapidIO系统中,门铃消息FIFO是硬件控制器内部的缓冲区,用于临时存储接收到的门铃消息(Doorbell Message)。…...

Springboot社区养老保险系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...