手把手教你如何给 Docker 开启 IPv6 网络支持

系统 Linux
本文最重要的先决条件是主机商已经分配给你一个公网 IPv6 地址段,我们可以通过查看主机控制面板中信息、询问主机供应商或者直接SSH登录主机使用命令ip -f inet6 addr show eth0获取。

[[416156]]

Docker 默认是不开启 IPv6 支持的,但是我们某些业务往往又需要 IPv6 的支持,特别是 IPv6 普及大势所趋,本文主要介绍的是如何开启 Docker 桥接网络 IPv6 支持,这篇文章具体操作仅供参考,建议以官方文档为准。

本文最重要的先决条件是主机商已经分配给你一个公网 IPv6 地址段,我们可以通过查看主机控制面板中信息、询问主机供应商或者直接SSH登录主机使用命令ip -f inet6 addr show eth0获取。命令方式获取的 ipv6 地址输出如下: 

  1. 6: eth0:  mtu 9000   
  2.     inet6 2607:f0d0:1002:51::4/64 scope global   
  3.        valid_lft forever preferred_lft forever  
  4.     inet6 fe80::230:48ff:fe33:bc33/64 scope link   
  5.        valid_lft forever preferred_lft forever 

其中inet6 2607:f0d0:1002:51::4/64 scope global这行指示的IPv6地址是我们需要的目标地址,注意我们这里选取的是公网IP,也就是后面scope global指示的,大家注意到后续还有一个fe80 开头的 IPv6 地址,这个后面没有 global,也就是通常意义内网 IPv6,本文不使用,当然读者可以根据实际需要选择内网 IPv6 继续参照下面介绍的步骤完成操作。

1、IPv6 地址段划分

Docker 可以配置多个虚拟网络,对于 IPv4 来说通过形如 172.17.0.1/16、172.18.0.1/16、172.19.0.1/16 这样内网私有IP地址段配置多个 IPv4 虚拟网段,那么同样的道理 IPv6 也建议划分多个段,如果手动划分不便,可以通过 IPv6 Subnetting Calculator自动划分,如下图所示:

比如刚才的 IPv6 地址划分为 4 个网段如下: 

  1. 2607:f0d0:1002:51::/66  
  2. 2607:f0d0:1002:51:4000::/66  
  3. 2607:f0d0:1002:51:8000::/66  
  4. 2607:f0d0:1002:51:c000::/66 

2、配置默认 Docker IPv6

编辑 Docker 配置文件/etc/docker/daemon.json,如果该文件不存在,请手动建立。配置文件内容如下,如果你已有的配置文件缺少相应的配置项,添加上即可,没有必要完全覆盖内容。 

  1.  
  2.   "experimental": true,  
  3.   "ipv6": true,  
  4.   "ip6tables": true,  
  5.   "fixed-cidr-v6": "2607:f0d0:1002:51::/66"  

这里ip6tables是指由 Docker 自动配置 IPv6 的防火墙规则,如果你希望自己手动配置,请改为 false 或者移除此项,否则容器将无法连接 IPv6 网络;fixed-cidr-v6 则是我们划分的子网段的第一个,这里仅作示例请读者根据实际情况修改。

完成配置后请使用systemctl restart docker重启docker服务生效。完成此步后 Docker 算是完成对于 IPv6 的支持了。

3、配置 Docker Compose 的 IPv6 支持(可选)

这个主要是我编排容器时用的比较多,这里也记录一下作为一个备忘吧。

Docker Compose 的配置文件内容关于 IPv6 部分重点是网络节配置,如果另外配置网络的话,必须选择与默认daemon.json不同的 IPv6 子网段,例如: 

  1. networks:  
  2.   example:  
  3.     enable_ipv6: true  
  4.     driver: bridge  
  5.     driver_opts:  
  6.       com.docker.network.enable_ipv6: "true"  
  7.     ipam:  
  8.       config:  
  9.        - subnet: 172.23.0.0/16  
  10.        - subnet: "2607:f0d0:1002:51:4000::/66"  
  11.          gateway:2607:f0d0:1002:51:4000::1 

这里example网络我们通过配置开启IPv6支持,其中网络段配置IPv4是172.23.0.0/16,IPv6选用余下的第二个网段2607:f0d0:1002:51:4000::/66注意这里不能和daemon.json配置的 IPv6 网段一样。这里的 IP 配置同样是一个示例,读者请根据实际情况进行修改。

4、参考资料

  •  Enable IPv6 support 

 

责任编辑:庞桂玉 来源: 奇妙的Linux世界
相关推荐

2021-11-09 06:55:03

水印图像开发

2020-09-16 06:19:50

IPV6网络协议IPv4

2020-08-12 07:41:39

SQL 优化语句

2018-05-22 15:30:30

Python网络爬虫分布式爬虫

2011-05-03 15:59:00

黑盒打印机

2011-01-10 14:41:26

2022-12-07 08:42:35

2022-07-27 08:16:22

搜索引擎Lucene

2010-07-06 09:43:57

搭建私有云

2010-07-06 09:38:51

搭建私有云

2019-06-05 15:43:34

IPV6IPV4网站

2021-02-26 11:54:38

MyBatis 插件接口

2011-02-22 13:46:27

微软SQL.NET

2021-12-28 08:38:26

Linux 中断唤醒系统Linux 系统

2018-05-16 15:46:06

Python网络爬虫PhantomJS

2009-12-24 13:52:57

网络接入控制解决方案

2010-05-31 13:14:00

移动IPv6

2009-03-18 11:36:21

代理服务器下载MyEclipse7.

2009-06-05 09:49:18

修改.NET Frammscorlib.dl

2020-03-04 09:25:39

Python网络安全WiFi
点赞
收藏

51CTO技术栈公众号