![Невозможно увидеть порты Docker с внешних машин при использовании интерфейса veth с OPNSense KVM](https://rvso.com/image/762136/%D0%9D%D0%B5%D0%B2%D0%BE%D0%B7%D0%BC%D0%BE%D0%B6%D0%BD%D0%BE%20%D1%83%D0%B2%D0%B8%D0%B4%D0%B5%D1%82%D1%8C%20%D0%BF%D0%BE%D1%80%D1%82%D1%8B%20Docker%20%D1%81%20%D0%B2%D0%BD%D0%B5%D1%88%D0%BD%D0%B8%D1%85%20%D0%BC%D0%B0%D1%88%D0%B8%D0%BD%20%D0%BF%D1%80%D0%B8%20%D0%B8%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B8%20%D0%B8%D0%BD%D1%82%D0%B5%D1%80%D1%84%D0%B5%D0%B9%D1%81%D0%B0%20veth%20%D1%81%20OPNSense%20KVM.png)
Краткое описание настройки:
- Ubuntu Server 20.04 с 4 сетевыми портами
- Маршрутизатор OPNsense, работающий в libvirt KVM
- Один порт — WAN, три порта — LAN (мостовое соединение)
- Роутер работает отлично
- Сервер (тот же, на котором запущен OPNsense) получает доступ к локальной сети и интернету по протоколу VETH через мост локальной сети
- Службы работают на различных портах сервера, и внешние машины могут получить к ним доступ.
- ПРОБЛЕМА: Если служба запущена в Docker, порты службы видны серверу, но не видны другим машинам в локальной сети (nmap отображает их как «отфильтрованные»).
- Проблема решается путем настройки контейнера Docker на работу в режиме «хоста», что, очевидно, не является оптимальным, поскольку сопоставление портов больше невозможно.
Почему внешние машины не видят порты, выставленные docker в этой настройке? Я понимаю, что это сложная сетевая настройка, и, вероятно, есть некоторый отсутствующий маршрут между docker VLAN и мостом VETH, но все, что я проверил, выглядит нормально. Демон Docker, похоже, настроен на прослушивание всех интерфейсов. Я в растерянности.