PVE + OpenWRT 实现旁路由

2024-02-17 09:04
文章标签 实现 openwrt 旁路 pve

本文主要是介绍PVE + OpenWRT 实现旁路由,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

最近想玩下软路由,了解了下各种软路由系统之后选择了openwrt,这个是基于linux的,而且可以安装docker之类的各种有用的插件,但是我手头暂时没有机器可以做软路由,先使用PVE虚拟一台研究,由于openwrt占用的资源很少 1G内存就够了,这篇文章的前提是pve已经安装好了

1.安装openwrt

openwrt的镜像是img格式的,但是pve并不支持img,我们需要将img转成qcow的格式

我使用了img2kvm脚本来进行转换

./img2kvm /dev/pve/openwrt.img 100 /var/lib/vz/template/iso/vm-100-disk-1

命令解释:openwrt.img后面的100 对应的是虚拟机编号id 最后的vm-100-disk-1 中的100也是一样的,disk-1的1代表这个虚拟机第一个盘

  1. 这里说明一下 /dev/pve这是上传镜像之后会在这里目录里面 (对应pve默认的local存储池)
  2. /var/lib/vz/template/iso 这个路径是pve虚拟机的磁盘默认存储目录 (对应pve默认的local-lvm存储池)
  3. /var/lib/vz/template/iso 里面创建的符合pve磁盘命名规范的可以识别到

登录pve,创建一个openwrt虚拟机,先不使用任何介质引导

创建完成之后点虚拟机,点 Hardware 也就是硬件,看到有个为分配的磁盘

点击添加 Add 直接确定,然后去其他Option 其他中选择 Boot Order 启动引导项中

将 local-lvm:vm-101-disk-1,iothread=1,size=520M 这个盘移动到第一位,并且勾选启用

开启虚拟机即可

我们在创建openwrt的时候给了10G的磁盘,但是我们使用了openwrt的镜像进行引导,实际上openwrt并没有安装在10G的盘,我们可以直接克隆下

root@OpenWrt:~# fdisk -l
Disk /dev/loop0: 104.44 MiB, 109510656 bytes, 213888 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytesDisk /dev/sdb: 520 MiB, 545259520 bytes, 1064960 sectors
Disk model: QEMU HARDDISK   
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x968806c2Device     Boot Start     End Sectors  Size Id Type
/dev/sdb1  *      512   33279   32768   16M 83 Linux
/dev/sdb2       33792 1057791 1024000  500M 83 LinuxDisk /dev/sda: 10 GiB, 10737418240 bytes, 20971520 sectors
Disk model: QEMU HARDDISK   
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes

可以看到 /dev/sda 是我们最开始给的10G盘

/deb/sdb就是我们引导的盘

使用dd命令克隆 sdb到sda

dd if=/dev/sdb of=/dev/sda
在pve中虚拟机引导项中取消最开始的引导,将10g的盘放到第一项

即可通过10g的盘引导进入openwrt系统

2.配置OpenWRT 

编辑网络配置 vim /etc/config/network 

config interface 'loopback'option ifname 'lo'option proto 'static'option ipaddr '127.0.0.1'option netmask '255.0.0.0'config interface 'lan'option ifname 'eth0'option proto 'static'option netmask '255.255.255.0'option delegate '0'option gateway '192.168.3.1'option dns '192.168.3.1'option ipaddr '192.168.3.100'config interface 'wan'option ifname 'eth1'option proto 'dhcp'option metric '64'option delegate '0'config interface 'wan6'option proto 'dhcpv6'option ifname 'eth1'option delegate '0'option reqaddress 'none'option reqprefix 'no'config interface 'vpn0'option ifname 'tun0'option proto 'none'config interface 'ipsec_server'option ifname 'ipsec0'option device 'ipsec0'option proto 'static'option ipaddr '192.168.100.1'option netmask '255.255.255.0'config interface 'docker'option ifname 'docker0'option proto 'none'option auto '0'config deviceoption type 'bridge'option name 'docker0'config interface 'lan2'option proto 'static'option ifname 'br-lan.22'

我这里把lan 口网卡 配置ip为192.168.3.100 这个是openwrt的ip地址了

这个需要按照家庭中网络的网段来配置,也就是你openwrt接入到了那个网段下

浏览器输入 192.168.3.100 即可进入openwrt管理界面

账号默认为:root

密码默认为: password

进入之后点击左侧网络,接口

修改lan接口 也是eth0  

网关指向主路由的网关 192.168.3.1 

使用自定义的 DNS 服务器 192.168.3.1

我这边主路由的是192.168.3.1 这里根据自己的环境来配置

DHCP 忽略此接口,因为主路由就有dhcp了如果在加一个dhcp的话很容易出问题

高级设置基本不变,用ipv6就勾选使用内置的 IPv6 管理

物理设置去掉桥接接口 ,接口选 以太网适配器: "eth0" (lan)

防火墙设置不变

然后点网络,防火墙 将lan口

IP 动态伪装MSS 钳制

全部勾选

将设备的网关指向软路由即可使用软路由上网

这篇关于PVE + OpenWRT 实现旁路由的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/717302

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja