java代码-编译-打包-执行_云原生时代笔记总结

  • 楔子:可能201几年开发的时候,有个ide,加上打包插件,就可以开发了,测试的时候war包扔到服务器容器里就可以跑起来了。
    • (而且没有做过批处理的小伙伴对jar包执行可能不甚熟悉,只见过web容器的目录结构和lib中的jar包。)
    • 但是2015年之后应该是全面进入,云原生时代。大量操作需要linux命令行和shell脚本。tomcat也内嵌到spring boot中去启动。
    • Java官网去找资料可能就一个helloworld
    • 网上的博客,都是遇到才写一个单一的打包命令。内容分散,治标不治本。
    • 所以我把java编译打包执行整理在一起。,然后和spring-boot打包也比较一下。

  • 编译-打包-执行步骤总结如下:
  1. 编写Java代码
  2. 编译class文件
    • javac -d destination_folder Helloxx.java multisource/*.java source_folder2/*.java -cp imported_neededcompile_neededxx.jar
  3. 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/
  4. 执行jar包
    • 4.1 java -cp "/xxx/jarfilefolder/filexx.jar;xx/classfolder" XXMainclassname
    • 4.2 有main-class配置,直接执行jar包
      java -jar xx.jar (和-cp不能同时使用。springboot采用这种方式启动)
  5. maven普通打包,通过package指定jar或者war,然后是打包插件和compile插件里面做一些复制和排除的配置
  6. springboot比较
    • 一般都会有一个类里面有注解@SpringbootApplication,然后在这个类里面会有main方法,但是这个main方法不是最后打包出来的mainclass,mainclass一定是springboot自己的类作为入口的main-class。
    • 必须通过springboot的maven插件进行打包,然后看maven依赖中的starter是否带有web-starter,最后打包出来的虽然是jar包,但是jar里内嵌了服务器和打包出来的服务容器的目录。
    • 除了web,也可以有@CommandLineRunner的方法,springboot的maven插件打包的时候扫描代码中的注解,最后打包出来的jar也可以像上面的普通jar一样执行。

  • 结语 从sre或者运维的角度看开发经验的话,现象和原因不在一起,不能直观的看到的时候,通过多次测试和长期观察也不能确定真正的原因。
    • 如果不了解原理,也没有实际的经验,只是单纯看别人的笔记或者博客。就算是自己上手试试,也几乎是盲人摸象。所以最好把原理现象操作总结在一起。