当前位置: 首页 > news >正文

手动部署内网穿透

内网穿透的部署

  • 一. 什么是内网穿透
  • 二. 部署内网穿透的步骤
    • 1.下载frp [https://github.com/fatedier/frp/releases/tag/v0.58.1](https://github.com/fatedier/frp/releases/tag/v0.58.1)
    • 2.下载Watt Toolkit [https://steampp.net/](https://steampp.net/)
  • 三.测试
    • 1. ssh的远程登陆
      • (1)所需设备
      • (2)将下好的压缩包包直接导入虚拟机与云服务器
      • (3) tar -xzf 解压压缩包
      • (4) 改变服务端 提供 listen端口
      • (5)启动服务端可执行程序
      • (6)修改被远程登陆客户端配置文件
      • (7) 启动被远程登陆客户端可执行程序
      • (8)此时再用xshell启用一个客户端 只不过端口改为8081号端口
    • 2. nginx远程访问
      • 1. 安装一个nginx代理服务器
      • 2. 启动后查看nginx所使用到的端口号
  • 四.将客户端与服务端放置后台运行

一. 什么是内网穿透

内网穿透是一种技术,它能让处于内网(比如家庭网络或企业内部网络)中的设备,在不直接暴露于公网的情况下,通过一些特殊的设置和工具,让外部网络中的设备也能访问到内网中的设备或服务。

打个比方,你家就像一个内网,家里的电脑、手机等设备组成了这个内网中的 “小世界”。通常情况下,这些设备通过家里的路由器连接到互联网,但它们在互联网上是隐藏的,外部的人无法直接访问你家设备上的东西。

现在,假设你在家里搭建了一个私人的照片分享网站,只希望让一些特定的朋友能访问到这个网站,查看你分享的照片。但因为你家的设备在内网,朋友们从外面的互联网无法直接访问到。这时候,你就可以使用内网穿透技术。通过在内网穿透平台上进行一些设置,你可以获得一个公网的地址(就好像给你家的照片分享网站在互联网上开了一个 “窗口”),然后把这个地址告诉朋友们,他们就能通过这个地址访问到你家里的照片分享网站了,就像这个网站直接放在互联网上一样,这就是内网穿透的作用。

二. 部署内网穿透的步骤

1.下载frp https://github.com/fatedier/frp/releases/tag/v0.58.1

在这里插入图片描述

2.下载Watt Toolkit https://steampp.net/

避免访问github时过慢,可以下载这个软件用来加速。
在这里插入图片描述

三.测试

1. ssh的远程登陆

(1)所需设备

需要一台虚拟机作为被远程登陆的客户端,准备一台有公有ip的云服务用来做为服务端。

(2)将下好的压缩包包直接导入虚拟机与云服务器

在这里插入图片描述
在这里插入图片描述

(3) tar -xzf 解压压缩包

用tar -xzf + 压缩包名字 解压.tar.gz文件,获取蓝色的文件,内部自带服务端frps(服务端)与frpc(客户端)的可执行程序。

(4) 改变服务端 提供 listen端口

  1. vim frps.toml
    在这里插入图片描述
    这里可以随便改,也可以不改,改成8888方便记忆。

(5)启动服务端可执行程序

输入命令 ./frps -c frps.toml
这里要带 -c 才使用配置文件运行 才会使用到自己设置的端口号8888作为 listen套接字获取连接
在这里插入图片描述

(6)修改被远程登陆客户端配置文件

vim frpc.toml
在这里插入图片描述
将remotePort 改为8081端口(该端口为服务端8081号端口,用来映射自己的私有Ip端口),连接的服务端地址改成 服务器 的公有ip,服务端端口改为修改好的8888端口。

(7) 启动被远程登陆客户端可执行程序

./frpc -c frpc.toml

在这里插入图片描述
此时可以看到服务器有一条新的消息,服务器8081号端口被启动了。
在这里插入图片描述

(8)此时再用xshell启用一个客户端 只不过端口改为8081号端口

在这里插入图片描述
点击确定 再 连接
在这里插入图片描述
此时该客户端已经远程登陆上了我们的虚拟机了。
我们可以用Xshell上的客户端 进入 Desktop 文件 touch 一个文件,此时远程的虚拟机桌面上就会多出一个自己所 touch 出来的文件。

在这里插入图片描述
在这里插入图片描述
此时就完成了 远程登陆 测试模块。

2. nginx远程访问

1. 安装一个nginx代理服务器

sudo yum install nginx # centos 安装
sudo apt install nginx # ubuntu 安装
#启动
$ nginx
#暂停
# nginx -s stop

安装好后启动
在这里插入图片描述

2. 启动后查看nginx所使用到的端口号

这里可以看到nginx所使用的端口是80号端口,此时在虚拟机客户端修改frpc.toml配置文件
在这里插入图片描述
再添加一个字段 对应 服务器的8082号端口。
nginx 首页默认 apt 安装之后,首页是:/var/www/html/XXX(index.nginx-debian.html)
在这里插入图片描述
此时这里使用到了http服务,我们用浏览器浏览 服务器公有Ip 加 8082端口号 即可看到 Nginx 所提供的http服务了。
在这里插入图片描述
由于我修改了 .html 文件所以界面就是这个样子,正常的华一般是 hello Nginx 的界面。

四.将客户端与服务端放置后台运行

nohup ./frpc -c ./frpc.toml &> /dev/null &
nohup ./frps -c ./frps.toml &> /dev/null &

&> /dev/null:这是重定向操作,用于将命令的标准输出(stdout)和标准错误(stderr)都重定向到/dev/null。/dev/null 是一个特殊的设备文件,向它写入的内容都会被丢弃,读取它则会立即返回文件结束。因此,这个操作的作用是忽略命令的所有输出信息。

相关文章:

  • 有序数组的平方
  • 【云安全】云原生-centos7搭建/安装/部署k8s1.23.6单节点
  • 【开源项目】Excel手撕AI算法深入理解(二):Transformer
  • 头歌educoder——数据库 第10-11章
  • 对自己的优缺点评价
  • 导入 Excel 批量替换文件夹名称
  • MySQL 分区与分库分表策略
  • 【场景应用6】Autoformer在时间序列预测任务中的应用
  • LangGraph——Agent AI的持久化状态
  • 038-flatbuffers
  • ngx_set_worker_processes
  • 考研数据结构之串的模式匹配算法——KMP算法详解(包含真题及解析)
  • 回顾CSA,CSA复习
  • Linux的网络配置的资料
  • python对mysql数据库的操作
  • 深度学习中多机训练概念下的DP与DDP
  • C++ 编程指南35 - 为保持ABI稳定,应避免模板接口
  • SQL查询语句的执行顺序
  • C++(初阶)(十一)——list
  • 数据结构实验6.1:矩阵的螺旋方阵输出
  • “把历史视角、战略思维,都落实到具体行动上来”——习近平总书记河南考察纪实
  • 乌前总统亚努科维奇前顾问在西班牙遭枪击死亡
  • 建行原副行长章更生涉嫌受贿罪、违法发放贷款罪被逮捕
  • 观察|脱欧5年后英欧再办峰会,多项突破性协议意味着什么?
  • 马上评|把孩子当牟利工具,这样的流量吃不得
  • 中国需加强自主创新和国际合作,提升产业链供应链韧性