2020年原本难得清闲的春节,由于疫情的原因只能在家里看视频打发时间。打开某奇艺,全是某某公寓的推荐真的是受不了。一群人在那里叽叽喳喳,超前点播更是吃像难看,实在是没意思,所以决定搞一个独臂路由器玩一玩。

啥是独臂路由器

单臂路由(router-on-a-stick)是指在路由器的一个接口上通过配置子接口(或“逻辑接口”,并不存在真正物理接口)的方式,实现原来相互隔离的不同VLAN(虚拟局域网)之间的互联互通。

有啥用

其实上面的定义就说明了这完意有啥用。

我电脑上有几个虚拟机,桥接形式设置了固定IP(因为有时候可能要在别的电脑上访问这几个虚机),自己在家里玩的时候还好。但是只要一换环境,比如我把我的电脑拿去给别人演示,而新环境的网段并不一定和家里的一样。所以我想让所有虚机或容器处于固定IP状态。

实现方式 Hyper-V + LEDE固件

这里说一下,之前在油管上看了一个视频内容大概是用旧电脑做独臂路由器,当然他这样做的目的是因为他想让这台电脑代理家里的所有设备访问大千世界,和我的目的不太一样。

用旧电脑和工控机可以实现的东西,用虚机应该也可以实现,查了查果然可以。

Hyper-V 的选择原因

Hyper-V了解的不多,只知道的是Windows自带的虚拟机,其增强会话功能只支持Windows。我选择它的主要原因就是他在内存方面使用很无感,不像VMware那样每次关机都要等很长时间用来让它释放内存。

实现原理

路由器

先说一下路由器的实现方式,后面的网线插口有两种,一种WAN口一般只有一个,一种是LAN口有若干个。WAN口处用来连接猫或者交换机,LAN口用来连接电脑或服务器。

WIFI就不说了,和这里没关系。。。。

LEDE

Linux嵌入式开发环境项目(Linux Embedded Development Environment,LEDE),是路由器固件项目OpenWRT的一个复刻分支项目,并继承原来OpenWRT的开发目标。2018年1月 LEDE 和 OpenWRT 正式宣布合并,合并后的项目使用 OpenWrt的名字。

上面是百度百科对LEDE的说明,用人话说就是用这个完意可以自己重新刷路由器的固件(直接把固件刷进路由器中,我还没有试过,感觉应该有些受限条件,比如,路由器支不支持等等)。当然这个完意其实就是一个Linux系统,可以重装系统到电脑里,也可以放在虚拟机里。


所以实现方式就是,在自己的电脑里装一个LEDE虚拟机并分配一块网卡给它单独使用来充当软路由。然后通过Hyper-V虚拟交换机的配置来实现WAN口连接外部网络环境,LAN口开放给本地电脑和所有虚拟机。

这样配置好后,这台电脑的上网方式就不在是直接连接外部网络,而是外部网络接入LEDE虚拟机,然后本地电脑和其它虚拟机都通过LEDE虚拟机访问外部网络。

