1

在 Jenkins CloudBees 中运行时,我无法弄清楚如何访问 MySQL 数据库。我试过关注Dev@Cloud MySQL,但是控制台输出中有很多警告,我必须处理 localhost 访问与套接字,这在没有命令行的情况下调试非常棘手。

有没有办法使用 CloudBees MySQL 托管?当我尝试使用 cloudbees JDBC 驱动程序时,我收到 ClassNotFound 错误消息。

更新:下面的答案澄清了我不能使用 CloudBees 驱动程序,所以我现在通过 c3p0 连接池使用常规 MySQL 连接器。根据下面的评论,我将池中的连接数限制为 10。

当我从我的开发计算机运行它并连接到 Cloudbees Mysql 实例时,完全相同的配置和 Maven 命令行可以工作。

不幸的是,尝试连接时出现此错误:

Caused by: com.googlecode.flyway.core.exception.FlywayException: Unable to obtain Jdbc connection from DataSource
    at com.googlecode.flyway.core.util.jdbc.JdbcUtils.openConnection(JdbcUtils.java:56)
    at com.googlecode.flyway.core.Flyway.execute(Flyway.java:864)
    at com.googlecode.flyway.core.Flyway.migrate(Flyway.java:591)
    at com.assuredlabor.db.DatabaseMigrator.migrate(DatabaseMigrator.java:13)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeCustomInitMethod(AbstractAutowireCapableBeanFactory.java:1414)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1375)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
    ... 62 more
Caused by: java.sql.SQLException: Connections could not be acquired from the underlying database!
    at com.mchange.v2.sql.SqlUtils.toSQLException(SqlUtils.java:106)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:529)
    at com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:128)
    at com.googlecode.flyway.core.util.jdbc.JdbcUtils.openConnection(JdbcUtils.java:50)
    ... 72 more
Caused by: com.mchange.v2.resourcepool.CannotAcquireResourceException: A ResourcePool could not acquire a resource from its primary factory or source.
    at com.mchange.v2.resourcepool.BasicResourcePool.awaitAvailable(BasicResourcePool.java:1319)
    at com.mchange.v2.resourcepool.BasicResourcePool.prelimCheckoutResource(BasicResourcePool.java:557)
    at com.mchange.v2.resourcepool.BasicResourcePool.checkoutResource(BasicResourcePool.java:477)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:525)
    ... 74 more

任何想法,将不胜感激。

4

1 回答 1

2

您不能从 RUN@Cloud 容器外部使用 CloudBees JDBC 驱动程序,但您可以使用标准 MySQL JDBC 驱动程序和您的 RUN 数据库,使用您可以在 RUN@Cloud Web 控制台上为您的数据库资源找到的主机名和端口。

于 2012-09-12T10:10:54.637 回答