maven学习利用Profile构建不同环境的部署包.docx

上传人:小飞机 文档编号:3161342 上传时间:2023-03-11 格式:DOCX 页数:4 大小:37.90KB
返回 下载 相关 举报
maven学习利用Profile构建不同环境的部署包.docx_第1页
第1页 / 共4页
maven学习利用Profile构建不同环境的部署包.docx_第2页
第2页 / 共4页
maven学习利用Profile构建不同环境的部署包.docx_第3页
第3页 / 共4页
maven学习利用Profile构建不同环境的部署包.docx_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《maven学习利用Profile构建不同环境的部署包.docx》由会员分享,可在线阅读,更多相关《maven学习利用Profile构建不同环境的部署包.docx(4页珍藏版)》请在三一办公上搜索。

1、maven学习利用Profile构建不同环境的部署包maven学习利用Profile构建不同环境的部署包 接上回继续,项目开发好以后,通常要在多个环境部署,象我们公司多达5种环境:本机环境(local)、(开发小组内自测的)开发环境(dev)、(提供给测试团队的)测试环境(test)、预发布环境(pre)、正式生产环境(prod),每种环境都有各自的配置参数,比如:数据库连接、远程调用的ws地址等等。如果每个环境build前手动修改这些参数,显然太不fashion. maven早就考虑到了这些问题,看下面的pom片段: View Code profiles节点中,定义了二种环境:local、d

2、ev(默认激活dev环境),可以在各自的环境中添加需要的property值,接下来修改build节点,参考下面的示例: View Code resource节点是关键,它表明了哪个目录下的配置文件,需要根据profile环境来替换属性值。 通常配置文件放在resources目录下,build时该目录下的文件都自动会copy到class目录下 以上图为例,其中spring-database.xml的内容为: View Code 各属性节点的值,用占位符$属性名占位,maven在package时,会根据profile的环境自动替换这些占位符为实际属性值。 默认情况下: maven package

3、将采用默认激活的profile环境来打包,也可以手动指定环境,比如: maven package -P dev 将自动打包成dev环境的部署包(注:参数P为大写) 最后再给2个实例的运用例子: 1、开发环境与生产环境数据源采用不同方式的问题 本机开发时为了方便,很多开发人员喜欢直接用JDBC直接连接数据库,这样修改起来方便; View Code 而生产环境,通常是在webserver(比如weblogic上)配置一个JNDI数据源, View Code 如果每次发布生产前,都要手动修改,未免太原始,可以通过maven的profile来解决 先把配置文件改成 View Code 即用占位符来代替

4、bean的id,然后在pom.xml里类似下面设置 View Code 这样,mvn clean package -P local打包本地开发环境时,将生成 View Code 而打包生产环境 mvn clean package -P pro时,生成 View Code spring配置的其它跟数据库相关的bean,约定引用dataSource这个名称的bean即可 2、不同webserver环境,依赖jar包,是否打包的问题 weblogic上,允许多个app,把共用的jar包按约定打包成一个war文件,以library的方式部署,然后各应用在WEB-INF/weblogic.xml中,用类

5、似下面的形式 View Code 指定共享library 的名称即可。这样的好处是,即节省了服务器开销,而且各app打包时,就不必再重复打包这些jar文件,打包后的体积大大减少,上传起来会快很多。 而其它webserver上却未必有这个机制,一般为了方便,我们开发时,往往采用一些轻量级的webserver,比如:tomcat,jetty,jboss 之类,正式部署时才发布到weblogic下,这样带来的问题就是,本机打包时,要求这些依赖jar包,全打包到app的WEB-INF/lib下;而生产环境下,各应用的WEB-INF/lib下并不需要这些jar文件,同样还是用profile来搞定,先处理pom.xml,把依赖项改成类似下面的形式: View Code 即scope这里,用一个占位符来代替,然后profile这样配置 View Code 在maven里,如果一个依赖项的scope是provided,表示由容器提供,打包时将不会打包进最终的package里,所以这样配置后,生产环境打包时,依赖项的scope全变成了provided,即不打包进war文件,而本机环境下,因为scope是compile,所以会打包到war里

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号