硬件信息:N5095+8G2666MHz+512GM.2
系统信息: Ubuntu 22.04.1 LTS
以下内容默认Ubuntu已经安装最新版Docker,如未安装需先安装Docker
部署通过纯命令行进行,无需图形界面
一、环境配置
1. 安装Docker
使用官方安装脚本,并使用阿里云镜像加速,防止无法访问Docker原网站导致访问超时:
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
或
curl -sSL https://get.daocloud.io/docker | sh
2. 配置网络
使用MobaXterm终端连接Ubuntu,使用
ifconfig
命令查看当前正在使用的网卡。找到正在启动的网卡名称后,开启网卡的混杂模式
# 现在使用的网卡名称为enp3s0,根据实际情况进行替换iplinkset enp3s0 promisc on
随后配置MACVLAN,其中注意:
192.168.0.0
和
192.168.0.1
根据实际情况进行替换
例如:当使用上述
ifconfig
命令发现设备的IP地址为
192.168.1.112
,则需要将
192.168.0.0
和
192.168.0.1
替换为
192.168.1.0
和
192.168.1.1
。
docker network create -d macvlan --subnet=192.168.0.0/24 --gateway=192.168.0.1 -oparent=enp3s0 macnet
创建好网络后,可以使用以下命令查看设置好的网络,其中第三个NAME为macnet即为我们刚才创建网络:
docker network ls
NETWORK ID NAME DRIVER SCOPE
ef157b2f1695 bridge bridge local
9e6448a30c4d hosthostlocal
a4fcd62a3fcb macnet macvlan local
7482e50ca32b none null local
宿主机的网络配置完成后,现在对OpenWRT的网络进行配置:
# 创建配置文件存放的目录mkdir-p /home/docker/openwrt
# 创建网络配置文件并编辑vim /home/docker/openwrt/network
network 配置文件如下:
config interface 'loopback'
option ifname 'lo'
option proto 'static'
option ipaddr '127.0.0.1'
option netmask '255.0.0.0'
config globals 'globals'
option packet_steering '1'
config interface 'lan'
option type 'bridge'
option ifname 'eth0'
option proto 'static'
option netmask '255.255.255.0'
option ip6assign '60'
option ipaddr '192.168.0.3'
option gateway '192.168.0.1'
option dns '192.168.0.1'
config interface 'vpn0'
option ifname 'tun0'
option proto 'none'
其中
option ipaddr '192.168.0.3'
需要将IP地址设置为你想要给OpenWRT分配的网络地址;
option gateway '192.168.0.1'
和
option gateway '192.168.0.1'
需要设置为路由器的地址
二、Docker配置
使用docker命令拉取镜像并运行
docker run --restart always --name openwrt -d--network macnet --privileged--ip192.168.0.3 -v /home/docker/openwrt/network:/etc/config/network registry.cn-shanghai.aliyuncs.com/suling/openwrt:x86_64 /sbin/init
命令中的
192.168.0.3
需要替换为刚刚
option ipaddr '192.168.0.3'中设置的IP地址
如果运行命令后提示
WARNING: IPv4 forwarding is disabled. Networking will not work
则需要进行如下配置:
vim /etc/sysctl.conf
#添加 net.ipv4.ip_forward = 1sysctl-p /etc/sysctl.conf
再次执行上面命令即可
三、OpenWRT配置
可以使用
docker ps
命令看到容器正常运行后,登录刚刚配置的
ipaddr
的IP地址,进行OpenWRT的后台页面
用户名:
root
密码:
password
进入后台页面可以根据需要配置Clash、SmartDNS等服务实现科学上网或广告屏蔽等功能
四、OpenWRT高级服务使用
To Be Continued…
参考文档:
1.Ubuntu Docker 安装
2.在Docker 中运行 OpenWrt 旁路网关
3.Docker 安装 openwrt 软路由
版权归原作者 Indigo_5Alpha 所有, 如有侵权,请联系我们删除。