Eu tenho o cenário abaixo - 3x VMs Vagrant são geradas a partir do Vagrantfile abaixo, instaladas e em execução (visíveis no Oracle VirtualBox).
Estou logado no docker1, o tipo de rede é "NAT", o encaminhamento de porta é usado (Guest:8080, Host:8080).
Consigo acessar a página de localhost:8080 & 127.0.0.1:8080 & 127.0.1.1:8080. Porém, não tenho acesso via IP (192.168.99.101:8080 está "Demorando muito para responder" e não pode ser alcançado).
Vagrant.configure("2") do |config|
config.vm.define "docker1" do |docker1|
docker1.vm.box="xxx/centos-stream-8"
docker1.vm.hostname = "docker1.do1.lab"
docker1.vm.network "private_network", ip: "192.168.99.101"
docker1.vm.provision "shell", path: "docker-setup.sh"
docker1.vm.provision "shell", path: "other-steps.sh"
docker1.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--memory", "1536"]
end
end
config.vm.define "docker2" do |docker2|
docker2.vm.box="xxx/centos-stream-8"
docker2.vm.hostname = "docker2.do1.lab"
docker2.vm.network "private_network", ip: "192.168.99.102"
docker2.vm.provision "shell", path: "docker-setup.sh"
docker2.vm.provision "shell", path: "other-steps.sh"
docker2.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--memory", "1536"]
end
end
config.vm.define "docker3" do |docker3|
docker3.vm.box="xxx/centos-stream-8"
docker3.vm.hostname = "docker3.do1.lab"
docker3.vm.network "private_network", ip: "192.168.99.103"
docker3.vm.provision "shell", path: "docker-setup.sh"
docker3.vm.provision "shell", path: "other-steps.sh"
docker3.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--memory", "1536"]
end
end
end
o arquivo docker-setup.sh está abaixo:
#!/bin/bash
echo "* Add Docker repository ..."
dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
echo "* Install Docker ..."
dnf install -y docker-ce docker-ce-cli containerd.io
echo "* Enable and start Docker ..."
systemctl enable docker
systemctl start docker
echo "* Add vagrant user to docker group ..."
usermod -aG docker vagrant
o arquivo other-steps.sh está abaixo:
#!/bin/bash
echo "* Add hosts ..."
echo "192.168.99.101 docker1.do1.lab docker1" >> /etc/hosts
echo "192.168.99.102 docker2.do1.lab docker2" >> /etc/hosts
echo "192.168.99.103 docker3.do1.lab docker3" >> /etc/hosts
echo "* Install Additional Packages ..."
dnf install -y jq tree git nano
echo "* Firewall - swarm - open ports ..."
firewall-cmd --add-port=2377/tcp --permanent
firewall-cmd --add-port=4789/udp --permanent
firewall-cmd --add-port=7946/tcp --permanent
firewall-cmd --add-port=7946/udp --permanent
echo "* Firewall - app - open port 8080 ..."
firewall-cmd --add-port=8080/tcp --permanent
firewall-cmd --reload
As redes estão abaixo:
[vagrant@docker1 etc]$ docker network ls
NETWORK ID NAME DRIVER SCOPE
f2351cd29061 bridge bridge local
f91a21d83931 docker_gwbridge bridge local
c5fc9aedf330 host host local
oc2i4c2czira ingress overlay swarm
50fe2b72573c none null local
O conteúdo do etc/hosts está aqui:
[vagrant@docker1 etc]$ cat hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
127.0.1.1 docker1.do1.lab docker1
192.168.99.101 docker1.do1.lab docker1
192.168.99.102 docker2.do1.lab docker2
192.168.99.103 docker3.do1.lab docker3
O comando usado para ativar um contêiner é o abaixo:
docker container run -d --name web -p 8080:80 -e APP_MODE='test' swarm-app
Pesquisei vários artigos com o mesmo problema, mas ainda não consigo encontrar uma solução. Suponho que isso possa ter algo a ver com a resolução DNS do endereço IP em questão.
Atualização: estou abrindo no CMD via curl os endereços abaixo (Port Forwarding Host:8080, Guest:80), se houver alguma informação a fornecer, por favor me avise: `[vagrant@docker1 ~]$ curl http:/localhost:8080-> não abre no navegador
Olá Docker Swarm!
Executando em modo de teste.Servido por:be93b0268b1d
[vagrant@docker1 ~]$ curlhttp://172.17.0.2:80 -> este é o IP do container - não abre pelo navegador
Olá Docker Swarm!
Executando em modo de teste.Servido por:be93b0268b1d
[vagrant@docker1 ~]$ curlhttp://192.168.99.101:8080 -> este é o IP do host Docker que deveria abrir através do navegador - também sem sucesso
Olá Docker Swarm!
Executando em modo de teste.Servido por:be93b0268b1d`