Konfiguruję swoje lokalne środowisko programistyczne z kontenerami Docker. Docker-compose.yml wygląda następująco
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
Zaczyna się bez błędów. Docker wyświetla 3 uruchomione kontenery
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
Jednak gdy próbuję połączyć się z tymi uruchamiającymi kontenery z innego kontenera
docker run --link my_app_mq_1:mq --link my_app_db_1:db -it worker
Otrzymuję błąd
docker: Error response from daemon: Cannot link to /my_app_mq_1, as it does not belong to the default network.
Ja też próbowałem
docker run --link my_app_mq_1:mq --link my_app_db_1:db -it --net default worker
Ten sam błąd.
Jak więc mogę utworzyć link do uruchomionego kontenera uruchomionego przez docker-compose?
źródło
--net
przed komendą. Napotkałem ten problem podczas próby uruchomienia oficjalnego obrazu dokera redis.moje polecenie uruchomienia linków
źródło
W przypadku korzystania z definicji usługi w wersji 2 lub
docker-compose
nowszej tworzy sieć zdefiniowaną przez użytkownika. Rozpoznawanie nazw w sieci zdefiniowanej przez użytkownika działa za pośrednictwem wbudowanego serwera DNS platformy Docker. Oto powiązany cytat z dokumentacji :Kontenery są również dostępne przez aliasy sieciowe, które
docker-compose
tworzy. Można to zweryfikować poleceniem takim jak:To drukuje
["db","$CONTAINER_ID"]
.Podanie linków za pomocą
--link
nie będzie miało żadnego efektu w przypadku istniejącej sieci zdefiniowanej przez użytkownika. Możesz się upewnić i spojrzeć na/etc/hosts
, który nie będzie miał odpowiednich linii.W związku z tym wystarczy polecenie:
źródło