欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

War包与配置文件分离

发布时间:2025/4/16 编程问答 1 豆豆
生活随笔 收集整理的这篇文章主要介绍了 War包与配置文件分离 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

2019独角兽企业重金招聘Python工程师标准>>>

背景

WAR包和配置文件分离,这应该是个老生常谈的问题了。一直没怎么深入研究。今天抽空看了下Spring Resource相关的介绍和代码。然后得出一个结论:这事很简单。

一般解决方法

一般我们都会使用properties文件,然后在xml中引用properties文件。一般用法如下:

<context:property-placeholder location="classpath:jdbc.properties"/>

就是这样,加载classpath下面的文件,很常见。 然后为了解决不同环境,配置不同的问题引入了profile的概念。Spring自身提供了Profile功能,Maven也提供了Profile功能。

二般解决方案

一般解决方案的原则就是:提前做好准备。给谁用,打谁的包。
但是,你懂的。天有不测风云,人有毫无准备。能支持临时改配置的包才是好包。
那怎么办?看这里:

<context:property-placeholder ignore-resource-not-found="true" location="classpath:jdbc.properties,/jdbc.properties,file:#{systemProperties['catalina.home']}/conf/appX.properties,file:/usr/local/appConfig/appX.properties"/>

配置解析如下:

  • ignore-resource-not-found="true" 这个配置,意思是找不到文件也不报错。只会在日志中输出一句warning。
  • classpath:jdbc.properties 都懂,不用说
  • /jdbc.properties 由于是WEB工程,这里就指的是ServletContext.getRealPath("/jdbc.properties")这个文件。场景:有些时候我们把jdbc.properties打包到了jar中,没法改。于是我们在web根目录下放一个jdbc.properties,这个文件会覆盖jar中的jdbc.properties配置。这样操作,其实还是对war有侵入的,毕竟要先解压才能放,并且重新部署很容易误删该文件。
  • file:#{systemProperties['catalina.home']}/conf/appX.properties 指的是tomcat/conf/appX.properties这个文件。好了,这次是在war外面,并且是一个相对于tomcat根目录的相对路径。只要tomcat不动,重新发布更换WAR包,毫无影响。
  • file:/usr/local/appConfig/appX.properties 这个操作更绝了。可能你部署了多个应用,想把所有程序的配置统一放置到/usr/local/appConfig目录中。这样不管更换tomcat还是更换war都毫无影响。
  • 以上配置顺序很重要。按照Spring的流程,后面文件中的配置项,会覆盖掉前面文件中的。如果后面的文件不存在,不影响大局,只要列表中任意一个存在就行。

是不是有点像Spring Boot的套路。配置文件的加载遵循一个既定的顺序,每个环节有不同的优先级。

转载于:https://my.oschina.net/huanger/blog/1830579

总结

以上是生活随笔为你收集整理的War包与配置文件分离的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。