如何为本地Docker或Kubernetes中运行的ASP.NET Core应用程序连接本地SQL Server数据库?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

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

k8s小能手 2019-01-11 11:33:15 1242

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

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

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

SQL 开发框架 Kubernetes .NET API 数据库 Docker 容器
分享到
取消 提交回答
全部回答(1)
  • k8s小能手
    2019-07-17 23:25:16

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

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

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

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

    1 0
+ 订阅

云原生时代,是开发者最好的时代

推荐文章
相似问题