从另一个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链接function将名称“server”添加到带有容器IP地址的/etc/hosts
,所以你可以通过名字来引用它。
- Kubernetes节点的安装失败与CentOs 7上的冲突软件包
- Spring MVC – 带“ – ”的string参数parsing为“?”
- Haskell Yesod堆栈生成可运行的文件
- Clojure:使用aleph连接到TLS启用docker守护进程
- docker不开始退出ruby
- 解决docker问题 – 编写不同的客户端服务器会导致新的错误,说明降级Docker SDK for Python的版本
- 无法连接到存储在Azure虚拟机上的Nexus 3预览版上的Dockerregistry
- 有没有办法只添加更改的文件作为一个新的图层泊坞窗图像 – 无需诉诸docker提交?
- Docker撰写:没有冒号的卷(:)