Подключитесь к MySQL на локальном хосте из контейнера Docker

У меня есть mysql, работающий на моем localhost Я могу подключить его, запустив:

mysql -h 127.0.0.1 -P 3306 -u root -p

Я также запускал контейнер докера с командой:

docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 --name container container

И я хочу получить доступ к моему Mysql db из контейнера докеров. Поэтому я также использую контейнер для докеров:

mysql -h 127.0.0.1 -P 3306 -u root -p

Но это дает мне ошибку:

ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111)

Что я делаю неправильно? Порты кажутся правильными. РЕДАКТИРОВАТЬ 1 Вывод ifconfig в докере:

eth0      Link encap:Ethernet  HWaddr 02:42:ac:11:00:02  
          inet addr:172.17.0.2  Bcast:0.0.0.0  Mask:255.255.0.0
          inet6 addr: fe80::42:acff:fe11:2/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1780 errors:0 dropped:0 overruns:0 frame:0
          TX packets:977 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:2225781 (2.2 MB)  TX bytes:56572 (56.5 KB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:28 errors:0 dropped:0 overruns:0 frame:0
          TX packets:28 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1 
          RX bytes:1400 (1.4 KB)  TX bytes:1400 (1.4 KB)

Ответ 1

Даже если вы настроите MySQL для прослушивания на всех интерфейсах, а затем из своего контейнера получите доступ к MySQL с IP-адреса без обратной связи, вы можете обнаружить, что правила маршрутизации, NAT и брандмауэра Dockers не позволяют вам получать доступ к службам, запущенным на хосте. Быстрый обходной путь для этого - запустить ваш контейнер в сетевом стеке хоста с помощью:

docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 \
  --name container --net host container

Вы также можете переместить MySQL в контейнер, работающий в той же сети Docker, а затем получить к нему доступ через имя контейнера, используя обнаружение службы Dockers DNS.

Ответ 2

Используйте маршрут по умолчанию. Например:

~# ip route show | grep "default" | awk '{print $3}'
172.18.0.1

затем

mysql -h 172.18.0.1 -P 3306 -u root -p

если вам нужно автоматизировать это, допустим, использовать этот IP-адрес в оболочке script, отправить его в оболочку script, считать как:

host=$(ip route show | grep \"default\" | awk '{print $3}' | xargs echo -n)

тогда у вас есть хост ip addr на $host