Docker容器只能使用内部IP /端口访问在另一个容器中运行的MSSQL

时间:2019-01-28 21:39:08

标签: java sql-server spring-boot docker

我已经使用以下docker run命令部署了一个非常简单的MSSQL docker容器:

docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=NotYourBusiness" -p 2433:1433 --name sql1 -d mcr.microsoft.com/mssql/server:2017-latest

我的计算机上安装了SSMS,并且可以使用以下URL连接到该实例:

MyHostName,2433

我还可以使用以下连接字符串从我的机器上运行Spring Boot应用程序:

dataSource.setJdbcUrl("jdbc:sqlserver://localhost:2433;database=SomeDatabase;");

在docker容器中只有MSSQL的情况下,我的应用程序可以在我的机器上正常运行。

现在,我也想将Spring Boot应用程序放入一个容器中。因此,我建立了以下docker文件:

FROM openjdk:11-jre-slim
VOLUME /tmp
EXPOSE 8082
ADD target/tno-1.0.jar tno-1.0.jar
ENTRYPOINT ["java","-jar","tno-1.0.jar"]

这是我用来创建图像的构建命令:

docker build -f Dockerfile -t tno .

这是我用来构建容器的命令:

docker run -t --name tno --link sql1:mssql -p 8082:8082 tno

使用与我的机器上相同的连接字符串,spring boot应用程序无法启动,并显示连接被拒绝错误。我确实看过很多文章,他们指出,从容器运行时,“本地主机”一词不再真正适用,因为它仅指该容器。我能够使其工作的唯一方法是将localhost:2433替换为容器IP地址:1433。

这是完全可以接受的,但是容器是否可以像我的开发机一样工作,并能够连接到另一个容器,就像连接来自外部世界一样?

谢谢

1 个答案:

答案 0 :(得分:0)

如果可以从在其他容器中运行的应用程序访问数据库,请尝试将jdbc url从localhost配置为mssql(数据库链接的名称)。

jdbc:sqlserver://mssql:2433;database=SomeDatabase;

让我知道或检查此how to link container in docker?