FRP 是一个免费开源的用于内网穿透的反向代理应用,它支持 TCP、UDP 协议, 也为 http 和 https 协议提供了额外的支持。
使用FRP可以实现在家里搭建自己的网站,个人网盘,远程访问自己的电脑,流媒体服务器等
1.我们需要一台公网服务器 大家可以选择腾讯云的轻量服务器 现在有活动一年60几 平均下来一个月也才5块钱,两瓶快乐水的价格而已 同时新用户还可以白嫖免费的服务器

2.通过ssh远程连接到服务器,并在控制台放通安全组内的所有端口(为了方便)
我使用的远程工具是FinalShell 它自带FTP功能,方便我们上传安装文件

3.将编译好的最新版本的FRP服务端(frps)上传到服务器内 这里我上传到/root目录下
项目地址:Releases · fatedier/frp · GitHub
记得选择linux_amd64.tar.gz结尾的文件下载,因为只有这个才是符合我们系统以及架构的文件
下载完成后你会得到一个以gz结尾的压缩包,这个是压缩包的格式,我们先在本地电脑上进行解压操作,方便后期上传。解压完gz格式的压缩包后你还会得到一个以tar结尾的压缩包,再次进行解压后就可以得到项目本体文件夹啦
文件夹的大体结构如下
frpc
frpc.ini
frpc_full.ini
frps
frps.ini
frps_full.ini
其中frpc开头的是我们的客户端文件,我们单独创建一个文件夹将frpc开头的文件剪贴进去
这个文件夹现在就只剩下frps开头的服务端文件了
这时候我们开始编辑客户端的配置文件啦(服务端的配置文件默认不需要更改,除非7000的侦听端口被占用才需要进行更改)
打开frpc.ini
大家应该可以看到以下内容
[common]
server_addr = 127.0.0.1
server_port = 7000
[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6000
我们需要将里面的内容全部删掉,修改成这样
[common]
server_addr = 改成你自己的服务器IP地址
server_port = 7000
[remote]
type = tcp
local_ip = 127.0.0.1
local_port = 3389
remote_port = 3389
其中 local_port代表本地电脑的端口,remote_port代表远程服务器的端口
即:我们远程连接的链接为:
服务器IP:3389
local_port如果没有修改的话默认都是3389
remote_port可以修改成自己喜欢的端口号,这里为了方便就保持一致啦
修改完成后将配置文件保存
4.将frps文件夹全部上传到服务器/root目录下,并且设置文件夹以及文件夹下全部文件权限为777

完成后会发现多了一个文件夹(就是你刚才拖过来的那个,我这里是用frps做为文件夹名称)
完成后点击确定保存
5. 执行
cd /root/frps
跳转到frps目录下
启动frps
./frps -c ./frps.ini
看到以下反馈即代表服务端搭建成功啦,你已经成功一半了

6.客户端连接服务端
我们回到客户机上面 打开frpc客户端所在的文件夹 并且通过cmd进入该文件夹内

运行以下命令
frpc.exe -c frpc.ini
这时候你肯定会发现以下情况

是的 这个是错误示范,我犯了一个错误,因为服务端和客户端是绑定在一起的,而我们下载的服务端是Linux的,但是客户端我们需要Windows版才可以
所以我们前往项目地址下载Windows版本的客户端
我们依旧选择以
windows_amd64.zip为结尾的客户端
Releases · fatedier/frp · GitHub
我们只需要把frpc.exe这个文件拉到文件夹里面即可,其他配置文件格式是与Linux下相同的
这时候我们再重复执行上述命令,就可以成功连接啦

服务端上面也有我们连接成功的日志

这时候,我们就可以在任何地方远程控制我们家里的电脑啦,流畅度比什么向日葵和todesk都高,因为他们的传输协议是stream视频流传输,但是我们不是
哦对了,大家记得打开家里电脑的允许远程控制的开关哦,不知道怎么打开的可以请教一下百度
通过这个就可以远程连接到自己家里的电脑啦

计算机地址就是 服务器IP:3389
(如果你没有更改的话就是3389)
还有一个题外话,被控机器(家里的电脑需要设置一个密码才可以远程连接哦,不然就只能破解了,这样会稍微麻烦一点,如果有需要的可以在评论区留言,我看一下需要这个功能的人数多吗,如果多的话我们再单独出一期教程)
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除
Unity自动旋转动画1.开门需要门把手先动,门再动2.关门需要门先动,门把手再动3.中途播放过程中不可以再次进行操作觉得太复杂?查看我的文章开关门简易进阶版效果:如果这个门可以直接打开的话,就不需要放置"门把手"如果门把手还有钥匙需要旋转,那就可以把钥匙放在门把手的"门把手",理论上是可以无限套娃的可调整参数有:角度,反向,轴向,速度运行时点击Test进行测试自己写的代码比较垃圾,命名与结构比较拉,高手轻点喷,新手有类似的需求可以拿去做参考上代码usingSystem.Collections;usingSystem.Collections.Generic;usingUnityEngine;u
require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame
我有一个使用PDFKit呈现网页的pdf版本的Rails应用程序。我使用Thin作为开发服务器。问题是当我处于开发模式时。当我使用“bundleexecrailss”启动我的服务器并尝试呈现任何PDF时,整个过程会陷入僵局,因为当您呈现PDF时,会向服务器请求一些额外的资源,如图像和css,看起来只有一个线程.如何配置Rails开发服务器以运行多个工作线程?非常感谢。 最佳答案 我找到的最简单的解决方案是unicorn.geminstallunicorn创建一个unicorn.conf:worker_processes3然后使用它:
我将以下代码放在一起用于一个简单的RubyTFTP服务器。它工作正常,因为它监听端口69并且我的TFTP客户端连接到它,我能够将数据包写入test.txt,但我不只是写入数据包,我希望能够从我的客户端通过TFTP传输文件到/temp目录。预先感谢您的帮助!require'socket.so'classTFTPServerdefinitialize(port)@port=portenddefstart@socket=UDPSocket.new@socket.bind('',@port)whiletruepacket=@socket.recvfrom(1024)putspacketFile
在previousquestion中我想出了如何在多个服务器上启动经过密码验证的sshsession来运行单个命令。现在我需要能够执行“sudo”命令。问题是,net-ssh-multi没有分配sudo需要运行的伪终端(pty),导致以下错误:[127.0.0.1:stderr]sudo:sorry,youmusthaveattytorunsudo根据documentation,可以通过调用channel对象的方法来分配伪终端,但是,以下代码不起作用:它会生成上面的“notty”错误:require'net/ssh'require'net/ssh/multi'Net::SSH::Mul
我刚刚在我的Ubuntu9.10服务器上安装了TeamBox。我使用提供的服务器脚本在端口3000上启动并运行它。它的运行速度非常慢,从另一台计算机连接时每个HTTP请求最多需要30秒。我使用链接从shell加载TeamBox,一点也不花时间。然后我设置了一个SSH隧道,它再次运行得非常快。我通过此服务器上的apache以及SAMBA等运行了大约30个虚拟主机,没有任何问题。我该如何解决这个问题? 最佳答案 我的redmine(ruby,webrick)太慢了。现在我解决了这个问题:apt-getinstallmongrelruby