如何解决在 docker-compose.yml 中设置桥名称
我正在运行一个 dockerized GitLab 实例启用了“userns-remap”,我想在主机上使用共享的 PostgreSQL。然而,当我 docker-compose up 时创建的桥在每次运行时都会获得一个新的随机名称“br-xxxxxxxxxxxx”。
这通常不是问题,但主机上的 Vuurmuur 防火墙默认会阻止从容器到主机的所有流量,我需要网桥名称才能在 Vuurmuur 上设置允许规则。
我发现了许多相关主题,例如com.docker.network.bridge.name
,但我无法将它们拼凑在一起。到目前为止,我试图找到一种方法来确保每次升级容器时,网桥都会获得相同的名称和相同的 IP/掩码。这在 docker-compose.yml
中甚至是可能的,还是这种方法完全错误?
这是目前为止不起眼的 docker-compose.yml
:
version: '3.8'
services:
web:
image: 'gitlab/gitlab-ce:latest'
restart: always
hostname: 'gitlab.example.com'
environment:
GITLAB_OMNIBUS_CONFIG: |
external_url 'https://gitlab.example.com'
gitlab_rails['db_adapter'] = 'postgresql'
gitlab_rails['db_host'] = '172.18.0.1'
(...)
ports:
- '8080:80'
volumes:
(...)
感谢您的任何提示!
解决方法
该选项是网络 driver_opts
配置的一部分
$ cat docker-compose.yaml
---
services:
sleep:
image: ubuntu
command: [sh,-c,"sleep infity"]
networks:
demo:
networks:
demo:
driver_opts:
com.docker.network.bridge.name: br-demo
$ docker-compose up -d
Creating network "tmp_demo" with the default driver
Creating tmp_sleep_1 ... done
$ brctl show
bridge name bridge id STP enabled interfaces
br-demo 8000.02423d13fd2a no
docker0 8000.02428a615bfa no
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。