jar包和war包的区别
- 一、打包成jar
- 二、打包成war包形式
首先给大家来讲一个我们遇到的一个奇怪的问题: 我们在一个springboot项目中遇到了一些问题,具体而言,我们用mvn install打包成jar后,将其运行在一台有jdk的机器上,可以直接使用java -jar 项目名.jar的方式运行,毫无问题。但是在另一台机器上,我们将打包好的war文件放入tomcat中运行时,发现端口号变成了默认的8080,而不是我们在server.port中设置的端口8090,同时我们还需要在接口地址中加上项目名。
也就是说,原先在我们的IDEA中运行时,项目接口地址为ip:8090/listall,但是在将其部署到另一台机器的tomcat中之后,接口地址就变成了ip:8080/项目名/listall。这是为什么呢?
经过我们的调查,我们发现通过jar运行实际上是启动了内置的tomcat,所以使用的是应用的配置文件中的端口;而直接部署到tomcat之后,内置的tomcat就不会启用,所以相关配置就以安装的tomcat为准,与应用的配置文件就没有关系了。
哎,现在学编程的基本都不会教历史了,也没人有兴趣去钻研,但是我们仍然需要了解这些底层知识才能更好地解决问题。
总体来说,很多年前,当时的 Sun 公司在度过了早期用 C++ 写 Html 解析器的荒蛮时期后,进入了 CGI 时代,而此时 Sun 公司决定进军这个领域。为了区别自己并显得更加高大上,公司研发出了 Servlet 标准,并搞出了最早的 JSP。同时,公司还给自己起了一个非常高大上的名称——JavaEE——即 Java 企业级应用标准。实际上,JavaEE 就是一堆服务器以 HTTP 提供服务的东西,但公司为此吹嘘不已。
既然是企业级标准,那么自然得有自己的服务器标准。于是 Servlet 标准便应运而生。以此标准实现的服务器被称为 Servlet 容器服务器。Tomcat 就是 Servlet 容器服务器的代表,并且被 Sun 公司捐献给了 Apache 基金会。当时的 Web 服务器还是一个非常高大上的概念。而当时的 Java Web 程序的标准就是 War 包(实际上就是一个 Zip 包),这就是 War 包的来源。
后来随着服务器领域的屡次进化,人们发现使用这么笨重的 Web 服务器还要实现一大堆 Servlet 之外的管理功能非常不便,因此 Jetty 推出了可以内嵌的 Servlet 服务器,并去掉了一大堆非核心功能。Tomcat 也跟进了,而传统的 JavaEE 服务器 Jboss 也推出了 Undertow 以满足市场需求。正好这个时候微服务的概念兴起,“ use Jar,not War ”,要求淘汰传统 Servlet 服务器的呼声也随之而起。
jar包和war包的区别
1、war是一个web模块,其中需要包括WEB-INF,是可以直接运行的WEB模块;jar一般只是包括一些class文件,在声明了Main_class之后是可以用java命令运行的。
2、war包是做好一个web应用后,通常是网站,打成包部署到容器中;jar包通常是开发时要引用通用类,打成包便于存放管理。
3、war是Sun提出的一种Web应用程序格式,也是许多文件的一个压缩包。这个包中的文件按一定目录结构来组织;classes目录下则包含编译好的Servlet类和Jsp或Servlet所依赖的其它类(如JavaBean)可以打包成jar放到WEB-INF下的lib目录下。
JAR文件格式以流行的ZIP文件格式为基础。与ZIP文件不同的是,JAR 文件不仅用于压缩和发布,而且还用于部署和封装库、组件和插件程序,并可被像编译器和 JVM 这样的工具直接使用。
【格式特点】:
- 安全性 可以对 JAR 文件内容加上数字化签名。这样,能够识别签名的工具就可以有选择地为您授予软件安全特权,这是其他文件做不到的,它还可以检测代码是否被篡改过。
- 减少下载时间 如果一个 applet 捆绑到一个 JAR 文件中,那么浏览器就可以在一个 HTTP 事务中下载这个 applet 的类文件和相关的资源,而不是对每一个文件打开一个新连接。
- 压缩 JAR 格式允许您压缩文件以提高存储效率。
- 传输平台扩展 Java 扩展框架(Java Extensions Framework)提供了向 Java 核心平台添加功能的方法,这些扩展是用 JAR 文件打包的(Java 3D 和 JavaMail 就是由 Sun 开发的扩展例子)。
WAR文件就是一个Web应用程序,建立WAR文件,就是把整个Web应用程序(不包括Web应用程序层次结构的根目录)压缩起来,指定一个war扩展名。
【建立的条件】:
- 需要建立正确的Web应用程序的目录层次结构。
- 建立
WEB-INF
子目录,并在该目录下建立classes与lib两个子目录。 - 将Servlet类文件放到
WEB-INF\classes
目录下,将Web应用程序所使用Java类库文件(即JAR文件)放到WEB-INF\lib
目录下。 - 将JSP页面或静态HTML页面放到上下文根路径下或其子目录下。
- 建立
META-INF
目录,并在该目录下建立context.xml
文件。
下面给大家讲讲怎么将springboot项目打包成jar和war
SpringBoot项目打包成jar很简单,也是SpringBoot的常用打包格式;本篇博客将SpringBoot打包成jar和war两种方式都记录下来;
先介绍将SpringBoot打包成jar包的方式:(以下示例是在idea中演示)
一、打包成jar
1)先new 一个Spring Starter Project
这里注意packaging默认为jar,不用修改.
2)创建完成后项目的pom如下:
3)打成jar包(通过maven命令的方式):
在Terminal窗口,使用 mvn clean package
命令打包:
然后在target目录下就能看到打包好的jar包了
二、打包成war包形式
1)可以在刚才创建的项目上做改动,首先打包成war需要一个ServletInitializer
类,这个类的位置需要和启动类在同一个文件下
如果一开始选择war包形式,会自动创建此类
2)修改pom.xml
修改pom.xml
的war将原先的jar改为war;
3)如果我们的SpringBoot是使用html作为前端页面开发没有问题,但是如果我们想用jsp开发,这个时候就需要配置一些依赖了:主要是排除SpringBoot的内置Tomcat,添加javax.servlet-api
和tomcat-servlet-api
(SpringMVC还需要配置后缀);
最后的pom.xml
如下:
因为SpringBoot默认推荐的是html,而不是jsp;经过上面的修改就可以使用jsp进行开发了;
4)打包成war:使用mvn clean package
如下:
打包成功后,就可以将war包放在tomcat下的webapps下,然后运行tomcat,启动项目了;
记录下来,以后用到的时候看 ^_^;
当然了,在创建项目的时候直接选择package为war,直接就能打成war包了
当选择war为打包方式创建项目时,ServletInitializer
是默认直接创建的
此时,pom文件如下
直接mvn clean package
就能打包成功