您可以在属性文件中提及变量属性,并定义特定于环境的属性文件,例如local.properties,production.propertied等。
现在基于环境,可以在启动时调用的侦听器之一(例如ServletContextListener)中读取其中一个属性文件。
该属性文件将包含各种键的特定于环境的值。
样本“ local.properties”
db.logsDataSource.url=jdbc:mysql://localhost:3306/logs
db.logsDataSource.username=root
db.logsDataSource.password=root
db.dataSource.url=jdbc:mysql://localhost:3306/main
db.dataSource.username=root
db.dataSource.password=root
样本“ production.properties”
db.logsDataSource.url=jdbc:mariadb://111.111.111.111:3306/logs
db.logsDataSource.username=admin
db.logsDataSource.password=xyzqer
db.dataSource.url=jdbc:mysql://111.111.111.111:3306/carsinfo
db.dataSource.username=admin
db.dataSource.password=safasf@mn
要使用这些属性文件,可以使用如下所述的REsource
PropertyPlaceholderConfigurer configurer = new PropertyPlaceholderConfigurer();
ResourceLoader resourceLoader = new DefaultResourceLoader();
Resource resource = resourceLoader.getResource("classpath:"+System.getenv("SERVER_TYPE")+"DB.properties");
configurer.setLocation(resource);
configurer.postProcessBeanFactory(beanFactory);
可以将SERVER_TYPE定义为具有适用于本地和生产环境的值的环境变量。
通过这些更改,appplicationContext.xml将进行以下更改
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="${db.dataSource.url}" />
<property name="username" value="${db.dataSource.username}" />
<property name="password" value="${db.dataSource.password}" />
希望这可以帮助 。