为什么需要多环境
在it项目开发过程中,会有开发、测试、生产等多套环境, 所以一般在项目中使用配置文件来区分环境变量参数,比如:开发数据库服务器Ip:192.168.1.33,生产服务器Ip是:biz_dbserver001,测试服务器上的数据库是:test_dbserver001, 不同的环境参数也是不同的,如果我们在系统开发的时候不考虑多环境管理的话,等我们从开发迁移到测试的时候,需要改动的参数会随着系统规模的增大而变得多起来, 如果漏掉任何一个参数,都会造成系统运行出来的结果不正确,或者系统不能正常工作等问题。 因此会有多环境管理,通过把系统一些参数抽象出来,然后定义多个环境参数文件, 文件定义环境特有的一些数据值。 然后在打包过程中,使用目标环境变量参数替换预定义的系统参数。 打包后,直接部署到目标环境即可保证正确运行。减少了脑力、人力工作。
在c/c++语言开发的系统中,有些参数是通过环境变量获取env,window上是注册表,有些是通过ini、conf、etc、yaml文件通过在安装过程中,把参数值写入到env或者window的注册表中,以后每次启动的时候,首先把参数都读出来,放在内存里,方便在程序运行过程中直接拿到期望的参数值。
在java系统开发中,一般都是通过配置文件properties、yaml、json文件获取。比如在springmvc项目中,一般都是application.properties、xml等配置文件。
java打包工具
像是c/c++使用make解决依赖和编译程序,java一开始使用的是自己的打包工具,从一开始的java命令,到后来的ant、maven、gradle,一点点进步。 启动本文主要介绍的是maven,其他就不细说了。
maven最核心的改进就在于提出仓库这个概念。我可以把所有依赖的包,都放到仓库里去,在我的工程管理文件里,标明我需要什么什么包,什么什么版本。在构建的时候,maven就自动帮我把这些包打到我的包里来了。我们再也不用操心着自己去管理几十上百个jar文件了。
maven使用如下:
C:homeapache-maven-3.5.3bin>mvn --helpusage: mvn [options] [] []Options: -am,--also-make If project list is specified, also build projects required by the list -amd,--also-make-dependents If project list is specified, also build projects that depend on projects on the list -B,--batch-mode Run in non-interactive (batch) mode (disables output color) -b,--builder The id of the build strategy to use -C,--strict-checksums Fail the build if checksums don't match -c,--lax-checksums Warn if checksums don't match -cpu,--check-plugin-updates Ineffective, only kept for backward compatibility -D,--define Define a system property -e,--errors Produce execution error messages -emp,--encrypt-master-password Encrypt master security password -ep,--encrypt-password Encrypt server password -f,--file Force the use of an alternate POM file (or directory with pom.xml) -fae,--fail-at-end Only fail the build afterwards; allow all non-impacted builds to continue -ff,--fail-fast Stop at first failure in reactorized builds -fn,--fail-never NEVER fail the build, regardless of project result -gs,--global-settings Alternate path for the global settings file -gt,--global-toolchains Alternate path for the global toolchains file -h,--help Display help information -l,--log-file Log file where all build output will go (disables output color) -llr,--legacy-local-repository Use Maven 2 Legacy Local Repository behaviour, ie no use of _remote.repositories. Can also be activated by using -Dmaven.legacyLocalRepo=true -N,--non-recursive Do not recurse into sub-projects -npr,--no-plugin-registry Ineffective, only kept for backward compatibility -npu,--no-plugin-updates Ineffective, only kept for backward compatibility -nsu,--no-snapshot-updates Suppress SNAPSHOT updates -o,--offline Work offline -P,--activate-profiles Comma-delimited list of profiles to activate -pl,--projects Comma-delimited list of specified reactor projects to build instead of all projects. A project can be specified by [groupId]:artifactId or by its relative path -q,--quiet Quiet output - only show errors -rf,--resume-from Resume reactor from specified project -s,--settings Alternate path for the user settings file -t,--toolchains Alternate path for the user toolchains file -T,--threads Thread count, for instance 2.0C where C is core multiplied -U,--update-snapshots Forces a check for missing releases and updated snapshots on remote repositories -up,--update-plugins Ineffective, only kept for backward compatibility -v,--version Display version information -V,--show-version Display version information WITHOUT stopping build -X,--debug Produce execution debug outputC:homeapache-maven-3.5.3bin>
实现方式
我们这里利用maven的profile方式实现多环境变量,maven常见的两种使用Profile的方法:占位符替换和文件复制。我们使用占位符替换方式,通过在项目顶层的pom.xml文件中定义多个profile,里面分别定义不同环境的一些参数值,在通过maven package -PenvName的时候,使用envName对应的profile里面的值替换掉工程配置文件里面的${}变量的值。
- 3.1 profile定义
pom.xml文件里面定义多个profile,如下:
生产环境 false <_env.name>生产环境 <_datasource.url>jdbc:oracle:thin:@40.17.13.150:1521:biz <_datasource.username>biz_product <_datasource.publickey>MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAIa7nwUBBMpredF5d5XmbY6RTmDbgwQWzKRvqN9AfoYIMuWbVNmEnaXImJEsVNCpG1uCj5JdoxnNhyDMDrgVT7kCAwEAAQ== <_datasource.password>PCf2UyzwD4ynCrm/NiyepRtp//iMRhTNUkPM+GiVIzwXVHJiQABk1P41+yMwj5VIYJECk45aXVjuvuXOEFshQA== <_log4j.path>/home/lehoon/apache-tomcat-8.0.50/temp/lehoon/logs <_ehcache.path>/home/lehoon/apache-tomcat-8.0.50/temp/lehoon/ehcache <_redis.host>localhost <_redis.port>6379 <_redis.password>smartweb 测试环境 false <_env.name>测试环境 <_datasource.url>jdbc:oracle:thin:@147.3.156.134:1521:ORCL <_datasource.username>biz_develop_test <_datasource.publickey>MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAIa7nwUBBMpredF5d5XmbY6RTmDbgwQWzKRvqN9AfoYIMuWbVNmEnaXImJEsVNCpG1uCj5JdoxnNhyDMDrgVT7kCAwEAAQ== <_datasource.password>PCf2UyzwD4ynCrm/NiyepRtp//iMRhTNUkPM+GiVIzwXVHJiQABk1P41+yMwj5VIYJECk45aXVjuvuXOEFshQA== <_log4j.path>/home/lehoon/tomcat/temp/lehoon/logs <_ehcache.path>/home/lehoon/tomcat/temp/lehoon/ehcache <_redis.host>localhost <_redis.port>6379 <_redis.password>smartweb 开发环境 true <_env.name>开发环境 <_datasource.url>jdbc:oracle:thin:@localhost:1521:ORCL <_datasource.username>biz_develop <_datasource.publickey>MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAIa7nwUBBMpredF5d5XmbY6RTmDbgwQWzKRvqN9AfoYIMuWbVNmEnaXImJEsVNCpG1uCj5JdoxnNhyDMDrgVT7kCAwEAAQ== <_datasource.password>PCf2UyzwD4ynCrm/NiyepRtp//iMRhTNUkPM+GiVIzwXVHJiQABk1P41+yMwj5VIYJECk45aXVjuvuXOEFshQA== <_log4j.path>../temp/lehoon/logs <_ehcache.path>../temp/lehoon/ehcache <_redis.host>localhost <_redis.port>6379 <_redis.password>smartweb
公共配置文件common.properties定义如下:
#============================##===== Database sttings =====##============================##oracle database settingjdbc.type=oraclejdbc.driver=oracle.jdbc.OracleDriverjdbc.url=${_datasource.url}jdbc.username=${_datasource.username}jdbc.password=${_datasource.password}jdbc.publickey=${_datasource.publickey}#pool settingsjdbc.pool.init=5jdbc.pool.minIdle=10jdbc.pool.maxActive=20#jdbc.testSql=SELECT 'x'jdbc.testSql=SELECT 'x' FROM DUAL#redisredis.host=${_redis.host}redis.port=${_redis.port}redis.password=${_redis.password}#============================##===== System settings ======##============================##产品信息设置productName=webgiscopyrightYear=2018version=V1.2.6envName=${_env.name}#log file pathlog.path=${_log4j.path}#管理基础路径, 需同步修改:web.xmladminPath=/a#前端基础路径frontPath=/f#网站URL后缀urlSuffix=.htmlnotAllowRefreshIndex=falseuser.multiAccountLogin=true#分页配置page.pageSize=10session.sessionTimeout=3600000session.sessionTimeoutClean=3600000#缓存设置ehcache.configFile=cache/ehcache-local.xml#ehcache.configFile=cache/ehcache-rmi.xml
通过在common.properties文件中使用${}占位符,引用profile定义的节点值,就可以在maven打包过程中使用maven profile中定义的值插入到properties文件中来。
- 3.2 定制化profile替换
如果在我们文件中,有二次配置文件,第二层引用第一层的配置文件中的变量,我们在打包的时候不想使用maven的pforile值替换第二层配置文件的话,需要使用resource去个性化定制maven打包对资源文件的处理逻辑。 在resource中可以忽略指定类型文件、指定名称文件、引入需要处理的文件等。配置如下:
../webgis-system/src/main/resources**/*.xmltrue../webgis-PreciousMetal/src/main/resources**/*.xmltrue../webgis-common/src/main/resourcestruesrc/main/resources**/*.xml**/*.propertiescache/ehcache-rmi.xmleditor.htmlmybatis.xmlproperties/redis.propertiesmybatis-generator-config.xmltruesrc/main/resourcesmybatis.xmlfalse
../smartweb-common/src/main/resources/common.properties
配置好了后, idea 集成了maven后,点击右侧的maven栏,可以看到maven读取到了profile列表,
可以在这里切换环境,然后启动工程,就可以使用选择的环境启动、调试项目。 打包的话,直接使用build Artifacts打包即可。或者切换到控制台下使用maven package -p envName打包。