hibernate - 从另一个 docker 容器连接到数据库

标签 hibernate tomcat docker

我运行了两个 docker 容器,一个是 tomcat,一个是 phpmyadmin。 我用这个命令运行了 phpmyadmin 容器:

docker run -d -p 49160:22 -p 49161:80 -p 49162:3306 --name db phpmyadmin:imported

我可以在浏览器的 49161 端口上看到 phpmyadmin。我用这个命令运行了 tomcat 容器

 docker run -it -v ~/docker/tomcat/tomcat-users.xml:/usr/local/tomcat/conf/tomcat-users.xml --name tomcat --link db:server -p 8888:8080 tomcat:deployed

一切看起来都很好。我可以从 tomcat 容器 ping 数据库。但是当我尝试使用 hibernate 和我的 J2EE 应用程序连接到它时,出现以下错误。

10-Jun-2015 19:20:12.293 WARNING [http-nio-8080-exec-15] org.hibernate.cfg.SettingsFactory.buildSettings Could not obtain connection metadata


java.sql.SQLException: Connections could not be acquired from the underlying database!
    at com.mchange.v2.sql.SqlUtils.toSQLException(SqlUtils.java:118)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:690)
    at com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:140)
    at org.hibernate.connection.C3P0ConnectionProvider.getConnection(C3P0ConnectionProvider.java:56)

这是我的 hibernate.cfg.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://172.17.0.20:3306/auction</property>
        <property name="hibernate.connection.username">root</property>
       <property name="hibernate.show_sql">true</property>
        <property name="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</property>
        <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>


        <mapping class="ie.domain.entity.User"/>
        <mapping class="ie.domain.entity.Auction"/>
        <mapping class="ie.domain.entity.Offer"/>
    </session-factory>
</hibernate-configuration>

我尝试使用名称服务器而不是 IP,我也尝试使用端口 49162 而不是 3306,但我得到了同样的错误。

最佳答案

尝试连接:

jdbc:mysql://server:3306/auction

端口映射在主机上,因此在直接与容器对话时不使用它们。 docker 链接功能会将名称“server”添加到带有容器 IP 地址的 /etc/hosts 中,因此您可以通过名称引用它。

更新:从对 https://registry.hub.docker.com/u/wnameless/mysql-phpmyadmin/ 的评论来看,这是行不通的,因为服务器只监听 127.0.0.1,而不是 0.0.0.0。

关于hibernate - 从另一个 docker 容器连接到数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30765767/

相关文章:

hibernate - 如何在 Hibernate 中存储日期集合

java - JPA/hibernate : how to automatically update fields on entity update

spring - 如何在两个应用程序之间共享同一个 session

java - 如何将服务器端 Jax-rs 调用与没有前缀的 native 文件混合?

docker - 如何在 Docker 之外将 NGINX 反向代理到 proxy_pass 到 docker 容器

java - entityManager.getTransaction().rollback() 分离实体?

mysql - 如何在 hibernate 中使用 between 子句比较日期

tomcat - Tomcat8 (8.0.32-1ubuntu1.5) 安装失败

maven - Docker Jenkins集成

docker - 无法安装 windowsServerCore 容器镜像