Докер-контейнер mysql получает удаленный хост: Соединение отклонено после запуска контейнера

Я попытался запустить несколько Docker-контейнеров MySQL на одном хост-сервере. После установки одного первого контейнера MySQL, он работает нормально. После того же шага я установил второй и изменил рабочий порт с 3306 на 3307 и использовал другой путь dump.sql. После запуска контейнера я не могу telnet контейнер с ip контейнера с портом, но я могу пропинговать ip. Это показывает, что Соединение отказано. Попытка добавить строку bind-address=0.0.0.0 в /etc/my.cnf и перезапустить контейнер, и проблема остается той же. Я вижу запуск второго контейнера mysql и могу выполнить некоторую команду над контейнером, но примерно через 1 минуту контейнер автоматически останавливается

usr@ip-172-0-1-199:~/$ docker run --name=test-db -p 3310:3306 -e MYSQL_ROOT_PASSWORD=pass -e MYSQL_USER=user -e MYSQL_DATABASE=db -e MYSQL_PASSWORD=pass -v dump.sql:/var/lib/mysql -d mysql/mysql-server:5.7
0e3fbcbd9126a726584549a13248eb07eb7d97fbeba4795fb5a924037a66b205
usr@ip-172-0-1-199:~/$ docker ps
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS              PORTS                               NAMES
0e3fbcbd9126        mysql/mysql-server:5.7   "/entrypoint.sh mysql"   29 seconds ago      Up 28 seconds       33060/tcp, 0.0.0.0:3310->3306/tcp   test-db
usr@ip-172-0-1-199:~/$ docker inspect --format '{{ .NetworkSettings.IPAddress }}' test-db
172.17.0.4
usr@ip-172-0-1-199:~/$ telnet 172.17.0.4 3310
Trying 172.17.0.4...
telnet: Unable to connect to remote host: Connection refused
usr@ip-172-0-1-199:~/$ ping 172.17.0.4
PING 172.17.0.4 (172.17.0.4) 56(84) bytes of data.
64 bytes from 172.17.0.4: icmp_seq=1 ttl=64 time=0.037 ms
^C
--- 172.17.0.4 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 1999ms
rtt min/avg/max/mdev = 0.037/0.042/0.053/0.009 ms
usr@ip-172-0-1-199:~/$ docker ps
CONTAINER ID        IMAGE                    COMMAND                  CREATED              STATUS              PORTS                               NAMES
0e3fbcbd9126        mysql/mysql-server:5.7   "/entrypoint.sh mysql"   About a minute ago   Up About a minute   33060/tcp, 0.0.0.0:3310->3306/tcp   test-db
usr@ip-172-0-1-199:~/$ docker ps -a
CONTAINER ID        IMAGE                    COMMAND                  CREATED              STATUS                      PORTS                               NAMES
0e3fbcbd9126        mysql/mysql-server:5.7   "/entrypoint.sh mysql"   About a minute ago   Up About a minute           33060/tcp, 0.0.0.0:3310->3306/tcp   test-db
usr@ip-172-0-1-199:~/$ docker exec test-db "exec mysql -h 172.17.0.4 -u user -p"
Error response from daemon: Container 0e3fbcbd9126a726584549a13248eb07eb7d97fbeba4795fb5a924037a66b205 is not running
usr@ip-172-0-1-199:~/$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
usr@ip-172-0-1-199:~/$ docker ps -a
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS                      PORTS                               NAMES
0e3fbcbd9126        mysql/mysql-server:5.7   "/entrypoint.sh mysql"   2 minutes ago       Exited (1) 37 seconds ago                                       test-db

1 ответ

Задавать MYSQL_ROOT_HOST=% разрешить root-вход с любого IP.

docker run --name mysql -p 3306:3306 \
-e MYSQL_RANDOM_ROOT_PASSWORD=yes \
-e MYSQL_ROOT_HOST=% -d mysql/mysql-server:latest
Другие вопросы по тегам