I am setting up my local development environment with docker containers. The docker-compose.yml is like following
version: '2'
services:
db:
image: mongo:3
mq:
image: rabbitmq:3
api:
build: .
image: my_app/api
ports:
- "3000:3000"
links:
- db
- mq
environment:
- NODE_ENV=development
It starts without error. And docker lists 3 running containers
docker-compose up -d
docker ps
e90e5a8b5d33 my_app/api "/usr/local/bin/node " 0.0.0.0:3000->3000/tcp my_app_api_1
42bfcd971b16 mongo:3 "/entrypoint.sh mongo" 27017/tcp my_app_db_1
a0685a816c47 rabbitmq:3 "/docker-entrypoint.s" 4369/tcp, 5671-5672/tcp, 25672/tcp my_app_mq_1
However when I try to link to those running containers from another container
docker run --link my_app_mq_1:mq --link my_app_db_1:db -it worker
I get error
docker: Error response from daemon: Cannot link to /my_app_mq_1, as it does not belong to the default network.
I have also tried
docker run --link my_app_mq_1:mq --link my_app_db_1:db -it --net default worker
Same error.
So how can I link to a running container started by docker-compose?
When you use service definition version 2 and more,
docker-compose
creates user-defined network. Name resolution in a user-defined network works via Docker embedded DNS server. Here's related quote from documentation:Containers are also available by network aliases that
docker-compose
creates. It can be verified by command like:It prints
["db","$CONTAINER_ID"]
.Providing links with
--link
will not have any effect in case of existing user-defined network. You can make sure and look at/etc/hosts
, which will not have the corresponding lines.Thus the following command is sufficient:
my command to run links
Ok, found the answer to it. In case anyone else comes across the same problem, just do
This command lists all the docker networks. docker-compose will create a new network when you run docker-compose up. In my case, the network is named as myapp_default.
So the correct way to link to those containers is