Docker 网桥映射到 HOST OS 网络接口

问题描述

嗨,我是 docker network 的新人。基本上我想启动一个应该与现有 HOST OS 网络接口映射的 docker 容器。

例如HOST OS 网络接口列表

$>>ip a
1. ens192: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000 
4. ens224: <BROADCAST,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000

现在我想使用

创建一个Docker网桥(用ens192/ens224映射)

$ docker network create -d bridge my-bridge-network

然后使用 docker network

运行容器

$ docker run -itd --network=my-bridge-network mydocker

但通过上述步骤,我无法将 network interfacesdocker networks 映射。

解决方法

目标

假设您希望 Docker 容器作为普通设备显示在网络上,您可以使用 macvlan 网桥“映射”主机接口。你会得到什么:

  • Docker 客户端从主机所在的网络接收 IP
  • 其他设备可以像访问物理网络一样访问容器
  • 容器可以通过给定的接口访问与其主机相同的主机

如果这不是您的意思,请发表评论并进一步解释您的情况。

它是如何完成的

检查天气 macvlan 模块是否安装使用

lsmod | grep macvlan

如果未列出,请通过发出安装

modprobe macvlan

使用 Docker CLI

使用您要共享的接口创建网络并指定子网和网关(如果您想通过此网络使用互联网,网关是可选的):

docker network create -d macvlan --subnet=1.2.3.4/24 --gateway=1.2.3.1 -o parent=eth0 nice_name

(父级必须从 eth0 更改为您的界面)

使用 Docker-Compose

您还可以按需创建这些网络并将它们包含在您的 docker-compose.yml 文件中,如下例所示:

version: '3.3'
services:

  nginx1:
    restart: unless-stopped
    image: nginx:latest
    networks:
      - nice_name

networks:
  private:
  nice_name:
    driver: macvlan
    driver_opts:
      parent: eth0  # change this
    ipam:
      config:
        - subnet: "1.2.3.0/24" # change this
          gateway: "1.2.3.1" # change this (optional)

# Be aware that there is no "-" before "gateway" as it belongs to the subnet!

如果您已经在 Docker-Compose 之外创建了网络,您仍然可以使用 external 参数将使用 Docker-Compose 的客户端连接到它:

version: '3.3'
services:

  nginx1:
    restart: unless-stopped
    image: nginx:latest
    networks:
      - nice_name

networks:
  nice_name:
    external: true

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...