打包成可执行jar包总结
近期公司有更换数据库架构的想法,计划用shardingsphere替代mycat作为数据库中间价,由于公司项目是Saas化服务,部署在k8s云服务平台上,不能以传统的war执行,需要打包成可执行jar包制作镜像,我在打包shardingsphere-proxy模块的中间遇到一些踩坑的地方,做个记录;
1.如果只是打可执行jar包,可以直接用spring-boot-maven-plugin插件,导入到start.class的模块中(注意不要放在父级POM中)
报错处理:父pom引用错误
链接:https://blog.csdn.net/qq_29166327/article/details/100097327
2.System类获取系统环境变量参数和jvm启动参数
获取当前主机的系统环境变量配置信息
public static java.util.Map<String,String> getenv() {
SecurityManager sm = getSecurityManager();
if (sm != null) {
sm.checkPermission(new RuntimePermission("getenv.*"));
}
return ProcessEnvironment.getenv();
}
getProperty获取jvm配置信息
public static String getProperty(String key) {
checkKey(key);
SecurityManager sm = getSecurityManager();
if (sm != null) {
sm.checkPropertyAccess(key);
}
return props.getProperty(key);
3.jar包下的资源文件读取只能通过InputStream 流读取,
this.getClass().getResouceAsStream(“/”)方法读取文件
4.IDEA的打包命令有bug,切换到模块路径下使用命令行进行打包编译:
mvn clean compile package install spring-boot:repackage
5.查看依赖命令:mvn dependency:tree
6.bootstrapt启动时用loaderConfiguration配置类去读取server.yaml中zk配置,但我们想做成一个VM启动参数的形式去注入,由于没有springboot依赖,所以无法用springboot的yaml引擎去解析可注入配置,我以为的方案是改造本项目的配置引擎,不过单位一个大哥跟我说,没有必要深入定制化改造这个模块,可以在读取默认配置后,再通过system类去读vm参数,替换zk地址。这样一来极大的节省了开发时间,很有用的经验;
7.最后吐槽一下maven真的bug太多了,还是gradle稳定简练;
|