docker & docker-compose 自定义容器 ip, 彻底解决容器 ip 冲突问题

容器已经作为目前部署架构的主要角色了,当然我这里主要说的还是 Docker, 今天这篇文章就简要记录一下用到的一个小技巧:自定义容器运行时的IP分配。

本文会介绍基于 docker 及 docker-compose 的两种 IP 自定义配置介绍。

背景

默认情况下,docker 安装后 本机会多出一个虚拟网卡,其网卡 IP 段为:172.17.0.0/24

3: docker0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default 
    link/ether 02:42:0f:4a:a1:32 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.1/24 brd 172.17.0.255 scope global docker0
       valid_lft forever preferred_lft forever
    inet6 fe80::42:fff:fe4a:a132/64 scope link 
       valid_lft forever preferred_lft forever

如果你是单机环境,倒无所谓,但是对于企业多机器,多网络环境情况下,有可能会出现网络冲突。

为了应对网络冲突问题,docker & docker-compose 都想到了这个问题,当然解决方式也是比较简单。

我们分别介绍一下。

docker

官方指导文档在这里:

https://docs.docker.com/reference/cli/dockerd/

常见的可以通过 2 种方式:

  • dockerd 命令后加参数 --bip

  • 配置 /etc/docker/daemon.json 配置文件

我当然喜欢第 2 种了,话不多说,直接上配置(其中的 bip 字段设置的就是 ip 段):

{
  "max-concurrent-downloads": 10,
  "log-driver": "json-file",
  "log-level": "warn",
  "log-opts": {
    "max-size": "10m",
    "max-file": "3"
    },
  "bip": "179.30.0.1/24",
  "data-root": "/var/lib/docker"
}

这样设置之后,重启 docker, 再运行容器,默认分配的就是新的网段IP了。

最开始,笔者以为更改了 docker, 那 docker-compose 运行的不也就是 跟 docker 一样嘛?

直到第 2 天,同事跟我说,机器连不上内部监控系统(监控系统所在网段就是 172.17),这才知道,原来 docker-compose 跟 docker 不是一体啊!

继续开整。

docker-compose

同样,官网文档在这里:

https://docs.docker.com/compose/compose-file/06-networks/

我不饶弯子了,我也没有细研究,主打一个吃好够用,直接上实例,大家有兴趣自行阅读文档吧。

services:
  logstash:
    image: logstash:7.17.22
    restart: always
    networks:
      - logstash
    volumes:
      - ./logstash.yml:/usr/share/logstash/config/logstash.yml
      - ./conf/logstash.conf:/usr/share/logstash/pipeline/logstash.conf
      - /var/log:/var/log

networks:
  logstash:
    ipam:
      driver: default
      config:
        - subnet: "172.22.0.0/24"
          gateway: 172.22.0.1

再通过 docker-compose 启动的容器,其 IP 就变了。

总结

今天的内容主要介绍了 docker & docker-compose 如何自定义 IP 段,避免在复杂网络环境下产生冲突。

更多配置,请查阅文章中贴的文档,祝大家学有所成。

也欢迎大家关注我的公&号:新质程序猿,获取更多干货资料,一起探索成长之路。

### 配置 Docker Compose 中的自定义 IP 和 MAC 地址 #### 创建自定义网络并指定子网 为了为容器分配固定的 IP 地址,首先需要创建一个带有特定子网的自定义 Docker 网络。这可以通过 `docker network create` 命令实现。 ```bash docker network create \ --subnet=192.168.1.0/24 \ my_custom_network ``` 上述命令会创建一个名为 `my_custom_network` 的网络,并为其分配子网 `192.168.1.0/24`[^1]。 #### 在 `docker-compose.yml` 文件中配置静态 IP 地址 接下来,在 `docker-compose.yml` 文件中声明该服务使用的网络以及其对应的静态 IP 地址: ```yaml version: &#39;3.8&#39; services: app: image: your_image_name networks: custom_net: ipv4_address: 192.168.1.100 networks: custom_net: driver: bridge ipam: config: - subnet: 192.168.1.0/24 gateway: 192.168.1.1 ``` 在此配置中,`app` 服务被赋予了一个固定的 IPv4 地址 `192.168.1.100`,并且它运行在一个具有预定义子网和网关的桥接网络上[^3]。 #### 设置自定义 MAC 地址 Docker 并不直接支持在 `docker-compose.yml` 文件中设置容器的 MAC 地址。然而,可以借助于 `--mac-address` 参数手动启动容器来完成这一操作。如果希望在 Docker Compose 上下文中应用此功能,则需扩展脚本逻辑或利用插件工具辅助执行。 例如,单独启动带定制化 MAC 地址的 Redis 容器可如下所示: ```bash docker run --rm -d --name redis_container \ --net=my_custom_network \ --ip=192.168.1.100 \ --mac-address=&quot;02:42:ac:11:00:0a&quot; \ redis:7.2.3 ``` 对于更复杂的场景,可能考虑编写 shell 脚本来批量处理此类需求[^4]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值