Docker → Подключение к локальному MySQL из Docker-контейнера
Если возникнет необходимость подключиться из докер-контейнера к серверу MySQL, установленному на хост-машине, то сделать это можно следующим образом. Для начала определяем IP-адрес хоста:
ip addr show
Выбираем из появившейся кучи букв и цифр искомый адрес. У меня получилось, к примеру, 192.168.1.166. К нему и будем подключаться из докера. Адрес желательно иметь фиксированный, чтобы не менять его в настройках подключения от перезагрузки к перезагрузке, у себя привязку IP к MAC-адресу сделал сто лет в настройках роутера.
Далее поднастроим MySQL. Для начала в /etc/mysql/my.cnf находим и редактируем директиву bind-address, чтобы сервер БД прослушивал все адреса, а не только localhost:
# /etc/mysql/my.cnf bind-address = 0.0.0.0
И создадим базу данных и пользователя, который будет подключаться из докера:
CREATE DATABASE pupkin_db; CREATE USER pupkin IDENTIFIED BY 'secret_password'; GRANT ALL PRIVILEGES ON pupkin_db.* TO pupkin; -- сразу обновим права доступа FLUSH PRIVILEGES;
Готово.