如何在群晖中,正确配置 docker 的 ipv6 地址

关于这个话题,国内搜索引擎得到的结果出奇的一致,且过时。

(看的我脑壳痛)
(何为万众一心,齐心协力,见识到了)

这里记录我认为的,正确的,便捷的,配置方法 for 有缘人

方法一: 通过 docker web ui 配置 ipv6 网络

国内教程千篇一律说要 ssh 连接后台改 docker 配置,诸如:
/var/packages/Docker/etc/dockerd.json
/volume1/@appconf/Docker/dockerd.json
/usr/syno/etc/packages/Docker/dockerd.json
(用 /var/packages/Docker/scripts/start-stop-status 启停)

bash 复制代码
{
  "ipv6": true,
  "fixed-cidr-v6": "2001:db8:1::/64",
  "experimental": true,
  "ip6tables": true
}

大概是受到,这篇 docker 官方文档的影响:(假设cver们懂看官方文档)
https://docs.docker.com/config/daemon/ipv6/

其实完全不用,群晖早在 17年 就支持 ipv6 的 web ui 配置了
https://www.synology.com/en-br/releaseNote/Docker

相比 global 全局 的配置 network,单独添加好处:

  1. web ui 支持,无需 ssh 进入后台设置
  2. 影响可控/影响范围小 ------ 哪个需要给哪个开 ipv6

方法二: 通过 cli 添加 docker network (包括分析IP地址如何选择)

命令行添加更方便管理 docker / docker-compose

参考:
https://gdevillele.github.io/engine/userguide/networking/default_network/ipv6/
https://dev.to/joeneville_/build-an-ipv6-network-with-docker-compose-434i
https://stackoverflow.com/questions/39649458/how-to-assign-ipv6-address-with-docker-compose

创建虚拟网卡

bash 复制代码
docker network create --ipv6 \
 --subnet=172.16.2.0/24 \
 --gateway=172.16.2.1  \
 --subnet=<mynetv6-prefix/subnet> \
 --gateway=<mynetv6-gw> \
 mynetv6-1

or

bash 复制代码
# 自动选择 ipv4 内网地址段
docker network create --ipv6 \
 --subnet=<mynetv6-prefix/subnet> \
 --gateway=<mynetv6-gw> \
 mynetv6-1

or

bash 复制代码
# 自动选择 ipv4 内网地址段
# 自动决定 ipv6 网关
docker network create --ipv6 \
 --subnet=<mynetv6-prefix/subnet> \
 mynetv6-1

<mynetv6-prefix/subnet><mynetv6-gw> 如何填写?

建议写一个 nat6 地址 (ipv6的局域网网端)
fc00::/7
fc00::/8 (未启用)
fd00::/8 (推荐)

e.g.
fd00:996:996:996::/64 - subnet
fd00:996:996:996::1 - gw

更多 ipv6 网络划分等基础概念,推荐参考:

  1. 视频 - 中文 by 老湿基 - https://www.bilibili.com/video/BV1N14y1j7Ku/
  2. 视频 - 德国人说英文 by OneMarcFifty - https://www.youtube.com/watch?v=oItwDXraK1M
  3. 文字 (推荐) - IPv6 Cheat Sheet - https://github.com/onemarcfifty/cheat-sheets/blob/main/networking/ipv6.md

测试

bash 复制代码
docker run --rm --name testnetv6 --network ip6net -p 80:80 traefik/whoami 
bash 复制代码
$ curl http://[::1]:80
Hostname: d87e379f092b
IP: 127.0.0.1
IP: ::1
IP: 172.22.0.2
IP: fdff:db80:ab::2
IP: fe80::42:acff:fe16:2
RemoteAddr: [fdff:db80:ab::1]:51470
GET / HTTP/1.1
Host: [::1]:80
User-Agent: curl/7.79.1
Accept: */*

例子: 配置 docker qbittorrent ipv6 nat6 端口映射 外网访问

NAS fd00::/80
port:18888 2400::/60
port:18888 fd00:abcd::/64
port:18888 docker qbittorrent ISP router

todo

相关推荐
rkmhr_sef2 分钟前
Nginx反向代理出现502 Bad Gateway问题的解决方案
运维·nginx·gateway
孙同学_1 小时前
【Linux篇】调试器-gdb/cgdb使用
linux·运维·服务器
自由鬼1 小时前
免费开源抓包工具Wireshark介绍
运维·服务器·网络·测试工具·网络安全·wireshark
汤姆和杰瑞在瑞士吃糯米粑粑1 小时前
【Linux学习篇】--开发工具第一期
linux·运维·学习
Richard_Yang1 小时前
基于OpenObserve实现分布式系统监控(1)
运维
dessler2 小时前
DeepSeek-进阶版部署(Linux+GPU)
linux·运维·服务器·云原生·大模型·deepseek
fanxiaohui121383 小时前
元脑服务器:浪潮信息引领AI基础设施的创新与发展
运维·服务器·人工智能
毫无存在感的码农3 小时前
一、Jenkins简单配置(使用语言、凭证、SSH)
运维·ssh·jenkins
猴的哥儿4 小时前
Ubuntu 22.04 LTS 入门教学文档
linux·运维·ubuntu·docker
纷飞梦雪6 小时前
使用chroot预安装软件到ubuntu22中
linux·运维·ubuntu