云服务器+wireguard,为家宽附加固定公网ip

之前逛小黄鱼的时候,系统自动推荐了个“给家庭宽带附加固定公网ip”,一个月还要大几百,后面看了下描述,多半是利用各类隧道服务,把公网服务器和内网设备连接到一起,这个类似于内网穿透,但是比内网穿透更加底层。

4ffce04d92a4d6c

常规的内网穿透是需要配置端口信息,例如frp这种,没有原生管理界面,每次改端口都需要手搓配置文件,而且无法穿透(ping)这种协议,而通过隧道的形式就可以避免以上问题(至于什么是隧道,各位自行了解),配置好隧道后直接在路由器端口映射需要的端口就可以了。这里我就用云服务器+wierguard,把云服务器上的ip附加到内网设备上,实现访问云服务器就可以打开内网服务,用起来就和本地宽带有个公网ip没区别,还能把云服务器作为流量出口。

一、特别说明

本教程只是个人兴趣爱好,仅用来实现“内网穿透”功能,至于其他用途,本人一概不知,也不要来问,问也是不知道。

4ffce04d92a4d6c

二、所需设备

1.一个带有公网ip的云服务器作为服务端,一般云服务器都是固定公网ip,当然,如果是非固定公网的服务器也可以,只要是带公网能被访问到就行。这里我就以华为云的云服务器作为例子(为什么是它,因为是我白嫖的,拿来做教程刚刚好),云服务器系统是Debian11,不用12是因为这个服务器它不支持…….

2.一个内网设备作为客户端,支持linux系统就行,这里我用的是,因为有个图形化的界面,不用手搓客户端配置信息,配置端口映射也方便,如果使用爱快等系统都一样,反正能用wierguard就行,或者就干脆发行版的linux系统。

三、服务端&客户端安装

先放行云服务器的安全组,一般云服务器厂商都是带有防火墙,即系统内部防火墙和控制台防火墙,需要先把控制台防火墙放行。先到云服务器控制台,把全部端口都放行,这里放行入站流量,出站流量默认都是放行的不用管。

4ffce04d92a4d6c-1

然后登录服务器的ssh,依次输入以下命令:

4ffce04d92a4d6c-2

这时候就已经安装好(以下简称wg,不想打那么多字)服务端。

然后登录内网设备,这里我用openwrt(immortalwrt)就可以一键安装wg,在软件里面搜索wireguard,把框里面的三个安装上都安装上。

4ffce04d92a4d6c-3

安装完成后一定要重启,一定要重启,不然新建不了接口。重启openwrt后客户端也安装完成。

四、配置服务端&客户端

先进入内网openwrt,新建一个接口,协议选wg。

4ffce04d92a4d6c-4

然后在详细设置哪里,点击生成新的密钥对miyaodui,就会生成客户端的私钥和公钥,监听端口就填写想要的wg端口,ip地址可以填写任意内网地址,注意要和等下服务端的地址地址对应上。注意这里ip地址是指wg内部的ip地址,子网掩码是/24。

4ffce04d92a4d6c-5

然后先不保存,回到云服务器上,输入以下命令新建wg配置文件:

然后通过winscp等等软件打开这个配置文件,做修改,(为什么不在终端里面直接编写,因为不方便)。参照以下配置文件自行修改:

保存上面的配置文件,然后运行以下命令启动wg,并让其开机自动启动:

4ffce04d92a4d6c-6

之后再回到客户端,继续配置客户端。先分配防火墙,这里我图省事,直接用了wan口的防火墙,也可以自己新建一个防火墙。

4ffce04d92a4d6c-7
然后添加一个对端,这里公钥就填最初生成的公钥,就是生成的<>文件;共享密钥就是和服务端那个共享密钥一样;允许的ip我这里也偷懒了,直接0.0.0.0/0,意思是全部ip,建议只允许内网ip以及wg的ip;端点主机就是云服务器的ip,端点端口就是wg的端口,其他的默认就行,然后保存。
4ffce04d92a4d6c-8

此时就完成了服务端和客户端的配置。

五、配置服务端转发&防火墙

配置完wg后还不能直接使用,还需要配置服务端的系统。回到服务端ssh,输入以下命令并编辑文本开启ip转发:

4ffce04d92a4d6c-9

之后查询网卡名称:

例如我这里网卡名称是eth0,这里ip是内网ip很正常,国内云服务器厂商都是这样,网卡绑定的不是公网ip而是内网ip。

4ffce04d92a4d6c-10

然后输入以下命令配置防火墙:

注意系统需要启用iptables,一般系统都是带有此防火墙,如果不知道是否启用,自行百度系统名称+iptables搜索相关文章,需要注意的是,有些系统已经不使用iptables,这个建议换回iptables,无他,其他防火墙我没用过,不知道会发生啥。

iptables重启后规则会自动清除,还需要固定规则,输入以下命令安装iptables-persistent,在弹出的界面会提示是否保存现有规则,选择确定即可:

