【问题标题】:Jetty Docker container running spring application unable to connect to mysql running outside docker container运行spring应用程序的Jetty Docker容器无法连接到在docker容器外运行的mysql
【发布时间】:2017-11-03 08:10:27
【问题描述】:

我是码头工人世界的新手。我有一个运行 spring 应用程序的码头 docker 容器,该应用程序无法连接到在 docker 容器外运行的 mysql。 Mysql 在我的本地主机上运行,​​这是一个 MAC。我了解 docker 在 mac 上的 VM 中运行。我的 jdbc 连接字符串是jdbc.url=jdbc:mysql://127.0.0.1:3306/

下面是我看到的例外

nested exception is org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is java.sql.SQLException: Connections could not be acquired from the underlying database!
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:189)
    at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:588)
    ... 71 more
Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is java.sql.SQLException: Connections could not be acquired from the underlying database!
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:80)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:394)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:443)
    at com.multi.enterprise.commons.jdbc.config.JdbcConfig.jdbcTemplate(JdbcConfig.java:57)
    at com.multi.enterprise.commons.jdbc.config.JdbcConfig.namedParameterJdbcTemplate(JdbcConfig.java:52)
    at com.multi.enterprise.commons.jdbc.config.JdbcConfig$$EnhancerBySpringCGLIB$$492af47.CGLIB$namedParameterJdbcTemplate$3(<generated>)
    at com.multi.enterprise.commons.jdbc.config.JdbcConfig$$EnhancerBySpringCGLIB$$492af47$$FastClassBySpringCGLIB$$1a9e6a23.invoke(<generated>)
    at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:228)
    at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:358)
    at com.multi.enterprise.commons.jdbc.config.JdbcConfig$$EnhancerBySpringCGLIB$$492af47.namedParameterJdbcTemplate(<generated>)

        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:162)
        ... 72 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 org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111)
        at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77)
        ... 86 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)
        ... 89 more

【问题讨论】:

    标签: mysql macos docker jetty


    【解决方案1】:

    由于 docker 容器有自己的网络命名空间,所以它有自己的 127.0.0.1。您必须通过另一个可路由的 IP 地址连接到您的主机。

    就我而言,我的 Mac 位于我的本地家庭网络中,IP 地址为:192.168.10.42。当我运行 Docker For Mac 应用程序时,它会启动一个微型虚拟机。在该虚拟机中,docker 与我所有的容器一起运行。默认情况下,正在运行的虚拟机将所有流量发送出虚拟机。由于我的 mac 可以访问 192.168.10.42 地址,因此我从虚拟机内部发送到该 ip 的任何流量都将到达我的 mac。

    从我正在运行的一个容器的角度来看,它发出的任何流量都由虚拟机处理。这意味着虚拟机可以到达的任何位置我也可以从我的容器到达。

    如果您不想依赖本地网络上的 mac ip 地址,可以执行以下操作:https://gist.github.com/ralphschindler/535dc5916ccbd06f53c1b0ee5a868c93

    这个想法是为您的 Mac 提供一个 IP 地址,无论您将 Mac 移动到哪个网络,该地址都将始终存在。我做过类似的事情,我将通过 System Preferences Network gui 向我的 mac 添加一个新的桥接接口。我只是离开没有附加物理接口的网桥,然后手动为其分配一个 IP 地址。

    这两种方法都有效,因为请记住,Mac 上的任何 IP 地址都可以从 Docker For Mac 运行的虚拟机路由到。

    从 Docker 17.06 开始,一种全新的可能性是使用docker.for.mac.localhost 地址,而不是使用前面提到的任何其他解决方法。 (目前的稳定版本仍然是 17.03。)

    有关 17.06 更改的信息,请参阅:https://github.com/docker/docker.github.io/pull/3220

    【讨论】:

      猜你喜欢
      • 2015-11-19
      • 1970-01-01
      • 2020-10-15
      • 2021-07-02
      • 2019-06-01
      • 1970-01-01
      • 2020-09-28
      • 1970-01-01
      • 2021-04-04
      相关资源
      最近更新 更多