Как подключиться к MySQL, работающему на Docker с главной машины

Я уже искал эту тему и нашел несколько потоков. Основываясь на этих потоках, я выполнил следующие шаги. Но я столкнулся с проблемой.

В принципе, я хочу создать образ docker для mysql, а затем подключиться к нему с моей главной машины (Mac OS X).

Основываясь на этой почте, мне нужно разделить сокет unix mysql с хостом. к этому я сделал следующие шаги

1. Start docker quick terminal
2. docker run --name mysql -e MYSQL_ROOT_PASSWORD=password -d mysql/mysql-server:latest
3. docker exec -it mysql bash
4. mysql -uroot -p
5. create database MyDB;
6. GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password';
7. exit;
8. mkdir /Users/abhi/host
9. docker run -it -v /host:/shared mysql/mysql-server:latest

Теперь я получаю сообщение об ошибке

MacBook-Pro:~$ docker run -it -v /Users/abhi/host:/shared mysql/mysql-server
error: database is uninitialized and password option is not specified
  You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD

Но вы видите, что я предоставил пароль и инициализировал мою базу данных.

Все, что я хочу, это то, что с моего хост-компьютера я могу подключиться к базе данных mysql, запущенной внутри докера.

EDIT:: ----- решение, которое работало ------

Спасибо RICO. Наконец, шаги, которые работали для меня, - это

1. Start docker quick terminal
2. docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password -d mysql/mysql-server:latest
3. docker exec -it mysql bash
4. mysql -uroot -p
5. create database MyDB;
6. GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password';
7. exit;
8. docker-machine env default

Используйте IP-адрес, полученный на шаге 8. Порт 3306, пользователь root, пароль - пароль, база данных - MyDB.

Соединение выполнено успешно!

Ответ 1

Таким образом, вам в основном нужно открыть порт mysql для вашего хоста:

docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password -d mysql/mysql-server:latest

Затем вы можете получить доступ к вашему хосту с помощью командной строки mysql:

mysql -h127.0.0.1 -ppassword -uroot

Не знаете, почему вы пытаетесь запустить другой контейнер для подключения (возможно, вы имели в виду ссылку на два контейнера).

Если вы используете Mac (или Windows) с док-станцией, вы хотите подключиться к IP-адресу вашей виртуальной машины докеров. Например:

$ docker-machine ssh default
                        ##         .
                  ## ## ##        ==
               ## ## ## ## ##    ===
           /"""""""""""""""""\___/ ===
      ~~~ {~~ ~~~~ ~~~ ~~~~ ~~~ ~ /  ===- ~~~
           \______ o           __/
             \    \         __/
              \____\_______/
 _                 _   ____     _            _
| |__   ___   ___ | |_|___ \ __| | ___   ___| | _____ _ __
| '_ \ / _ \ / _ \| __| __) / _` |/ _ \ / __| |/ / _ \ '__|
| |_) | (_) | (_) | |_ / __/ (_| | (_) | (__|   <  __/ |
|_.__/ \___/ \___/ \__|_____\__,_|\___/ \___|_|\_\___|_|
Boot2Docker version 1.9.0, build master : 16e4a2a - Tue Nov  3 19:49:22 UTC 2015
Docker version 1.9.0, build 76d6bc9
[email protected]:~$ ifconfig eth1
eth1      Link encap:Ethernet  HWaddr 08:00:27:E6:C7:20
          inet addr:192.168.99.100  Bcast:192.168.99.255  Mask:255.255.255.0
          inet6 addr: fe80::a00:27ff:fee6:c720/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:18827 errors:0 dropped:0 overruns:0 frame:0
          TX packets:10280 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:1791527 (1.7 MiB)  TX bytes:2242596 (2.1 MiB)

Затем подключитесь к:

mysql -h192.168.99.100 -ppassword -uroot