Java项目打war包并部署到tomcat服务器

2024-06-22 17:32

本文主要是介绍Java项目打war包并部署到tomcat服务器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1 打war包
    • 1.1 编辑工具打war包
    • 1.2 DOS命令打war包
  • 2 部署到Tomcat服务器
    • 2.1 静态部署
    • 2.2 动态部署
    • 2.3 tomcat部署多应用
    • 2.4 补充

1 打war包

我们知道Java项目打war包可以在EclipseMyEclipse工具中自动打包,就是右键,然后导出war包就可以了,可是发现我的一个项目打war包的过程中遇到点小麻烦,导出的war包打开之后,里面少了很多东西,明显有问题。那怎么办呢,网上搜了许多偏方都没效果,请教同事,大家也没遇到过这种状况。

1.1 编辑工具打war包

附,eclipse导出war包方法:首先右击项目–export,将出现下图:
在这里插入图片描述
在框中输入war,然后选择导出位置就OK

1.2 DOS命令打war包

运用DOS命令来手工打war包:
首先,打开DOS命令行,敲入“jar”jar --help,我们发现它提示不是内部或外部的命令这样的错误,这时八成是你的JAVA环境没有配置好,我们可以用JAVA_HOME方式或者直接在Path路径里配置,等配置好,(注意JDK版本,里面有jar.exejavac.exe的版本适合)再敲入"jar"jar --help,会出现如下效果,说明配置成功。
在这里插入图片描述
下面我们用DOS命令进入到项目中,然后使用如下命令生成war
在这里插入图片描述
回车键入,等待它自动执行完:
在这里插入图片描述

OK,打包完成,现在我们来看下目录下的war包
在这里插入图片描述
已经打好了,我们放到TomcatWebapps下,启动tomcat,自动解压完成。

2 部署到Tomcat服务器

Tomcat中部署Java Web应用程序有两种方式:静态部署动态部署。在下文中$CATALINA_HOME指的是Tomcat根目录。
假如项目名为:ItSourceManage

2.1 静态部署

静态部署指的是在服务器启动之前部署我们的程序,只有当服务器启动之后,我们的Web应用程序才能访问。以下3中方式都可以部署:

  1. 项目目录拷贝到$CATALINA_HOME\webapps下,然后启动服务器就可以了。这种方式比较简单,但是web应用程序必须在webapps目录下。访问地址如下:http://localhost:8080/项目名/
  2. 这种方式可以不必将项目目录目录拷贝到webapps下,直接在F:\部署。方法如下,更改$CATALINA_HOME\conf\server.xml文件,在标签内添加标签,内容如下:
 <Context docBase="/Users/a123/Desktop/apache-tomcat-9.0.0/work/Catalina/localhost/test/sm-template-1.0.0-SNAPSHOT" path="/sm-template-1.0.0-SNAPSHOT" reloadable="false"><WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>

其中reloadable="false"表示当应用程序中的内容发生更改之后服务器不会自动加载,这个属性在开发阶段通常都设为true,方便开发,在发布阶段应该设置为false,提高应用程序的访问速度。docBase为路径,可以使用绝对路径,也可以使用相对路径,相对路径相对于webappspath属性的值是访问时的根地址。访问地址如下:http://localhost:8080/ItSource/

  1. 这种方式和第二种方式差不多,但是不是在Server.xml文件中添加Context标签,而是在$CATALINA_HOME\conf\Catalina\localhost中添加一个xml文件,如ItSource.xml,内容如下:
<?xml version='1.0' encoding='utf-8'?>
<Context docBase="/Users/a123/Desktop/apache-tomcat-9.0.0/work/Catalina/localhost/test/sm-template-1.0.0-SNAPSHOT" path="/sm-template-1.0.0-SNAPSHOT" reloadable="false"><WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>

大家可能发现和第二种方式差不多,如果缺少了path属性,这种方式服务器会使用.xml名字作为path属性的值。访问地址如下:http://localhost:8080/ItSource/
我们刚才是将ItSourceManage文件夹部署在了服务器中,我们知道可以将Web应用程序的内容打成.war包,然后在部署在服务器上。
这样在当前目录下应该有 myjspweb.war文件。
部署ItSource.war文件非常简单,将刚才有docBase="F:\ItSourceManage"更改为docBase="F:\ItSource.war"或者直接将其拷贝到webapps下也可以。重新启动服务器就可以将ItSource.war部署为一个Web应用程序了。如果你够细心的话你会发现,服务器将ItSource.war文件解开,并且在webapps下面又生成了一个ItSource文件夹,然后把ItSource.war的内容拷贝到里面去了。我们可以通过以下方式取消自动解压缩,配置方式如下:

  <Host name="localhost"  appBase="webapps"unpackWARs="false" autoDeploy="true">

