svo*_*oop 3 bridge docker docker-compose
我正在运行一个启用了“userns-remap”的dockerized GitLab 实例,并且我想在主机上使用共享的 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:
(...)
Run Code Online (Sandbox Code Playgroud)
感谢您的任何提示!
小智 7
该选项是网络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
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4871 次 |
| 最近记录: |