【问题标题】:Spring Boot multiple profiles DataSourceSpring Boot 多个配置文件数据源
【发布时间】:2016-06-24 02:16:35
【问题描述】:

我正在编写一个带有两个 Oracle 数据源的 Spring Boot 应用程序 - 这是我的 application.yml 文件:

spring:
    profiles: test
datasource:
  app2:
       url: jdbc:oracle:thin:@//rap-vin:1521/APP221
       username: user2
       password: pwd2
       driver-class-name: oracle.jdbc.OracleDriver
  app:
       url: jdbc:oracle:thin:@//eap10-san:1522/APP22
       username: user
       password: pwd
       driver-class-name: oracle.jdbc.OracleDriver
application:
  app:
       url: example.com/app

我有一个 DBConfiguration 类,如下所示:

@Configuration
public class DBConfiguration {

    @Bean
    @Primary
    @ConfigurationProperties(prefix = "datasource.app")
    public DataSource appDataSource() {
        DataSource ds = DataSourceBuilder.create().build();
        return ds;
    }

    @Bean
    @ConfigurationProperties(prefix = "datasource.app2")
    public DataSource app2DataSource() {
        DataSource ds = DataSourceBuilder.create().build();
        return ds;
    }
}

然后我有一个测试类:

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = DBConfiguration.class)
public class Test {

    private JdbcTemplate jdbcTemplateAPP;
    private JdbcTemplate jdbcTemplateAPP2;
    //private RestTemplate restTemplate;


    @Autowired
    public void setDataSource(final DataSource appDataSource,
                @Qualifier("app2DataSource") final DataSource app2DataSource) {
            this.jdbcTemplateAPP = new JdbcTemplate(appDataSource);
            this.jdbcTemplateAPP2 = new JdbcTemplate(app2DataSource);
        }

    @Test
    public void testJob() throws Exception {
        int count= jdbcTemplateAPP.queryForObject("select count(*) from parm", int.class);

        Assert.assertTrue(count==1);
    }
}

但每当我运行测试时,我都会将 db url 设为空。 我究竟做错了什么?另外,我应该如何阅读 application.app url?感谢您对此的帮助-(仅供参考,我是 Spring 新手) 错误:

java.sql.SQLException: The url cannot be null
    at java.sql.DriverManager.getConnection(DriverManager.java:649) ~[na:1.8.0_77]
    at java.sql.DriverManager.getConnection(DriverManager.java:208) ~[na:1.8.0_77]
    at org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:305) ~[tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:200) ~[tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:708) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:642) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.ConnectionPool.init(ConnectionPool.java:464) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.ConnectionPool.<init>(ConnectionPool.java:141) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.DataSourceProxy.pCreatePool(DataSourceProxy.java:115) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.DataSourceProxy.createPool(DataSourceProxy.java:102) [tomcat-jdbc-8.0.33.jar:na]
    at org.apache.tomcat.jdbc.pool.DataSourceProxy.getConnection(DataSourceProxy.java:126) [tomcat-jdbc-8.0.33.jar:na]
    at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:390) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:470) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:480) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.queryForObject(JdbcTemplate.java:490) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.queryForObject(JdbcTemplate.java:496) [spring-jdbc-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at com.tgt.trans.intl.batchtest.mib.tests.MIB022Test.testJob(MIB022Test.java:35) [test-classes/:na]
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_77]
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_77]
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_77]
    at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_77]
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) [junit-4.12.jar:4.12]
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) [junit-4.12.jar:4.12]
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) [junit-4.12.jar:4.12]
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) [junit-4.12.jar:4.12]
    at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) [junit-4.12.jar:4.12]
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:254) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) [junit-4.12.jar:4.12]
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) [junit-4.12.jar:4.12]
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) [junit-4.12.jar:4.12]
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) [junit-4.12.jar:4.12]
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) [junit-4.12.jar:4.12]
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) [junit-4.12.jar:4.12]
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:193) [spring-test-4.2.6.RELEASE.jar:4.2.6.RELEASE]
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86) [.cp/:na]
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) [.cp/:na]
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459) [.cp/:na]
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:670) [.cp/:na]
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) [.cp/:na]
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192) [.cp/:na]

【问题讨论】:

    标签: java oracle spring-boot yaml datasource


    【解决方案1】:

    首先,

    你是通过 VM 参数还是以某种方式激活了配置文件“测试”? 您的 yml 似乎只是定义了配置文件,但它仍然没有激活。

    如果您想激活 yml 中的配置文件“测试” 你应该写在下面

    spring:
      profiles: 
        active: test
    

    或者把这个放到虚拟机

    -Dspring.profiles.active=test
    

    秒,

    在测试类中 appDataSource 和 app2DataSource 都将由 appDataSource 注入。

    也许你不是故意的 所以如果你想将 app2DataSource 注入 app2DataSource 应该写在下面

    @Qualifier("app2DataSource") final DataSource app2DataSource
    

    终于 如果你想在你的测试类中使用 yml 的内容(比如 application.app.url) 放

    @ConfigurationProperties(prefix = "application.app")
    

    在你的类上并像这样定义变量

    private String url;
    

    【讨论】:

    • 谢谢 - 我修复了我的帖子以包含 app2datasource - 当你说“如果你想在你的测试中使用 application.app”时你是什么意思 - 那是哪个类?我必须创建一个吗?
    • 我应该说“如果你想在你的测试类中使用 yml 的内容”,答案是here
    • 我明白了——但我得到的错误是在读取数据源 url 时——我什至没有使用应用程序 url。
    【解决方案2】:

    通过编辑让它工作:

    @Configuration
    public class DBConfiguration {
    
    ... 
    

    到:

    @SpringBootApplication
    public class DBConfiguration {
    
        public static void main(String[] args) {
            SpringApplication.run(Application.class, args);
        }
    ...
    

    【讨论】:

      最近更新 更多