Docker使用IPv6网络的终极方案:搭建macvlan实现IPv4&IPv6双通
wptr33 2025-01-27 00:38 21 浏览
【一文讲透】Docker容器使用IPv6网络的终极方案:搭建macvlan网络模式实现IPv4&IPv6双通
哈喽,小伙伴们!答应你们的事我来兑现了!
就在上篇教程文章中,我教大家怎么在Docker版的qBittorrent上开启IPv6为下载提速。其中有两个方案:一个是采用Host网络模式,一个是Portainer手动添加IPv6网络。
虽说那两种方案是目前最便捷的,但是都有弊端。Host网络因为和主机共有一个IP,后期随着我们NAS上搭建的服务越来越多,很有可能会造成端口冲突,而Portainer手动添加IPv6网络虽说可行,但是我通过这两天尝试,感觉这样添加的网络非常的不稳定,具体原因恕我不才,我也不知道为什么~
So,最终找到了一种适用于当前NAS上的Docker容器使用IPv6网络的终极方案,那就是:在Docker上搭建macvlan网络实现IPv4&IPv6双通!
关于什么是macvlan网络,这里我也不想多说(其实主要原因是太专业的知识俺也不资道~哈哈),有兴趣的请自行度娘。
我们只需要知道它其实就是相当于我们在NAS中虚拟出来了一张独立的物理网卡,并且它独立于NAS的IP,拥有自己独立的 mac 地址,这样的话,我们在这个网络模式下搭建的Docker容器就会和它共用IP,所以我们就不用担心端口会和NAS的IP端口发生冲突了~(不知道我说的够不够清楚?个人理解能力有限,表达能力也有限,你们将就看吧~)
PS:今天的教程不能直接抄作业,请务必根据你自己那边的实际情况来修改配置和命令!!!
macvlan网络模式的创建
在NAS的网络环境中,Docker默认的就三种网络模式:
- bridge: 桥接模式 [默认网络模式]
- host: 主机模式
- none: 无网络模式 [不常用-测试用]
所以我们首先需要创建macvlan网络模式。
接下来的操作就需要远程终端SSH连接NAS了。至于SSH工具请自行解决,Putty,XShell,FinalShell等都可以,我个人使用的是FinalShell。
使用SSH连接工具连接到NAS之后先改用管理员模式登录。直接输入命令“【sudo -i 】回车,提示输入密码,密码就是我们NAS的登录密码,输入的时候不会有显示,输入完成后直接点回车即可。当出现“root”的标识的时候(威联通是admin),说明我们现在就是管理员模式了。
不用管理员模式其实也行,主要是我个人习惯了管理员模式赋予的最大权限,避免了很多我也不知道的未知问题。
然后输入命令【docker network ls】确认我们当前docker的网络详情。我这边还是之前说的默认三种网络模式,请确认你那边也是一样,最主要是没有macvlan网络。如果有请删掉重新配置。删除命令为【docker network rm XXXX】,XXXX是你那边的macvlan网络名字。
接着输入命令【ifconfig】并回车查询当前网卡信息,会看到下面列出了很多网卡列表。
那怎么确定那个是我们需要的信息呢?我们可以看到在列表中“eth0”上有个“inet addr:192.168.50.192”,而这个IP正好就是我们NAS的本地IP地址,所以“eth0”就是我们需要的网卡信息。
通过这个信息,我们可以得出以下结果:
- 接口名称:eth0(网卡接口)
- ipv4网段/网关:192.168.50.XXX(其实就是局域网的网段/网关)
- ipv6网段/网关:240e:XXXX:XXXX:XXXX(这里的ipv6需要用到Global前面的地址才是公网ipv6,下面一个fe80是内网ipv6地址,不需要)
接着输入macvlan网络的创建命令:
docker network create -d macvlan --subnet=192.168.50.0/24 --gateway=192.168.50.1 --ipv6 --subnet=240e:XXXX:XXXX:XXXX::/60 --gateway=240e:XXXX:XXXX:XXXX::1 -o parent=eth0 macnet
下面对以上命令加以说明:
- docker network create -d macvlan #指定创建的网络类型是macvlan
- --subnet=192.168.50.0/24 #macvlan的ipv4网段,这里写你的内网网段即可,最后一位是0(/24默认不要动)
- --gateway=192.168.50.1 #macvlan的ipv4网关,最后一位是1(其实就是路由器的本地IP地址)
- --ipv6 #启用ipv6支持
- --subnet=240e:XXXX:XXXX:XXXX::/60 #macvlan的ipv6前缀::/60(前缀取公网ipv6前4个网段即可,最后的 /60 默认不要动)
- --gateway=240e:XXXX:XXXX:XXXX::1 #macvlan的ipv6网关(其实就是前缀前4个网段::1)
- -o parent=eth0 #桥接网络走的是eth0接口(也就是前面我们ifconfig命令得出的接口名称)
- macnet #macvlan网络的名称(我这里名称就叫做macnet,你那边可以随意更改)
这里顺便说下,如果你不启用ipv6,仅启用ipv4,只需要将--ipv6以及后面的ipv6的信息去掉即可,也就是:
docker network create -d macvlan --subnet=192.168.50.0/24 --gateway=192.168.50.1 -o parent=eth0 macnet
再次输入输入命令【docker network ls】检查以下,我们创建的macvlan虚拟网卡是否成功。
因为我用的是华硕NAS,打开Portainer之后在它的网络列表中也能看到多出了一个我们创建的macvlan网络,名称macnet,且已经同时启用了IPv4&IPv6网络。
Docker容器使用IPv6网络实操
macvlan网络创建成功,我们就可以开始在该网络模式下搭建容器了!
用那个Docker容器来检测今天的教程效果呢?毫无疑问,当然是qBittorrent了!有了IPv6的加持,搭配最新的tracker,下载速度必然是满速“狂飙”。
镜像我使用的是这位国内大佬的“国内优化版”,主要是它对某些“吸血BT”做了屏蔽(大家不要误会,没说是XL哈),并且内置tracker订阅地址,支持自动更新tracker,非常强大!
先来看看大佬给出的配置命令。这个配置命令使用的网络模式是Docker默认的bridge,要想使用今天我们所说的macvlan网络模式,我们就不需要配置它的环境变量(-e)以及端口转发(-p),因为前面说过,macvlan网络其实是虚拟出来的一张独立的物理网卡,而环境变量(-e)以及端口转发(-p)都是在原宿主机(NAS)上的配置,并且两者默认是无法相通的,所以macvlan网络模式就用不上这些了。
所以我们在去除环境变量(-e)以及端口转发(-p)之后,我们qBittorrent在macvlan网络下的搭建命令便为:
docker run -d --name=qbittorrentee --net=macnet --ip=192.168.50.10 -v /volume1/Docker/qbittorrent/config:/config -v /volume2/影视下载:/downloads --privileged=true --restart=always superng6/qbittorrentee:latest
再次解释下以上命令:
- -net=macnet #为qBittorrent容器使用名为macnet的网络模式(也就是我们创建的macvlan网络名称)
- --ip=192.168.50.10 #指定qBittorrent容器IP,前面说过macvlan网络独立于NAS的IP,这里指定一个内网内的其它任意IP即可)
- --privileged=true #赋予qBittorrent容器特权,免得意外退出了
其它就没什么好说了,-v 后面的挂载点根据自己NAS的实际路径自己更改哈!
完成之后我们在Portainer的qBittorrent容器详情页面最下方查看连接的网络,可以看出它已经获取到了IPv4&IPv6的两个IP。
直接登录qBittorrent的WEB页面看看效果吧!请注意,这里的登录IP地址一定要输入我们搭建命令中的指定IP,而不是宿主机(NAS)的IP,后面带上默认的端口8080。用户名和密码不用多说,默认的都是admin/adminadmin。
进入WEB页面之后默认便是中文,首先开启镜像制作者内置的tracker订阅地址吧~
可以看到,瞬间速度拉满的快感还是非常爽的,并且用户列表同时连接了IPv4,IPv6用户,说明我们的macvlan网络搭建是没有问题的~!
打通宿主机(NAS)和macvlan网络容器互访
这个一般是给特定使用场景的小伙伴学习吧,比如说nas-tools~~
前面说过,原宿主机(NAS)和当前macvlan网络下的容器采用的是相互独立的网卡,默认是无法相通(也是为了安全的考量),也就是无法访问的,怎么搞定这个问题呢?根据macvlan网络的特性,既然宿主机(NAS)和当前macvlan网络下的容器不能相同,但是macvlan网络与macvlan网络之间可以互通的,所以只需要用ip link手动再创一个macvlan网卡即可。
具体操作如下:
我们只需要输入以下命令:
ip link add SMZDM link eth0 type macvlan mode bridge ip addr add 192.168.50.50 dev SMZDM ip link set SMZDM up ip route add 192.168.50.10 dev SMZDM
命令的说明如下:
- ip link add SMZDM link eth0 type macvlan mode bridge #创建一个名为SMZDM的macvlan网卡接口(SMZDM可随意更改),eth0是我们前面获取到的宿主机(NAS)的物理接口
- ip addr add 192.168.50.50 dev SMZDM #指定SMZDM接口的IP为192.168.50.50,这个和前面设置的qBittorrent容器须在同一网段
- ip link set SMZDM up #启动SMZDM接口
- ip route add 192.168.50.10 dev SMZDM #让宿主机(NAS)到qBittorrent容器(指定的macvlan网络模式IP)经过SMZDM接口
确认以下我们创建的SMZDM网卡接口是否生效。输入命令【ifconfig】就能看到列表中有SMZDM了。
再输入命令【ip route show】查看路由表信息,可以看出qBittorrent容器(IP192.168.50.10)确实是经过我们创建的SMZDM网卡接口的。
最后直接终端ping一下qBittorrent容器的IP,能ping通就说明是没有问题的!
不过这个方案还有一个很大的弊端,就是在设备重启后会失效,需要重新再配置一遍。具体怎么解决我目前还不知道怎么操作,希望有知道的大佬指导一下~
好了,以上就是今天给大家分享的内容,我是爱分享的Stark-C,如果今天的内容对你有帮助请记得收藏,顺便点点关注,我会经常给大家分享各类有意思的软件和免费干货,咱们下期再见!谢谢大家~
相关推荐
- 开发者必看的八大Material Design开源项目
-
MaterialDesign是介于拟物和扁平之间的一种设计风格,自从它发布以来,便引起了很多开发者的关注,在这里小编介绍在Android开发者当中里最受青睐的八个MaterialDesign开源项...
- 另类插这么可爱,一定是…(另类t恤)
-
IT之家(www.ithome.com):另类插图:这么可爱,一定是…OSXMavericks和Yosemite打破了苹果对Mac操作系统传统的命名方式,使用加州的某些标志性景点来替换猫...
- Android常用ADB命令(安卓adb工具是什么)
-
杀死应用①根据包名获取APP的PIDadbshellps|grep应用包名②执行kill命令...
- 微软Mac版PowerPoint测试Reading Order Pane功能
-
IT之家5月20日消息,微软公司昨日(5月19日)发布博文,邀请Microsoft365Insiders成员,测试macOS新版PowerPoint演示文稿应用,重点引入...
- Visual Studio跨平台开发实战(4):Xamarin Android控制项介绍
-
前言不同于iOS,Xamarin在VisualStudio中针对Android,可以直接设计使用者界面.在本篇教学文章中,笔者会针对Android的专案目录结构以及基本控制项进行介绍,包...
- 用云存储30分钟快速搭建APP,你信吗?
-
背景不管你承认与否,移动互联的时代已经到来,这是一个移动互联的时代,手机已经是当今世界上引领潮流的趋势,大型的全球化企业和中小企业都把APP程序开发纳入到他们的企业发展策略当中。但随着手机APP上传的...
- 谷歌P图神器来了!不用学不用教,输入一句话,分分钟给结果
-
Pine发自凹非寺量子位|公众号QbitAI当你拍照片时,“模特不好好配合”怎么办?...
- iOS文本编辑控件UITextField和UITextVie
-
记录一个菜鸟的IOS学习之旅,如能帮助正在学习的你,亦枫不胜荣幸;如路过的大神如指教几句,亦枫感激涕淋!细心的朋友可能已经注意到了,IOS学习之旅系列教程在本篇公众号的文章中,封面已经换成美女图片了,...
- Android入门图文教程集锦(android 入门教程)
-
Android入门视频教程集锦AndroidStudio错误gradientandroid:endXattributenotfound...
- 如何使用Android自定义复合视图(如何使用android自定义复合视图)
-
在最近的一个客户应用中,我遇到了一个需求,根据选定的值来生成指定数量的编辑框字段,这样用户可以输入人物信息。最初我的想法是把这些逻辑放到Fragment中,只是根据选中值的变化来向线性布局容器中增加编...
- 原生安卓开发app的框架frida常用关键代码定位
-
前言有时候可能会对APP进行字符串加密等操作,这样的话你的变量名等一些都被混淆了,看代码就可能无从下手...
- 教程10 | 三分钟搞定一个智能输入法程序
-
一案例描述1、考核知识点网格布局线性布局样式和主题Toast2、练习目标掌握网格布局的使用掌握Toast的使用掌握线性布局的使用...
- (Android 8.1) 功能与新特性(android的功能)
-
和你一起终身学习,这里是程序员AndroidAndroid8.1(API级别27)为用户和开发人员引入了各种新特性和功能。本文档重点介绍了开发人员的新功能。通过本章阅读,您将获取到以下内容:Andr...
- 怎样设置EditText内部文字被锁定不可删除和修改
-
在做项目的时候,我曾经遇到过这样的要求,就是跟百度贴吧客户端上的一样,在回复帖子的时候,在EditText中显示回复人的名字,而且这个名字不可以修改和删除,说白了就是不可操作,只能在后面输入内容。在E...
- 如何阻止 Android 活动启动时 EditText 获得焦点
-
技术背景在Android开发中,当活动启动时,EditText有时会自动获得焦点并弹出虚拟键盘,这可能不是用户期望的行为。为了提升用户体验,我们需要阻止...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- 开发者必看的八大Material Design开源项目
- 另类插这么可爱,一定是…(另类t恤)
- Android常用ADB命令(安卓adb工具是什么)
- 微软Mac版PowerPoint测试Reading Order Pane功能
- Visual Studio跨平台开发实战(4):Xamarin Android控制项介绍
- 用云存储30分钟快速搭建APP,你信吗?
- 谷歌P图神器来了!不用学不用教,输入一句话,分分钟给结果
- iOS文本编辑控件UITextField和UITextVie
- Android入门图文教程集锦(android 入门教程)
- 如何使用Android自定义复合视图(如何使用android自定义复合视图)
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)