LEDE虚拟机安装

  1. WIN10启用Hyper-V功能(应该只Windows10专业版企业版才会有),确认WIN10版本后,在启用或关闭Windows功能中勾选Hyper-V就好了,应该会重启。

  2. 在koolshare论坛下载镜像

    以下是镜像列表

    文件 大小 更新时间
    信步等特殊机型专用 - 2019-10-05 14:43:59
    虚拟机转盘或PE下写盘专用 - 2019-09-30 14:56:59
    .img或.gz可以直接在LEDE系统Web升级,如需要转盘或PE写盘请下载转盘文件夹下的镜像 0.00B 2019-09-30 13:19:40
    openwrt-koolshare-mod-v2.31-r10822-50aa0525d1-x86-64-combined-squashfs.img.gz 40.18MB 2019-09-30 13:19:41
    openwrt-koolshare-mod-v2.31-r10822-50aa0525d1-x86-64-uefi-gpt-squashfs.img.gz 41.13MB 2019-09-30 13:19:41
    openwrt-koolshare-mod-v2.33-r12074-007caa48d1-x86-64-combined-squashfs.img.gz 56.94MB 2019-09-30 13:19:42
    openwrt-koolshare-mod-v2.33-r12074-007caa48d1-x86-64-uefi-gpt-squashfs.img.gz 57.43MB 2019-09-30 13:19:43
    uefi.md 147.00B 2019-09-30 13:19:43
    version.md 147.00B 2019-09-30 13:19:43

    镜像文件有很多个,区别看文件名就好了。我选择的是虚拟机转盘或PE下写盘专用下的x86-64-uefi-gpt-squashfs.vmdk版本。

    下载链接:LEDE_X64

  3. 上面之所以选择下虚拟机或PE下写盘专用的文件,是因为我担心镜像里有针对虚拟机的支持。但是这个镜像的扩展名是.vmdk的,这个完意是VMware虚拟硬盘的扩展名。如果用VMware自然没有这个问题了。所以这个时候需要下载一个软件StarWind V2V Converter,这个工具的作用就是将VMware的虚拟硬盘转换为Hyper-V的虚拟硬盘。

    下载链接:StarWind V2V Converter

    转换步骤

    • Local file
    • 选择从koolshare下载的文件
    • Local file
    • VHD/VHDX
    • 这一步比较关键VHDX growable imageVHDX pre-allocated image这两个选项都是可以的,区别在于虚拟硬盘的空间是否可以增长。但是另外两个选项就不可以选了,我在安装过程中发现似乎只可以使用VHDX的虚拟硬盘。
  4. 新建虚拟机

    这一步比较简单,正常新建并使用已有虚拟硬盘的创建方式就可以了。

    注意

    • 如果下载的是uefi版镜像或虚拟硬盘,自然选择第二代启动方式。
    • 第二代启动方式情况下,先不急于启动虚拟机,在虚拟机设置 > 安全 > 启用安全启动的选项勾掉。
  5. 启动虚拟机,加载完之后在页面上回车一下,如果出现OPENWRT的Logo说明安装成功了。

配置虚拟交换机

  • 内部

新建一个内部交换机,作为LEDE虚拟机的LAN口,然后所有虚拟机和本地电脑都连接这块虚拟网卡。

  • 外部

新建一个外部交换机,在下拉选中选择一块网卡,这块网卡就是电脑连接外部网络的实际网卡,勾掉允许管理操作系统共享此网络适配器,意为只有连接这个虚拟网卡的虚拟机才会有使用这块实际网卡的权限,并作为LEDE虚拟机的WAN口连接外部网络。

  • 虚拟网卡连接步骤

    • LEDE虚拟机依次添加上面新建的内部网卡和外部网卡(好像只有这个顺序有用)。

    • 添加好后在虚拟机上的硬件名称叫网络适配器,在这两个适配器的高级功能里勾选上启用MAC地址欺骗

    • 重启LEDE虚拟机,然后在本地电脑的网络适配器中找到上面新建的内部网络手动分配IP地址。我分配的信息如下:

      IP地址 192.168.1.10
      子网掩码 255.255.255.0
      默认网关 192.168.1.1
      首选DNS服务器 192.168.1.1
    • 如果不出问题的话,现在WIN10的网络和Internet状态中应该可以看到连接了上面创建的内部网卡。

  • 配置软路由

通过访问192.168.1.1可以访问软路由,密码为koolshare,进入之后将WAN口的桥接选项勾掉。


到这里所有配置就都完成了。所有虚拟机都可以配置内部网卡然后经由LEDE虚拟机访问外网,这样所有虚拟机同属于同一网段,不再因外部环境变化而受到影响。

