如何使用springboot和tomcat服务器资源数据库为liquibase任务配置JNDI数据源?

时间:2018-01-10 14:19:42

标签: apache spring-boot jndi tomcat8 liquibase

我正在使用Spring引导应用程序以及liquibase版本3.5.3,其中我需要为liquibase任务和应用程序执行配置两个不同的JNDI数据源。 我在tomcat server.xml文件中创建了两个不同的JNDI数据源

<Resource name="JDBC/DSAdmin"
         global="jdbc/DSAdmin"
         auth="Container"
         factory="com.zaxxer.hikari.HikariJNDIFactory"
         type="javax.sql.DataSource"
         driverClassName="com.mysql.jdbc.Driver"
         jdbcUrl="jdbc:mysql://localhost:3306/dbname"
         username="admin"
         password="admin"
         minimumIdle="5" maximumPoolSize="50" connectionTimeout="300000" maxLifetime="1800000" />
and 
<Resource name="jdbc/DS"
         global="jdbc/DS"
         auth="Container"
         factory="com.zaxxer.hikari.HikariJNDIFactory"
         type="javax.sql.DataSource"
         driverClassName="com.mysql.jdbc.Driver"
         jdbcUrl="jdbc:mysql://localhost:3306/database"
         username="root"
         password="root"
         minimumIdle="5" maximumPoolSize="50" connectionTimeout="300000" maxLifetime="1800000" />

我需要使用jdbc / DSAdmin连接池和应用程序使用jdbc / DS连接池运行liquibase任务。

但liquibase版本3.5.3没有提供任何使用tomcat服务器资源指定数据源的属性。

在application.properties文件中,我已配置spring.datasource.jndi-name = java:comp/env/jdbc/DSAdmin

同样我想配置liquibase.datasoure=java:comp/env/jdbc/DS

这是我的context.xml文件

<ResourceLink name="jdbc/DS" 
     global="jdbc/DS"
     auth="Container"
type="javax.sql.DataSource" /> 

<ResourceLink name="jdbc/DSAdmin" 
     global="jdbc/DSAdmin"
     auth="Container"
type="javax.sql.DataSource" />

0 个答案:

没有答案