找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
广告投放联系QQ68610888
查看: 8985|回复: 19

我的HomeServer搭建小记:ESXI+OpenWrt+Windows10+Linux

[复制链接]
本帖最后由 片布斯尼 于 2021-12-17 14:40 编辑
一直对于提升家庭网络体验有种执念,本次折腾就是来填坑的。最终通过本篇文章记录的折腾之后,我家的网络拓扑图如下:


通过本次折腾,我实现了以下需求:

  • 宽带拨号,公网IP
  • DDNS,在外网访问路由器后台;
  • Windows10为跳板机,可通过RDP访问
  • CentOS运行一个Telegram机器人
  • CentOS搭建一个内网相册分享网站
  • CentOS搭建GitLab私有代码服务器


一、硬件选择

考虑过多种方案,包括Intel NUC产品线、DIY组装HTPC小主机、成品多网口小主机。最终我选择了成品多网口小主机,主要是基于以下:

  • NUC只有单网口,无法做主路由;
  • DIY太麻烦费时,且目前市售没有好看的CASE机箱;
  • 工控多网口小主机,无风扇设计,外壳硬朗,体积尚可接受


最终配置为:



  • CPU:i7-1165G7, 卖家提供赛扬6305、酷睿i5-1135G7、酷睿i7-1165G7可供选择,我选择一步到位!
  • 内存:笔记本DDR4 3200GHz 16GB x 2,最大支持64GB内存
  • 硬盘:mSATA 512GB + 2T SSD
  • 网卡:Intel i210 x 6
  • 其他接口:HDMI 2.0 x 1、USB 3.1Gen2 x 4、COM(RJ45) x 1
  • 电源:DC 12V 5A, 5.5 x 2.5 插头


伪开箱:







硬件就简单介绍到这里。



二、软件安装
由于要在这台小主机上借助底层虚拟机安装多个系统,分别运行不同的服务。因个人喜好,我选择 VMware,也就是大家常说的ESXI虚拟机,各位小伙伴也可以选择 Proxmox VE(简称PVE)。

2.1 安装底层虚拟机



关于如何安装虚拟机,网上有非常多的轮子,我这里简单带过。在一切开始之前,需要准备好一个空优盘。

  • 下载虚拟机镜像,可以前往丁辉博客下载;
  • 把固件烧录进优盘,这几个软件均可以把虚拟机系统固件烧录进优盘;RufusBalenaEtcher
  • 烧录完成,即可进行系统安装;



注意事项:

  • ESXI刚启动安装的时候,按住Shift+O(是字母o不是零),键入以下代码:
    1. cdromBoot runweasel autoPartitionOSDataSize=8192
    复制代码

    OSDataSize=8192改成4096也行,这段代码的目的是解除ESXI 7.0自动划分120G虚拟闪存的问题,解决120G硬盘不能安装ESXI7.0的问题。
  • 安装过程中,ESXI安装是可视化的安装过程,是需要接键盘鼠标的。
  • 安装完毕之后,按F2进入设置界面,在这个设置界面,需要定义好虚拟机后台的IPv4地址、子网掩码、DNS地址等。这些地址需要提前规划好:


    • IPv4 Address:10.0.0.251也就是ESXI登录的后台地址
    • Subnet Mask: 子网掩码,为255.255.255.0
    • Default Gateway:10.0.0.1
  • 如果要解除ESXI的登录密码,在安装完毕系统后,F2进入设置后台,选择Reset system configuration进行密码重置,重置过后,密码为空值。


2.2 安装路由系统OPENWRT

路由器系统非常多,有OpenWrt、PfSense、OPNsense、iKuai、Panabit、RouterOS等,由于国内用户的实际需求导致,我和国内众多用户一样,对OpenWrt了解稍微更深,使用也更多一些,那么这里我就把OpenWrt作为我的主路由系统。

固件选择:OpenWrt固件系统选择:选择非常多,推荐这些大佬打包的固件包:eSir  HomeLede.  Sirpdboy

格式转换:转换img格式格式为适配虚拟机的vmdk格式,格式化软件下载和教程

