写点什么

5 分钟,使用内网穿透快速实现远程桌面

用户头像
星安果
关注
发布于: 3 小时前

1. 前言

大家好,我是安果!


一提到远程桌面,可能大家都会想到 TeamViewer、向日葵等第三方软件


但是,它们大多是商业化软件,价格昂贵;即使有提供免费版本,也是各种限制,稳定性和安全性也没法得到保证


本篇文章将介绍如何使用「 内网穿透 」实现远程桌面管理

2. 内网穿透 Frp

常见实现内网穿透的方案有:Frp、Ngrok、natapp


其中,Frp 是一款开源的、简洁易用、高性能的反向代理软件


它支持 TCP、UDP、HTTP、HTTPS 等协议类型


官方地址:https://github.com/fatedier/frp

3. 操作步骤

下面以 Frp 内网穿透为例,实现远程桌面访问


3-1  部署 Frp 服务端到云服务器


根据系统平台,从下面链接下载 Frp 源码上传到云服务器


https://github.com/fatedier/frp/releases


当然,也可以通过 wget 命令直接下载


# 使用wget命令下载0.37.1版本wget https://github.com/fatedier/frp/releases/download/v0.37.1/frp_0.37.1_linux_amd64.tar.gz
复制代码


接着,解压文件压缩包


# 解压文件tar -zxvf frp_0.37.1_linux_amd64.tar.gz
复制代码


然后,使用 vi/vim 编辑 Frp 服务端配置文件「 frps.ini 」


其中


  • bind_port 用于指定 Frp 服务端的端口号

  • dashboard_user、dashboard_pwd、dashboard_port 分别用于配置 Frp 后台管理的账号信息及访问端口号


# frps.ini
[common]bind_addr = 0.0.0.0bind_port = 7777token = 12345678 # 授权码
# 配置frp后台管理账号dashboard_user = admindashboard_pwd = admindashboard_port = 8888 enable_prometheus = true
# 配置日志配置文件夹log_file = /var/log/frps.loglog_level = infolog_max_days = 3
复制代码


最后,开放云服务器防火墙端口、配置安全组规则,运行 Frp 服务


# 开放防火墙端口号、配置安全组规则# 这里配置7777、8888端口号
# 配置服务mkdir -p /etc/frpcp frps.ini /etc/frpcp frps /usr/bincp systemd/frps.service /usr/lib/a# 启动frps服务systemctl enable frpssystemctl start frps
复制代码


3-2  访问 Frp 后台管理


打开浏览器,访问云服务器的 ip 地址 + 上面指定的端口号「 8888 」,输入上面的用户名和密码,即可以进入到 Frp 后台管理界面



管理界面实时查看 Frp 的运行状态及代理统计信息展示


3-3  部署 Frp 客户端到目标计算机


PS:由于目标计算机是 Windows,所有需要先下载 Windows 版本的 Frp 源码


首先,修改客户端配置文件「 frpc.ini 」


# 配置Frp客户端信息# frpc.ini
[common]server_addr = frp公网ip地址 #frp服务公网ip地址server_port = 7777 # frps.ini中指定的端口号token = 12345678 # 和frps.ini中的token保持一致
[ssh]type = tcp # 通信方式local_ip = 127.0.0.1local_port = 3389 # 远程访问服务默认端口是3389remote_port = 6000 # 定义远程端口通过6000指向本地3389端口
复制代码


然后,使用 CMD 中使用下面命令运行 Frp 客户端


# 运行frp客户端frpc -c frpc.ini
复制代码


最后,刷新 Frp Dashboard 管理页面,可以观察到 Frp 客户端的连接信息



3-4  目标计算机开机自启 - winsw


为了保证目标计算机永久在线,可以利用「 winsw 」将客户端连接配置做成一个服务,并配置为开机自启


项目下载地址:https://github.com/winsw/winsw/releases


配置步骤如下:


  • 根据系统版本下载对应源码,解压后放置到 Frp 同一级目录下

  • 修改可执行文件名称为 winsw.exe

  • 新建一个配置文件 winsw.xml,添加运行 Frp 客户端的命令


配置信息如下:


# winsw.xml<service>    <id>frp</id>    <name>frp</name>    <description>frp远程控制客户端服务</description>    <executable>frpc</executable>    <arguments>-c frpc.ini</arguments>    <logmode>reset</logmode></service>
复制代码


最后,使用管理员身份打开 CMD 终端,运行下面命令,使得 Frp 客户端能变成系统服务在后台运行了


# 管理员身份运行winsw installwinsw start
复制代码


3-5  远程桌面访问


通过云服务器 ip + 客户端指定的远程访问端口号,就可以对目标计算机进行远程桌面控制了


假设云服务器 ip 为「 *.*.*.* 」,Frp 客户端配置文件中指定的远程端口号为 6000


只需要使用命令「 mstsc 」进入到远程桌面窗口,计算机输入「 *.*.*.*:6000 」,输入目标计算机的用户名、密码即可以远程控制目标计算机了


当然,也可以通过手机 App,比如「 RD Client 」来控制远程桌面

4. 最后

上面通过 Frp 内网穿透实现了远程桌面控制,实际使用下来体验真的不要太好


事实上内网穿透的用途远不止此,大家可以查阅资料去自行扩展


如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

发布于: 3 小时前阅读数: 2
用户头像

星安果

关注

还未添加个人签名 2019.03.27 加入

公众号:AirPython,分享 Python 爬虫、自动化原创技术干货!

评论

发布
暂无评论
5 分钟,使用内网穿透快速实现远程桌面