开发者社区> 问答> 正文

如何为本地Docker或Kubernetes中运行的ASP.NET Core应用程序连接本地SQL Server数据库?

我使用VS2017创建了一个ASP.NET Core Web API。之后,我为我的应用程序启用了Docker支持。

接下来,我实现了EF Core功能。之后我在本地测试了应用程序然后它工作正常,数据库也创建了。但每当我在本地Docker或本地Kubernetes中运行应用程序时,应用程序将无法正常工作。因为我使用了本地SQL Server,所以无论在Docker或Kubernetes中运行的容器,它都不知道SQL Server或SQL Server数据库。

如何在Docker或Kubernetes内运行的容器中使用本地数据库?

展开
收起
k8s小能手 2019-01-11 11:33:15 3799 0
1 条回答
写回答
取消 提交回答
  • 整合最优质的专家资源和技术资料,问答解疑

    您需要提供主机的IP。在linux中,您可以使用“host.docker.internal”主机名连接到主机。它应该在Windows中运行,但它在Windows中有很多问题。

    如果此主机名不适合您,则您有2个IP地址。一个是docker的网关,应该以10开头。。或172 . 。取决于你如何设置它。通常要学习这个,使用docker inspect ,您可以在网络部分看到默认网关。但是,Kubernetes可能会改变这些,它可能会提供更好的方式来访问主机。我没有使用Kubernetes,所以我不知道。

    另一种选择是使用主机的IP地址,由您的网络使用DHCP分配。通常应该以192.168开头。。。

    您的容器应该能够使用这些IP地址访问主机上的应用程序。如果问题仍然存在,请关闭防火墙,并尝试从容器内部进行ping操作。

    2019-07-17 23:25:16
    赞同 1 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
应用 Docker 进行持续交付:用技术改变交付路程 立即下载
从Docker到容器服务 立即下载
构建基因数据应用生态系统—— docker in Bio/informatics 立即下载