安装步骤:
  • 登录ESXI,新建虚拟机,名称可任意填写,客户机操作系统选择Linux,客户机操作系统版本选择其他4.x或更高版本的Linux(64位)
  • 将系统默认生成的硬盘删除,CD/DVD也用不到可以删除,并设置好网卡。
  • 内存一定要勾选预留所有客户机内存(锁定)
  • 选择添加硬盘>>>现有硬盘,选择本地的前面转好格式的vmdk文件上传,先上传kb级小文件,后上传大文件;
  • 保存并开启OpenWrt虚拟机;
  • 修改OpenWrt后台登录地址到前面规划好的后台地址,使用vim命令,在OP的终端命令行中输入:

    1. vim /etc/config/network
    复制代码


    按下字母i开启insert模式,修改option ipaddr '10.0.0.1',然后按下ESC键,键入:wq·保存并退出,最后输入 reboot实现命令行重启软路由OpenWrt系统。



2.3 安装WINDOWS

和创建OpenWrt虚拟机类似,不过又一些细节不一样。提前准备好Windows固件:下载ISO固件

  • 新建虚拟机,选择对应的Windows系统版本;
  • 内存需要勾选预留所有客户机内存(锁定);硬盘下拉,控制器位置设置为SATA控制器;
  • 在CD/DVD驱动器1,选择下拉的数据存储ISO文件,上传并选择我们的Windows ISO固件;
  • 一直下一步直到完成,在回到虚拟机>>>操作>>>编辑设置,在虚拟机选项中,把引导选项下面的固件,修改默认的EFI为BIOS引导;
  • 启动Windows10虚拟机,和物理装机一样,操作Windows系统安装,直至安装完毕!


2.4 安装LINUX系统

Linux系统分支有非常多中,可以根据各自的喜好进行下载:Ubuntu. CentOS. Debian 。这里,我用CentOS。

安装CentOS虚拟机步骤和物理机下安装CentOS一摸一样,这里过程就不再赘述!实在不会的,可以参考这个咖喱味视频教程 点击前往



三、虚拟机分工
如文章开篇所述,我家的网络拓扑图为如下。



3.1 网络拨号——OPENWRT

前提:我家使用电信宽带,且已经找电信客服申请到了公网IP(话题延升:公网IP 不等于 固定IP)。所以我使用OpenWrt进行宽带PPPoE拨号上网。



⚠️额外说明:

  • ESXI下的OpenWrt系统内的eth网口顺序和物理机上的LAN1-6是错乱的,这个目前似乎是这些工控机在BIOS设计中并没有和ESXI匹配上,不过问题不大,拿根网线实际插上测试下就能分辨出物理机上需要设置为WAN口的LAN6对应的是OpenWrt系统内的eth3,在网络>>>端口>>>WAN,点击修改进行选择绑定即可。
  • OpenWrt内的网络数量,跟我们创建虚拟机时,创建的PCI设备数量相关,通常你可以全部网络分配给OpenWrt,也可以只分配两个。
  • 各位可以选择另外一种方案:ESXI+iKuai+OpenWrt双软路由的方案,iKuai负责拨号,OpenWrt负责科学魔法上网



3.2 RDP跳板机——WINDOWS10 LTSC

使用场景:离家状态下,我可以直接通过微软的远程桌面,直接连接到家庭内网的Windows机器上,进入完全内网的环境中。
访问方式:在OpenWrt下设置好DDNS(可参考),并把Windows10 虚拟机端口转发出来,即可实现使用域名+端口号的方式实现远程桌面连接。



这里我设置了以下端口转发
  • 路由器后台;
  • Windows内网跳板机;
  • 群晖,当然群晖我基本使用自带的QuickConnect;
  • 部署在群晖上的Bitwarden服务



3.3 内网服务器——LINUX虚拟机

安装宝塔面板:
由于我是安装的CentOS服务器,所以使用这段代码进行安装
  1. yum install -y wget && wget -O install.sh [url]http://download.bt.cn/install/install_6.0.sh[/url] && sh install.sh
复制代码



