Docker acessível via localhost:8080 e 127.0.0.1:8080, mas não via IP

Docker acessível via localhost:8080 e 127.0.0.1:8080, mas não via IP

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`

informação relacionada