2016-07-30 167 views
4

我在学习docker并尝试将使用Tomcat的Java Web应用程序放到容器中。我跟着一些基本的教程,但我发现没有解决方案能够正常工作给我。如果我跑我的数据库和Java容器出现错误:无法使用Docker将Java程序连接到MySQL

SEVERE: Unable to create initial connections of pool. 
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:404) 
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:981) 
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:339) 
    at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2253) 
    at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2286) 
    at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2085) 
    at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:795) 
    at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:44) 

MySQL的Dockerfile

FROM mysql:latest 
ENV MYSQL_DATABASE=db_name #name of db that is required by Java program 

运行方式:

docker run --name db_name -e MYSQL_ROOT_PASSWORD=root -d db_name 

的Java Dockerfile

FROM tomcat:7.0.70-jre8 
ADD deploy /usr/local/tomcat/webapps #extracted .war 
ADD jdbc /usr/local/tomcat/lib #MySQL jdbc drivers 
ADD context /usr/local/tomcat/conf #context.xml 

通过运行:

docker run --name app_name --link db_name:db_name -p 8080:8080 -d app_name 

当我在Eclipse中本地运行它时,整个配置正常运行。

+0

什么是mysql_hostname或mysql连接字符串到java配置文件中? –

+0

有 “URL =” 的jdbc:mysql的://本地主机:3306/DB_NAME”我改 “的jdbc:mysql的:// DB_NAME:3306/DB_NAME” 像@Ohmen建议和它的工作现在可以正确 – Marcon

回答

2

因为你不提供完整的堆栈TACE,这会显示什么的连接字符串Tomcat是用,我猜测,你没有提供正确的连接字符串到Tomcat conainer。你必须提供一个如下的连接字符串:

jdbc:mysql://database_container_name:3306/database_name 

进入你的tomcat配置。


BTW:

你应该重新安排你在Tomcat Dockerfile线

FROM tomcat:7.0.70-jre8 
ADD jdbc /usr/local/tomcat/lib #MySQL jdbc drivers 
ADD context /usr/local/tomcat/conf #context.xml 
ADD deploy /usr/local/tomcat/webapps #extracted .war 

由于码头工人可以缓存构建层。使用旧订单,war是图像的第一层,每当您对应用程序进行更改时都会发生变化,从而导致每次都会重建以下图层,即使这些图层没有更改。新订单更好地使用码头工人。使用这个命令永远不会改变MySQL驱动总是被缓存,配置也不会像战争那样快速改变。

在这个例子中,效果可能是最小的,但如果你用更多的图层和更长的构建步骤构建更大的图像(如apt-get install smth),chache可以显着加快构建。

+0

它的作品。感谢您的回复和您的建议;) – Marcon

+0

不客气 – Ohmen