2.2 动态部署

要开启Web应用的自动部署,需要配置所在的虚拟主机;配置的方式就是Host元素的deployOnStartupautoDeploy属性。如果deployOnStartupautoDeploy设置为true,则tomcat启动自动部署:当检测到新的Web应用或Web应用的更新时,会触发应用的部署(或重新部署)。二者的主要区别在于,deployOnStartuptrue时,Tomcat在启动时检查Web应用,且检测到的所有Web应用视作新应用;autoDeploytrue时,Tomcat在运行时定期检查新的Web应用或Web应用的更新。除此之外,二者的处理相似。

appBase属性指定Web应用所在的目录,默认值是webapps,这是一个相对路径,代表Tomcat根目录下webapps文件夹。
xmlBase属性指定Web应用的XML配置文件所在的目录,默认值为conf/<engine_name>/<host_name>

Tomcat按照如下的顺序进行扫描,来检查应用更新:

  • 扫描虚拟主机指定的xmlBase下的XML配置文件
  • 扫描虚拟主机指定的appBase下的WAR文件
  • 扫描虚拟主机指定的appBase下的应用目录

动态部署是指可以在服务器启动之后部署web应用程序,而不用重新启动服务器。动态部署要用到服务器提供的manager.war文件,如果在$CATALINA_HOME\webapps\下没有该文件,你必须去重新下载tomcat,否则不能完成以下的功能。要想使用该管理程序必须首先编辑$CATALINA_HOME\conf\tomcat-users.xml文件,内容如下:

<user username="tomcat" password="123456" roles="tomcat,manager-gui"/>

在浏览器中键入如下地址:http://localhost:8080/应该看到一个漂亮的加菲猫了吧。点击左边的Tomcat Manager链接,提示输入用户名和密码,本文都是coresun

Context Path(option):中输入/ItSource
XML Configration file URL中要指定一个.xml文件,比如我们在F:\下建立一个ItSource.xml文件,内容如下:
docBase不用写了,因为在下一个文本框中填入。或者更简单点,这个文本框什么都不填。
在WAR or Directory URL:中键入F:\ItSourceManage或者F:\ItSource.war都可以,然后点击Deploy按钮,看看上面是不是已经看到了你web应用程序,名字就是你Context Path(option):中的名字。
如果你部署.war文件还有更加简单的方式,下面还有个Select WAR file uploae点击浏览选择.war文件,然后点击Deploy也可以。

2.3 tomcat部署多应用

关于用tomcat部署多个应用的3种方法:

  1. 配置文件中使用多个Context元素
    这种配置好处是这些应用公用Connector,也就是说访问端口是一样的,这样就可以都部署在8080下了。这样有一个要求,就是应用程序在设计的时候就支持Context,一些链接前面都先加上动态的应用名,而不是使用“/”这样的绝对路径。Context元素的path一定不要以“/”结尾,可以是""或者"/WEB1"这样的。

  2. 配置文件中使用多个Service元素。
    这种配置可以解决应用程序不支持动态应用名的情况,使用不同端口访问不同页面。不过这样有时候也不是很顺利,由于一个tomcatjvm对一个jni类只允许load一次,你多个应用如果同时load了某个jni的类则会部署失败。这种情况可以把这个类从项目里拿出来放到tomcat安装目录的lib下作为公用的。不过还是有点麻烦

  3. 部署多个tomcat。
    这个一般是做集群的时候用的,不过你也可以用来部署多应用,只要调整下端口不冲突就行。

2.4 补充

一般常用的方法:将你的项目或把项目的war包复制到tomcat安装目录下的webapps目录,然后启动tomcattomcat目录会自动解包并部署工程。
还有两种方法也可以试试:

  1. TOMCAT_HOME\conf\Catalina\localhost下新建一个xml文件,其中内容指向你所在的工程的应用目录,然后启动tomcat,也能实现工程的发布,这样的方式对于开发调试来说非常方便,是开发过程中经常使用的方式,xml内容格式如下:
<?xml version="1.0" encoding="UTF-8"?> 
  1. 将编译后的整个工程文件夹拷贝到webapps下,然后启动tomcat
<Context path="/myapp" docBase="H:/work/projects/myapp/myappWebContext" crossContext="false" 
debug="0" reloadable="true"></Context>

这篇关于Java项目打war包并部署到tomcat服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084947

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template