java代码-编译-打包-执行_云原生时代笔记总结
cnblogs 2024-09-19 08:09:14 阅读 77
- <li>楔子:可能201几年开发的时候,有个ide,加上打包插件,就可以开发了,测试的时候war包扔到服务器容器里就可以跑起来了。
- (而且没有做过批处理的小伙伴对jar包执行可能不甚熟悉,只见过web容器的目录结构和lib中的jar包。)
- 但是2015年之后应该是全面进入,云原生时代。大量操作需要linux命令行和shell脚本。tomcat也内嵌到spring boot中去启动。
- Java官网去找资料可能就一个helloworld
- 网上的博客,都是遇到才写一个单一的打包命令。内容分散,治标不治本。
- 所以我把java编译打包执行整理在一起。,然后和spring-boot打包也比较一下。
- 编译-打包-执行步骤总结如下:
- 编写Java代码
- 编译class文件
javac -d destination_folder Helloxx.java multisource/*.java source_folder2/*.java -cp imported_neededcompile_neededxx.jar
- jar包打包或者war包
- jar包就是class文件的压缩包,然后里面会有一个MANIFEST.MF的元信息文件。可以包含或者不包含如main-class的配置。war包多了webapp类似这样名称的文件夹,给web服务器解压了之后使用,存放如web.xml的信息。
- 3.1 不指定自己的manifest
jar -cvf buildedfilexx.jar -C classfolder/xx/ .
(-C 表示不复制源文件的文件夹目录,class文件都放在一个目录下,文件夹后面都带上/。. 表示当前文件夹下的class文件 - 3.2 指定自己的manifest文
jar -cvfm buildedfile.jar my_manifest.mf classfolder/
- 执行jar包
- 4.1
java -cp "/xxx/jarfilefolder/filexx.jar;xx/classfolder" XXMainclassname
- 4.2 有main-class配置,直接执行jar包
java -jar xx.jar
(和-cp不能同时使用。springboot采用这种方式启动)
- 4.1
- maven普通打包,通过package指定jar或者war,然后是打包插件和compile插件里面做一些复制和排除的配置
- springboot比较
- 一般都会有一个类里面有注解@SpringbootApplication,然后在这个类里面会有main方法,但是这个main方法不是最后打包出来的mainclass,mainclass一定是springboot自己的类作为入口的main-class。
- 必须通过springboot的maven插件进行打包,然后看maven依赖中的starter是否带有web-starter,最后打包出来的虽然是jar包,但是jar里内嵌了服务器和打包出来的服务容器的目录。
- 除了web,也可以有@CommandLineRunner的方法,springboot的maven插件打包的时候扫描代码中的注解,最后打包出来的jar也可以像上面的普通jar一样执行。
- 结语 从sre或者运维的角度看开发经验的话,现象和原因不在一起,不能直观的看到的时候,通过多次测试和长期观察也不能确定真正的原因。
- 如果不了解原理,也没有实际的经验,只是单纯看别人的笔记或者博客。就算是自己上手试试,也几乎是盲人摸象。所以最好把原理现象操作总结在一起。
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。