我正在使用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" />