Hyper-V 搭建独臂路由器(单网卡也可以)的更多相关文章

  1. windows2003 单网卡 搭建vpn ,windows 2008 R2 类似吧。网上转的,自己加了点经验总结

    先说说可能的坑,也就是我自己搭建的时候碰到的问题. 其实搭建起来很简单,我不知道我总结的对还是不对,但是按下面这样操作做绝对能搭好!因为我就是按这样搭起来的,但是我发现,好像pptp已经被墙了,我也不 ...

  2. Windows Server 2003/2008 单网卡搭建VPN

    Windows Server 2003/2008 单网卡搭建VPN 1.打开[控制面板] --> [管理工具] --> [路由和远程访问] 2.鼠标右击你要管理的电脑 在弹出式菜单中选中[ ...

  3. Windows Server 2003单网卡搭建VPN

    Windows Server 2003单网卡搭建VPN   1.打开[控制面板] --> [管理工具] --> [路由和远程访问] 2.鼠标右击你要管理的电脑 在弹出式菜单中选中[配置并启 ...

  4. 烂泥:nagios监控单网卡双IP

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 公司的业务有几台服务器存放在IDC机房中,说是双线路.但是我看到网卡的配置是单网卡双IP的形式.如下: 而公司这边的线路是联通的IP,如下: nagio ...

  5. Hyper V NAT 网络设置 固定IP / DHCP

    Hyper V 默认的Default Switch同时支持了NAT网络以及DHCP,虚拟机能够访问外网. 但使用过程中发现这个IP网段经常变化,而且Hyper V没有提供管理其NAT网络与DHCP的图 ...

  6. 使用Squid做代理服务器,Squid单网卡透明代理配置详解(转)

    使用Squid做代理服务器 说到代理服务器,我们最先想到的可能是一些专门的代理服务器网站,某些情况下,通过它们能加快访问互联网的速度.其实,在需要访问外部的局域网中,我们自己就能设置代理,把访问次数较 ...

  7. windows server 2008 r2 企业版 hyper v做虚拟化的相关问题处理

    windows server 2008 r2 企业版 hyper v做虚拟化的相关问题处理 今天在dell r710 上用windows server 2008 r2企业版hyper v 做虚拟化,添 ...

  8. 设置Hyper V

    1.打开服务器管理器 2.添加角色和功能 3.安装类型 -> 基于角色或基于功能的安装 4.服务器选择 -> 下一步 5.服务器角色 勾选"Hyper V"

  9. LINUX单网卡绑定多个IP

    在linux下,我们有时候需要给单网卡设置不同的IP地址,这样就涉及到单网卡绑定多个IP地址的情况.使用本方法可以方便的为单网卡绑定多个IP地址.笔者使用的环境是centos5.6,应该在fedora ...

随机推荐

  1. ios设备iframe无法滚动

    在使用IFRAME,你需要使用一个元素(如DIV)来包装他们 <div class="scroll-wrapper"> <iframe src="&qu ...

  2. .net webapi 文件夹上传

    如果我是DJ,是DJ,是DJ,是DJ,是DJ,是DJ,是DJ,是DJ,是DJ,是DJ,,, 前言 文件夹上传目前仅支持chrome内核的浏览器. 后期整理到git(2019-5-23说:不整理了,我要 ...

  3. 一键自动生成 java junit 测试代码神器 gen-test-plugin 入门介绍

    gen-test-plugin 我们日常编写代码的过程中,经常需要为代码编写测试案例. 随着对代码质量的要求越来越高,很多公司开始通过代码的测试覆盖率作为 QA 的一个评定指标. 本框架可以一键生成所 ...

  4. python常见关键字的使用

    常见关键字 在循环中常见的关键字使用方法 continue:结束本次循环,继续执行下一次循环 break:跳出一个循环或者结束一个循环 例 使用用户名密码登录(有三次机会)count=0while c ...

  5. 亲测可用的优雅的在已经安装了python的Ubuntu上安装python3.5

    我的Ubuntu上已经安装了python2.7和3.4. 用以下方法可以方便的顺利的安装python3.5,使用的时候也不会发生冲突. 一条一条输入以下语句 wget https://www.pyth ...

  6. Android CTS中neverallow规则生成过程

    CTS里面SELinux相关测试中neverallow测试项占绝大多数,Android系统开发者都应该知道,在修改sepolicy时,需要确保不能违反这些neverallow规则,不然会过不了CTS. ...

  7. javaweb-实现不同用户登录后跳转到不同界面

    今天下午,实现了公文流转系统的一小部分——登录界面验证不同用户跳转到不同界面 Dao package com.office.Dao; import java.sql.Connection; impor ...

  8. 怎么彻底删除用友通T3财务软件?

    [问题现象]怎么彻底删除用友通T3财务软件? [原因分析]通过"添加或删除程序"无法正常卸载用友通T3,也尝试了360安全卫士强力卸载,都无法完全卸载,有没有办法可以彻底删除用友通 ...

  9. $bzoj2067\ szn$ 二分+贪心

    正解:二分+贪心 解题报告: 传送门$QwQ$ 题目大意就说有一棵树,然后要用若干条线覆盖所有边且不能重叠.问最少要用几条线,在用线最少的前提下最长的线最短是多长. 昂首先最少用多少条线这个还是蛮$e ...

  10. $ CometOJ-Contest\#11\ D$ $Kruscal$重构树

    正解:$Kruscal$重构树 解题报告: 传送门$QwQ$ 发现一个图上搞就很麻烦,考虑变为生成树达到原有效果. 因为在询问的时候是要求走到的点编号尽量小,发现这个时候点的编号就成为限制了,于是不难 ...