Docker安装完毕后默认是不支持IPV6方式监听和访问的,如果您的服务器支持IPV6,且有IPV6需求,可以通过下面的方法启用IPV6支持。
先来说说我的场景,最近有个特殊需求,要求容器的某个端口只能通过IPV6访问,不支持IPV4访问。然而默认的情况却与之相反,现目前支持IPV4访问,但不支持IPV6访问。因此需要先将Docker启用IPV6支持并设置IPV6监听。
修改Docker配置文件/etc/docker/daemon.json
,如果没有就自己新建一个。然后复制下面的内容并保存:
{ "ipv6": true, "fixed-cidr-v6": "2001:db8:1::/64"}
2001:db8:1::/64
是一个虚拟的IPV6网段,保持上面默认的复制下来即可。然后输入命令:systemctl reload docker
重载一次Docker服务,这样Docker就支持IPV6的监听和访问了。
如果要想实现上面的屏蔽IPV4访问,仅支持IPV6访问,还需要进一步操作。默认情况下我们可以通过-p
参数指定监听IP和映射端口,比如我们可以指定监听127.0.0.1:80
可以这样做:
docker run -itd --name="onenav" -p 127.0.0.1:80:80 \ -v /data/onenav:/data/wwwroot/default/data \ helloz/onenav:0.9.27
如果只需要支持IPV6监听和访问,那么在启动容器的时候我们需要在-p
参数后面使用[]
来指定IPV6的IP监听,比如:
docker run -itd --name="onenav" -p [2a12:a301:2::1126]:80:80 \ -v /data/onenav:/data/wwwroot/default/data \ helloz/onenav:0.9.27
[]
括起来2a12:a301:2::1126
改成您自己的公网IPV6地址如果需要同时支持IPV4和IPV6的监听和访问,那么只需要去掉-p
参数后面的IP地址,仅保留端口即可,比如:
docker run -itd --name="onenav" -p 80:80 \ -v /data/onenav:/data/wwwroot/default/data \ helloz/onenav:0.9.27
Copyright © 2013-2021 8a.hk All Rights Reserved. 八艾云 版权所有 中山市八艾云计算有限公司 粤ICP备14095776号