宝塔绕过(出除)登录:
使用下面代码:
  1. sed -i "s|if (bind_user == 'True') {|if (bind_user == 'REMOVED') {|g" /www/server/panel/BTPanel/static/js/index.js
  2. rm -rf /www/server/panel/data/bind.pl
复制代码


关于如何借助宝塔面板搭建博客,这里就不在赘述。



评论区疑问解答:


1、远程访问内网,设置一台Windows跳板机的需求出发点:

——ESXI Server上的CentOS其实运行着一个京东产品比价机器人,可实现给身边的亲朋好友使用。能实现简单的天气预报查询、小爱人工智障、京东产品查券比价、京东撸羊毛,跳板机方便随时ssh进入到CentOS 后台,当然我用DDNS+端口方式也是可以进去的,双保险。


2、散热解决方案:

就原装被动散热,确实存在比较大的问题,机器外壳烫手,目前一起折腾的小伙伴,搞了很多套散热方案出来:

1、亚克力外壳+主动散热风扇
魔改后,抛弃了原装铝壳,体积进一步缩小到12.5 x 12.5 x 3.5 cm尺寸,塞弱电箱不是问题。如下图:


2、原铝质外壳+猫扇+强力双面胶

实测只加猫扇的烤鸡温度

3、原铝质外壳+散热片加强铜箔加强+更换7921硅脂




方案3实测烤鸡温度




3、关于all in one方案的数据安全性问题:

如果你家里有群晖系统,那问题基本不存在,我上个图,大家就明白了。


4、京东查券比价机器人简单介绍(运行在ESXI Server上的CentOS 8

功能1:发送京东产品链接,机器人返回比价结果信息和下单链接(带CPS返利),如果有优惠券,下单链接会是领券链接;
功能2: 带自动完成任务功能,各位利益相关(包括京东)不用找我麻烦,我使用的是Github上开源程序,代码也不是我写的,用途也仅限我自用!
功能3:带 管理员管理功能,可以简单发送一些指定命令给机器人,让自己人完成升级/查询目的;


机器人不会公开,也不会邀请各位使用,自用自用自用!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
有钱淫,玩homeserver都是11代处理器
回复

使用道具 举报

这个机器的op能不能放在主路由下,做旁路由使用
回复

使用道具 举报

折腾
回复

使用道具 举报

来自手机 | 显示全部楼层
大佬我的配置跟你一模一样。但卡在openwrt网络接口上,没有物理选项,想问大佬装的是什么ESXI版本!我装的esxi7.02b。按住Shift+O  cdromBoot runweasel 我是反的/runweasel cdromBoot也不知道什么情况
回复

使用道具 举报

能不能教一下bitwarden如何开启https,能不能出个教程
回复

使用道具 举报

感谢分享!
回复

使用道具 举报

原来进入内网还需要设置一台跳板机。思考了。
回复

使用道具 举报

可以免除跳板机,通过op架设v屁恩服务器,拨号进入内网。
回复

使用道具 举报

小大小二的爸爸 发表于 2022-2-25 17:01
大佬我的配置跟你一模一样。但卡在openwrt网络接口上,没有物理选项,想问大佬装的是什么ESXI版本!我装的es ...

好像反的命令一样的
回复

使用道具 举报

CHINA_CAN 发表于 2022-3-13 16:15
可以免除跳板机,通过op架设v屁恩服务器,拨号进入内网。

我现在就是用路由的v屁恩服务器进家里的内网.
回复

使用道具 举报

感谢分享
回复

使用道具 举报

我也有一台,还在闲置中。有空得搞下了
回复

使用道具 举报

感谢分享!
回复

使用道具 举报


感谢分享
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

欢迎大家光临恩山无线论坛上一条 /1 下一条

有疑问请添加管理员QQ86788181|手机版|小黑屋|Archiver|恩山无线论坛(常州市恩山计算机开发有限公司版权所有) ( 苏ICP备05084872号 )

GMT+8, 2024-5-18 12:49

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

| 江苏省互联网有害信息举报中心 举报信箱:js12377 | @jischina.com.cn 举报电话:025-88802724 本站不良内容举报信箱:68610888@qq.com 举报电话:0519-86695797

快速回复 返回顶部 返回列表