当前位置: 首页 > news >正文

Java应用快速部署Tomcat指南

将Java应用部署到Apache Tomcat服务器是开发Web应用过程中常见的任务。Tomcat是一个免费且开源的Servlet容器,它为Java应用提供了运行环境。本文将介绍如何准备你的Java应用,并将其部署到Tomcat服务器上。

Java 应用部署

tomcat 的根目录结构
Tomcat中默认网站根目录是$CATALINA_BASE/webapps/
在Tomcat中部署主站应用程序和其他应用程序,和之前WEB服务程序不同
nginx
假设在nginx中部署2个网站应用eshop、forum,假设网站根目录是/data/nginx/html,那么部署可以是这样的,eshop解压缩所有文件放到 /data/nginx/html/ 目录下,forum 的文件放在 /data/nginx/html/forum/下
最终网站链接有以下对应关系

http://localhost/ 对应于eshop的应用,即 /data/nginx/html/
http://localhost/forum/ 对应于forum的应用,即/data/nginx/html/forum/

Tomcat
Tomcat中默认网站根目录是CATALINA_BASE/webapps/
在Tomcat的webapps目录中,有个非常特殊的目录ROOT,它就是网站默认根目录
将eshop解压后的文件放到这个CATALINA_BASE/webapps/ROOT中
bbs解压后文件都放在CATALINA_BASE/webapps/forum目录下$CATALINA_BASE/webapps下面的每个目录都对应一个Web应用,即WebApp
最终网站链接有以下对应关系

http://localhost/ 对应于eshop的应用WebApp,即$CATALINA_BASE/webapps/ROOT/目录,
http://localhost/forum/ 对应于forum的应用WebApp,即$CATALINA_BASE/webapps/forum/

如果同时存在CATALINA_BASE /webapps/ROOT/forum,仍以$CATALINA_BASE/webapps/forum/ 优先生效。
每一个虚拟主机都可以使用appBase指令配置自己的站点目录,使用appBase目录下的ROOT目录作为主站目录。

主页目录和编码

[root@ubuntu2404 ~]#cat /usr/local/src/tomcat/webapps/ROOT/index.html
<h1>你好</h1>
[root@ubuntu2404 ~]#curl 192.168.1.20:8080/index.html -I
HTTP/1.1 200
Accept-Ranges: bytes
ETag: W/"16-1746341360522"
Last-Modified: Sun, 04 May 2025 06:49:20 GMT
Content-Type: text/html     #tomcat无指定编码,浏览器自动识别为GBK,可能会导致乱码
Content-Length: 16
Date: Sun, 04 May 2025 06:50:04 GMT#浏览器的设置默认不是UTF-8,可能会导致乱码,下载Chart插件可解决

在这里插入图片描述
修改网页指定编码

[root@ubuntu2404 tomcat]#vim webapps/ROOT/index.html
<html>
<head>  
<meta http-equiv=Content-Type content="text/html;charset=utf-8">
<title>tomcat</title>
</head>
<h1>你好</h1>

在这里插入图片描述

JSP WebApp目录结构

CATALINA_BASE/webapps下面的每个目录对应的WebApp,可能有以下子目录,但下面子目录是非必须的

  • 主页配置:默认按以下顺序查找主页文件 index.html,index.htm、index.jsp
  • WEB-INF/:当前目录WebApp的私有资源路径,通常存储当前应用使用的web.xml和context.xml 配置文件
  • META-INF/:类似于WEB-INF,也是私有资源的配置信息,和WEB-INF/目录一样浏览器无法访问
  • classes/:类文件,当前webapp需要的类
  • lib/:当前应用依赖的jar包

主页设置

全局配置实现修改默认主页文件
默认情况下 tomcat 会在$CATALINA_BASE/webapps/ROOT/目录下按以下次序查找文件,找到第一个则进行显示
index.html
index.htm
index.jsp
可以通过修改 $CATALINA_BASE/conf/web.xml 中的下面标签内容修改默认页文件
修改默认主页文件

[root@ubuntu2404 tomcat]#pwd
/usr/local/src/tomcat
[root@ubuntu2404 tomcat]#echo '<h1>www.caoge.com</h1>' > webapps/ROOT/index.html
[root@ubuntu2404 ~]#curl 192.168.1.20:8080
<h1>www.caoge.com</h1>[root@ubuntu2404 tomcat]#cat conf/web.xml <welcome-file-list><welcome-file>index.html</welcome-file><welcome-file>index.htm</welcome-file><welcome-file>index.jsp</welcome-file></welcome-file-list></web-app>
[root@ubuntu2404 tomcat]#vim conf/web.xml<welcome-file-list><welcome-file>index.jsp</welcome-file><welcome-file>index.htm</welcome-file><welcome-file>index.html</welcome-file></welcome-file-list>
</web-app>
[root@ubuntu2404 tomcat]#systemctl restart tomcat
[root@ubuntu2404 ~]#curl 192.168.1.20:8080

WebApp的专用配置文件

将上面主配置文件conf/web.xml中的welcome-file-list标签内容,复制到/usr/local/tomcat/webapps/ROOT/WEB-INF/web.xml中,如下所示
针对主站点根目录设置专用配置文件

