Meu objetivo era queJenkinscontainer irá "conversar" comAnsiblecontêiner para criarJenkinsarquivo paraJenkinsgasoduto.
Eu esperava que esses dois contêineres se "juntassem"ponterede e obtém 2 endereços IP com o mesmo ID de rede, mas em vez disso foram criadas duas redes adicionais e cada contêiner obteve IP com ID de rede diferente.
Além disso, espera-se que esses dois contêineres tenham acesso à internet.
Então, no meu Windows 10 estou executando o Docker Desktop, tenho 2 arquivos docker-compose.yml,
um, paraJenkinsrecipiente:
version: '3.7'
services:
jenkins:
image: jenkins/jenkins:lts
privileged: true
user: root
ports:
- 8080:8080
- 50000:50000
container_name: jenkins
Outro, porAnsiblerecipiente:
version: '2'
services:
ansible:
container_name: ansible
hostname: ansible
image: ansible
volumes:
- ~/product/ansible:/ansible
working_dir: /ansible
build:
context: .
dockerfile: Dockerfile
dns:
- 200.20.200.20
Executei o seguinte comando para cada arquivo docker-compose.yml, então tive duas máquinas separadas:
docker-compose up --build
Inspecionei os detalhes da rede do meu contêiner e descobri que cada contêiner recebeu um ID de rede diferente, veja abaixo:
PS > docker inspect -f '{{range.NetworkSettings.Networks}}{{.IPAddress}}{{end}}' ansible
172.18.0.2
PS > docker inspect -f '{{range.NetworkSettings.Networks}}{{.IPAddress}}{{end}}' jenkins
172.19.0.2
verifique minha seção de redes docker, revelou que mais 2 redes foram criadas, alémponte,hospedarenenhum:
PS > docker network ls
NETWORK ID NAME DRIVER SCOPE
8cefaed24885 ansible_default bridge local
44bedcd1622d bridge bridge local
61e1c7f7051e host host local
b5a7a7a424a4 jenkins_default bridge local
4e5d6c77cb5a none null local
Claro, inspecionarponterede mostra querecipientea chave está vazia:
{
"Name": "bridge",
"Id": "44bedcd1622d820ce4e29a5cd545f244ba2d303102f1956fe76069a63e7c220e",
"Created": "2021-08-25T13:13:57.6577149Z",
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.17.0.0/16",
"Gateway": "172.17.0.1"
}
]
},
"Internal": false,
"Attachable": false,
"Ingress": false,
"ConfigFrom": {
"Network": ""
},
"ConfigOnly": false,
"Containers": {},
"Options": {
"com.docker.network.bridge.default_bridge": "true",
"com.docker.network.bridge.enable_icc": "true",
"com.docker.network.bridge.enable_ip_masquerade": "true",
"com.docker.network.bridge.host_binding_ipv4": "0.0.0.0",
"com.docker.network.bridge.name": "docker0",
"com.docker.network.driver.mtu": "1500"
},
"Labels": {},
"CreatedTime": 1629897237657
}
Minha pergunta é:
a) Por que mais duas redes docker foram criadas quando executei docker-compose up --build
o comando?
b)Como posso fazer esses contêineres funcionarem componterede e obter IPs do mesmo ID de rede(o ID da rede bridge 172.17.xx) para que eles conversem entre si?
Responder1
A solução para conectar várias instâncias do docker-compose é usar redes externas.
Primeiro crie uma nova rede com o comando:
docker network create my-network
Em seguida, adicione ao docker-compose.yml o seguinte:
networks:
my_network:
external: true
E na seção de rede dos serviços:
(...)
networks:
- my_network
(...)
O docker-compose do Jenkins se tornaria:
version: '3.7'
networks:
my_network:
external: true
services:
jenkins:
image: jenkins/jenkins:lts
privileged: true
user: root
networks:
- my_network
ports:
- 8080:8080
- 50000:50000
container_name: jenkins
Siga a mesma ideia para o outro docker-compose.yml.