展开全部
其实也是最近才看Maven, 以前都是用ant+ivy, 对于轻量级的项目来说足够了32313133353236313431303231363533e4b893e5b19e31333335343966, 而且非常灵活.
看了看Maven, 约定.... 现在编程都说约定, 约定是挺好, 问题是超出约定的事情太多了, 到头来还要依赖其他东西, 真不想用maven啊.
以前我们开发环境和生产环境的配置文件都是单独分开目录存放的, ant脚本搞个变量就自动打包不同的文件了. 我觉得管理起来也很容易, 所以看到很多maven为解决开发/生产环境的方案真是不太理解啊:
1. 什么 ${your.configuration}, 和spring的东西都差不多了, 配置写到脚本里去了,....这叫啥配置...
2. 调用ant....
还是根据我以前的思路:
src/main目录下原来有 java, resources, 我新建几个目录: resources-dev, resources-test, resources-prod.
resources --- 一些共享的配置文件, 一般不需要修改的
resources-dev --- 开发环境下用的配置文件, 和resources目录下文件没有重合.
resources-prod --- 生产环境下用的配置文件, 和resources目录下文件没有重合.
本机开发的时候设置源码目录为 java, resources, resources-dev, 可以直接开发调试.
编译的时候希望maven根据不同环境, 打包不同的目录下的文件, 我们利用maven的profile和build-helper-maven-plugin插件就可以实现.
dev
org.codehaus.mojo
build-helper-maven-plugin
1.5
add-resource
generate-resources
add-resource
src/main/resources_dev
maven-war-plugin
package
war
dev
test
org.codehaus.mojo
build-helper-maven-plugin
1.5
add-resource
generate-resources
add-resource
src/main/resources_test
org.apache.maven.plugins
maven-war-plugin
package
war
test
(文章后面有简化版本)
自己根据实际的部署环境修改吧, 运行 mvn package -P test 就可以打包了.
反正很简单啦. 一大堆xml, 有用的没几句....太罗嗦了
另:目前开发用resin, intellij idea 9, 调试时webapp在开发目录webapp下就地开发, 所以我的maven脚本还有如下部分:
org.apache.maven.plugins
maven-war-plugin
2.1
WEB-INF/lib/**,WEB-INF/classes/**,WEB-INF/work/**,WEB-INF/tmp/**
false
这部分是公用的, 当然dev时候也不用打包.... 所以........ 可以用于本机开发, 打包到test, production等环境.
总之部署上maven不如ant灵活, ant写一套脚本一般来说也很少修改了.... 想改特容易. maven想复制个目录都要想法....
______________________________________________
简化后的版本:
notexists
dev
dev
test
test
org.codehaus.mojo
build-helper-maven-plugin
1.5
add-resource
generate-resources
add-resource
src/main/resources_${package.target}
org.apache.maven.plugins
maven-war-plugin
2.1
WEB-INF/lib/**,WEB-INF/classes/**,WEB-INF/work/**,WEB-INF/tmp/**
false
package
war
${package.target}
转载,仅供参考,祝你愉快,满意请采纳。
本回答由提问者推荐
已赞过
已踩过<
你对这个回答的评价是?
评论
收起