为了账号安全,请及时绑定邮箱和手机立即绑定

如何连接ASP.NET Core的docker镜像(代码优先)和SQL Server

如何连接ASP.NET Core的docker镜像(代码优先)和SQL Server

C#
慕容森 2023-06-25 14:27:30
我正在 nopCommerce 上处理一个项目,并尝试使用 docker 映像运行它。有两个映像,一个用于 nopCommerce,第二个用于 MSSQL 服务器。这是我遵循的步骤,1)构建docker镜像并在端口8080上运行C:\Users\Admin>docker run -d -p 8080:80 --name mystore nop420 ca626cc5ed4e3759a03e9645dcd374016a5d8f278ffede8e1345f851f9a82c7d项目运行在8080端口2) 从Docker Hub中提取 MSSQL(Express) Linux 镜像3)使用命令运行它docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=yourStrong(!)Password' -e 'MSSQL_PID=Express' -p 1433:1433 -d mcr.microsoft.com/mssql/server:2017-latest-ubuntu4) docker exec -it unruffled_tharp "bash"5) /opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P 'yourStrong(!)Password'6) 创建数据库7) 尝试使用 VSCode 扩展连接 MSSQL 图像并且它有效8) 将相同的连接字符串传递到 nopCommerce 安装页面Data Source=localhost;Initial Catalog=nop420;User ID=sa;Password=yourStrong(!)Password但它给出了一个错误Setup failed: An error occurred while creating the database: A network-related or instance-specific error occurred while establishing a connection to SQL Server. The server was not found or was not accessible. Verify that the instance name is correct and that SQL Server is configured to allow remote connections. (provider: TCP Provider, error: 40 - Could not open a connection to SQL Server)我尝试使用 IP 而不是 localhost,添加端口 1433 以及来自不同论坛的几乎所有内容,但错误仍然相同。
查看完整描述

1 回答

?
DIEA

TA贡献1820条经验 获得超2个赞

这通常是因为 Docker 为容器创建了自己的内部网络,因此默认情况下两个容器看不到对方。所以你有两个选择:

  1. 创建一个 docker 网络并将两个容器附加到该网络

创建一个新网络:

docker network create <networkName>

要将容器连接到特定网络:

– 使用 docker run 和 —network 标志启动容器时连接到网络。像这样的东西(注意网络标志)

docker run -dit --name <containerName> --network <networkName> <imageName>

– 使用以下命令将已创建的容器连接到网络

docker network connect <networkName> <containerName>
  1. 使用 docker-compose 设置两个图像(这是我的首选选项)。Docker compose 自动创建网络并设置容器以在该网络中运行

设置网络后,您应该能够使用以下命令从一个容器到达另一个容器containerName:PortNumber

如果容器仍然无法相互通信:

– 检查它们是否实际上在同一网络中:通过运行docker network inspect

– 检查是否可以到达另一台机器(从容器内)

ping <dockerContainerName>
ping <dockerContainerIPaddress>

– 检查相应的端口是否打开

nmap -p <portnumber> <dockerContainerIPaddress>


查看完整回答
反对 回复 2023-06-25
  • 1 回答
  • 0 关注
  • 119 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信