Can Not Connect To Sql Server From Docker Supported Asp.net Core Project
Answer :
This took me some time to work out, there are a number of small issues that may be wrong, which makes it frustrating. This can get even more frustrating as the .net core web application visual studio 2017 project that gets auto-generated doesn't work straight out of the box. Having this experience as your first exposure to Docker isn't ideal.
I initially also had the incorrect assumption that the docker image would come with SQL Server inside the container, this is not the case, it's trying to access the database server that must be pre-installed on the host machine.
Steps to follow (tested for a windows docker image, rather than linux);
1) Get the IP address of your host machine, by running a command prompt and typing IPCONFIG
2) Set the database connection string within you appsettings.json file to this Ip address, followed by the SQL Server port number, i.e.;
192.168.X.X,1433
3) Set the connection string not to use Trusted_Connection (delete this from the connection string) and hard code in the User Id and Password;
User Id=sa;Password=SuperSecurePassword;
If I didn't do this, on certain SQL Server configurations I'd get an unusual error (cannot quite remember the specifics!)
Connection String show look something like this;
"Server=192.168.X.X,1433;Database=MyDatabase;User Id=sa;Password=SuperSecurePassword;MultipleActiveResultSets=true"
4) now on the host machine you need to open up the windows firewall, and add a new inbound connection rule, for TCP port 1433.
5) After all this, and it still doesn't work, try a reboot; I struggled for a long time and had to reboot, which brought it into life; I'm not sure Docker had initialised correctly, this is mostly speculation though! I don't really like to say rebooting is a fix for problems, it's not really an answer, but in certain cases it does the trick.
edit, one final thing, running visual studio in administrator mode (right click icon, "run as administrator") helps too.
Apologises for the resurrection of an old thread, but this issue seems to still exist and the information available is a bit patchy on how to fix this, considering the small number of things that need to be done.
So what has worked for me is:
public static string DockerHostMachineIpAddress => Dns.GetHostAddresses(new Uri("http://docker.for.win.localhost").Host)[0].ToString();
docker.for.win.localhost is an address that inner dns of docker will resolve as localhost (not localhost inside docker but the hosting machine). The above code provides u with an ip address of your localhost and you are able to create connection string like this:
$"Server={DockerHostMachineIpAddress}\\SQL2017;Database=YourDB;User Id=Admin;Password=123;"
This will work if you are using named sql server instance - replace SQL2017 with ur instance name and crediatials with correct user.
HOWEVER! For migrations and update-database localhost works fine. Probably since its not handled from docker container.
EDIT:
Second solution is a bit cleaner but you need to have a project that supports docker-compose.
In docker-compose.yml file in definition of your service below image property definition add:
extra_hosts: - "localhost:192.168.65.2"
You still have to know what IP address (which you can find out by using the original answer) you have to add alias for, but once you know it it's a bit more clean. On more than 5 different machines that I worked on this IP is correct.
I had the same issue, followed the same approach as on the website you mentioned. It should work like that if you have the networks with standard configuration.
Simply disable the firewall for your public network.
My issue was simply, that windows seemed to classify the network created by Docker as public network and so the firewall blocked it, same as for this one:
Can't connect to SQL Server express from .net core app running on docker
It's not marked there as an answer but rather edited in the question.
Comments
Post a Comment