4ffce04d92a4d6c-11

之后重启云服务器系统,等待客户端重连,或者手动重连下就可以。然后在客户端尝试ping下wg服务端的ip(10.0.0.1),如果可以ping通,说明wg链接现在是正常的。

4ffce04d92a4d6c-12

六、配置端口映射

这个没啥好说的,和常规端口映射一样,就在openwrt-防火墙-端口转发里面添加配置就行,不懂的就看图。

4ffce04d92a4d6c-13

然后访问云服务器公网ip+端口,例如我图上设置了映射884端口,直接访问云服务器公网ip:8848,就可以打开内网服务,就和平常家宽做端口映射一致。如果想要80/443端口也可以自行设置,如果打不开可能是openwrt防火墙配置问题,参考我的配置。

4ffce04d92a4d6c-14

七、其他问题

1.这种隧道受限于云服务器带宽,不过常规内网穿透也一样会,只是这个用起来更简单点,只需要在对应系统/路由上配置端口映射就行。国内云服务器带宽小,用海外的也可以。

2.把域名解析到云服务器公网ip上就可以实现用域名访问,但是注意国内用域名访问80/443端口需要备案。

3.还可以把云服务器作为流量出口,大家都知道这是干啥的不?反正我不知道,啥都不知道。

4.需要注意,这里22和<6666>端口不能做端口映射,因为这两个端口一个是云服务器ssh,一个是wg端口,不会做转发,剩下的端口只要云服务器厂商不限制都可以用。

本文内容来源于公开网络,出于传递信息之目的整理发布。原文版权归原作者所有,若涉及侵权请先提供版权后联系我们删除

(0)
WP之家WP之家
上一篇 2025年3月29日
下一篇 2025年3月29日

相关推荐

  • 敏感肌肤专用护肤品排行榜前十名(十大敏感肌补水的护肤品排行榜)

    敏感肌大概是比大干皮和大油皮更棘手的一种肤质了,无论是油皮、干皮还是混合皮,都有可能有敏感肌的存在。敏感肌的护肤品要小心选择,一不小心就容易出现敏感问题了,敏感肌妹子用错护肤品容易烂脸哦,今天就来分…

    2025年3月29日
  • 这才是手机正确的截屏录屏功能,居然有7种不同的方法,太强大了

    说起手机的截屏功能,很多朋友会最先想到“三指下滑截屏”,这是常用的一种截屏方法。 但是大家知道吗?除了这种截屏方法之外,其实手机的截屏功能还有很多种,平时我们看到喜欢的文章或图片,都可以用截屏的方式保存…

    教程资讯 2025年3月29日
  • 保护自己的php代码相关教程

    保护自己的php代码相关教程。小编现在讲解用域名进行绑定授权代码的。 首先在你网站根目录创建一个quanxianurl.txt 文件,一个域名一行,例如: 代码加到你的原创php文件头部,在加密下就可以了。这样就能方便进行…

    教程资讯 2025年3月29日
  • 《QQ》QQ学生卡领取方式

    《QQ》QQ学生卡领取方式,九月是开学季,QQ近期给大家带来了学生卡的功能玩法,这个功能最大的特色是根据用户使用QQ的昵称来进行数据总结,得到一张专属的学生卡,这张卡片上会显示我们使用QQ的年限以及确定的天数…

    2025年4月5日
  • 50个实用提示词助你玩转DeepSeek

    这份提示词合集专为深度使用DeepSeek设计,覆盖生活、工作、学习各种场景。从处理日常杂事到提升专业技能,每个提示词都给出具体操作指引,帮你快速解决问题。灵活运用这些技巧,不仅能提高办事效率,还能解锁更多…

    教程资讯 2025年3月20日
  • 如何在 WordPress 网站上挂谷歌广告,轻松赚取美元收入!

    ? 将刚才复制的代码段,粘贴到文档里保存。然后回到 Adsense 里点击验证。 ? 我们选择一种方式来验证网站所有权。 7. 等待审核通过后就好啦 小贴士:?如果你的站点流量较少,或者内容不符合 Google 的要求,可能会…

    2025年3月29日
  • 网站不关站备.案且不影响蜘蛛和用户教程分享

    今天我给大家来一期干货,原因是因为看到有一位网友发帖,发了一串代码的方法,那样太麻烦了,我把我私藏已久的方法分享给你们 下面我直接给你们上教程,首先你的网站不管是老站新站必须是https的,这样才能不影响…

    2025年3月29日
  • 哔哩哔哩激活码免费领取教程2024

    哔哩哔哩激活码免费领取教程2024,哔哩哔哩激活码免费领取教程2024,wp之家小编整理了相关的内容,希望大家会喜欢。 哔哩哔哩激活码免费领取2024: cEuKC3o7G7 4E5G5QlBer wlck9dB1Vi slPaGuSvPA ylcvRdFLg4 b站大…

    2025年4月5日