【发布时间】:2015-06-10 19:39:01
【问题描述】:
我运行了两个 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,但我得到了同样的错误。
【问题讨论】:
-
你配置 MySQL 进行远程访问了吗?
-
@EstebanOlate 我使用了这个容器registry.hub.docker.com/u/wnameless/mysql-phpmyadmin。我认为它已经配置好了,因为他们在描述中提到了 ssh 的东西。在描述中他们说:使用以下凭据在浏览器中打开 localhost:49161/phpmyadmin:
用户名:root
密码:通过 SSH 登录
ssh root@localhost -p 49160
密码:admin跨度> -
我在容器所在的站点上看到了一条评论,据我了解,MySQL 远程访问没有启用,如果需要帮助,请通过 ssh 登录并配置它cyberciti.biz/tips/…
-
将容器更改为这个之后,它现在可以工作了。 registry.hub.docker.com/u/lxitgto/mysql-phpmyadmin 基本上是一样的,只是有人把sql绑定地址改成了0.0.0.0。非常感谢。