2

I have:

  • apache+php docker container (net=host)
  • mongo docker container (net=host)
  • mysql docker container (net=host)

In the first container, A php script is dumping a database from mysql and migrating processed data to mongodb. It write to mongodb, but a mysqldump command called from the script is not working. This is the mysqldump command

mysqldump -h 127.0.0.1 -u xxxxx -pxxxxxx 

Got below error

 mysqldump: Got error: 2003: Can't connect to MySQL server on
 '127.0.0.1' (111) when trying to connect

Note that this script is working on production without docker. I tried to add:

--protocol=TCP
--port=3307

Also tried to change 127.0.0.1 to mysql ( container name ) but maybe it dont works with (net=host), but it still doesn't work.

If i do mysql -h 127.0.0.1 -u xxxx -pxxxx from the php container it works, but no from php script.

Commands i use to launch containers:

docker run --restart=unless-stopped --net=host --name mysql   -v /opt/mysql/mysql_config:/etc/mysql/conf.d -v /opt/mysql/mysql_data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=xxxxx -d mysql:5.6

docker run --restart=unless-stopped --net=host --name apachephp -d apachephp 
3
  • 1
    how you start contaner? and If mysql command like work then script should also work! Commented Jun 30, 2020 at 15:51
  • Hi, @Adiii i updated my question. Commented Jun 30, 2020 at 15:54
  • Why are you running all of these things on the host network? That generally disables the Docker networking stack, and it's not necessary for typical TCP services like MySQL or an HTTP daemon. Commented Jun 30, 2020 at 16:07

1 Answer 1

1

The first option is better to use docker-compose networking. But providing a solution base on your current problem.

Using the Host network, the container does not get IP and linking does not work.

so the quick way to fix it can be remove --net host and add linking or you can create docker network as well.

You can publish port if you want to connect from host.

docker run --restart=unless-stopped  --name mysql   -v /opt/mysql/mysql_config:/etc/mysql/conf.d -v /opt/mysql/mysql_data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=xxxxx -d mysql:5.6

docker run --restart=unless-stopped --link mysql --name apachephp -d apachephp 

Now you will be able to access MySQL using below command from PHP container.

mysql -h mysql -uroot -ppassword
Sign up to request clarification or add additional context in comments.

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.