[root@ubuntu2404 tomcat]#vim webapps/ROOT/WEB-INF/web.xml 
<web-app xmlns="https://jakarta.ee/xml/ns/jakartaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaeehttps://jakarta.ee/xml/ns/jakartaee/web-app_6_1.xsd"version="6.1"metadata-complete="true"><display-name>Welcome to Tomcat</display-name><description><welcome-file-list><welcome-file>index.html</welcome-file>   #修改三个文件的顺序<welcome-file>index.htm</welcome-file><welcome-file>index.jsp</welcome-file></welcome-file-list></description></web-app>
#配置修改后,无需重启tomcat服务,即可观察首页变化
[root@ubuntu2404 ~]#curl 192.168.1.20:8080
<h1>www.caoge.com</h1>

配置规则
webApp的专有配置优先于系统的全局配置
修改系统的全局配置文件,需要重新启动服务生效
修改 webApp的专有配置,无需重启即可生效

应用部署实现

WebApp应用的归档格式
.war:WebApp打包,类zip格式文件,通常包括一个应用的所有资源,比如jsp,html,配置文件等
.jar:EJB类文件的打包压缩类zip格式文件,包括很多的class文件,网景公司发明
.rar:资源适配器类打包文件,目前已不常用
.ear:企业级WebApp打包,目前已不常用
传统应用开发测试后,通常打包为war格式,这种文件部署到Tomcat的webapps目录下,并默认会自动解包展开和部署上线

#conf/server.xml中文件配置
<Host name="localhost"  appBase="webapps" unpackWARs="true" autoDeploy="true">

部署方式

部署Deploy:将webapp的源文件放置到目标目录,通过web.xml和context.xml文件中配置的路径就可以访问该webapp,通过类加载器加载其特有的类和依赖的类到JVM上,即:最终用户可以通过浏览器访问该应用。
自动部署:Tomcat一旦发现多了一个web应用APP.war包,默认会自动把它解压缩,加载并启动起来。

手动部署

  • 冷部署:将webapp放到指定目录,才去启动Tomcat服务。
  • 热部署:Tomcat服务不停止,需要依赖manager、ant脚本、tcd(tomcat client deployer)等工具。

反部署 undeploy:停止webapp运行,并从JVM上清除已经加载的类,从Tomcat应用目录中移除部署的文件。
启动 start:启用 webapp 能够访问
停止 stop:禁用 webapp 不能访问,不能提供服务,但是JVM并不清除它

部署WebApp的目录结构

常见开发项目目录组成

#目录结构一般由开发用工具自动生成,以下模拟生成相关目录
mkdir projects/myapp/{WEB-INF,META-INF,classes,lib} -pv
mkdir: 已创建目录 "projects"
mkdir: 已创建目录 "projects/myapp"
mkdir: 已创建目录 "projects/myapp/WEB-INF"
mkdir: 已创建目录 "projects/myapp/META-INF"
mkdir: 已创建目录 "projects/myapp/classes"
mkdir: 已创建目录 "projects/myapp/lib"#常见应用首页,内容就用前面的test.jsp内部
vim projects/myapp/index.jsp#手动复制项目目录到webapps目录下去
cp -r projects/myapp/ /usr/local/tomcat/webapps/#注意权限和属性
chown -R tomcat:tomcat /usr/local/tomcat/webapps/myapp#访问http://YourIP:8080/myapp/

实战案例:手动的应用部署

部署主页目录下的应用WebApp

[root@ubuntu2404 tomcat]#vim webapps/ROOT/status.jsp 
<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>jsp例子</title>
</head>
<body>
后面的内容是服务器端动态生成字符串,最后拼接在一起
<%
out.println("hello jsp");
%>
<br>
<%=request.getRequestURL()%>
</body>
</html>
[root@ubuntu2404 ~]#curl 192.168.1.20:8080/status.jsp<!DOCTYPE html>
<html>
<head>
http://www.dtcms.com/a/331604.html

相关文章:

  • # 2025全球AI游戏市场研究报告:行业洞察与未来趋势
  • OpenAI 的浏览器将使用 ChatGPT Agent 来控制浏览器
  • 亚马逊FCF计划:破解高单价产品转化困局的金融杠杆
  • RH134 管理基本存储知识点
  • 考研408《计算机组成原理》复习笔记,第四章(1)——指令系统概念(指令字长、N地址指令、定长和变长操作码)
  • H.264编码格式详解:Annex-B vs AVCC
  • 14、Docker Compose 安装 Redis 集群(三主三从)
  • 嵌入式学习笔记--MCU阶段--DAY12实时操作系统rt_thread1
  • Cypher注入详解:原理、类型与测试方法
  • 使用免费API开发口播数字人
  • 数智化与全球化,双轮驱动艾芬达持续引领行业变革
  • 嵌入式 - Linux软件编程:进程
  • PIDGenRc函数中lpstrRpc的由来和InitializePidVariables函数的关系
  • 什么是期权ETF分仓的意思呢?
  • 安全加固4(K8S最小化微服务安全)
  • java-JVM详解
  • 如何安装 scikit-learn Python 库
  • Azure微软云内网接入问题
  • 大规模调用淘宝商品详情 API 的分布式请求调度实践
  • ant design vue pro 1.7.8 自定义渲染菜单,多页签,keep-alive 详细教程 vue2.x版
  • day33-LNMP
  • PostgreSQL——视图
  • 六十五、【Linux数据库】MySQL表结构 、 MySQL键值
  • 重学JS-003 --- JavaScript算法与数据结构(三)JavaScript 基础调试方法
  • Codeforces 1042 Div3(ABCDEFG)
  • 【科研日常】使用tensorflow实现自注意力机制和交叉注意力机制
  • Java中Record的应用
  • Flink Stream API 源码走读 - socketTextStream
  • Spark Shuffle机制原理
  • STM32HAL 快速入门(七):GPIO 输入之光敏传感器控制蜂鸣器