管理杂谈OA答疑ERP答疑教程搜索

【C#】FastTunnel:一个.NET开源免费高性能跨平台的内网穿透工具


快速上手

快速搭建服务

  1. 在 releases 页面下载对应的程序,也可以本地下载:FastTunnel.rar

  2. 根据自己的需求修改客户端以及服务端配置文件appsettings.json

  3. 服务端运行FastTunnel.Server

  4. 客户端运行FastTunnel.Cient

使用Docker安装

配置文件和日志文件通过volume挂载,如果之前运行过本镜像,docker可能不会更新至最新的镜像,请手动删除已存在的镜像,然后执行以下命令

docker run --detach \

  --publish 1270:1270 --publish 1271:1271 \

  --name FastTunnel \

  --restart always \

  --volume /var/FastTunnel/config:/app/config \

  --volume /var/FastTunnel/Logs:/app/Logs \

  springhgui/fasttunnel:latest

如果你不仅仅使用Http代理,可别忘记将docker的端口进行映射,例如在docker运行时增加类似下面的参数

-p 1270-2270:1270-2270  

​如何在 Linux/Mac系统运行?

Windows

直接双击 FastTunnel.Server.exe 或 FastTunnel.Client.exe 即可运行

Linux Mac

服务端:

chmod +x FastTunnel.Server

./FastTunnel.Server

客户端:

chmod +x FastTunnel.Client

./FastTunnel.Client

相关高质量博客

原理和教程


配置示例

1. 用自定义域名访问内网web服务

如果不希望每次访问都带上端口号,可以通过nginx转发实现。

http {

    # 添加resolver 

    resolver 8.8.8.8;


    # 设置 *.abc.com 转发至1270端口

    server {

      server_name  *.abc.com;

      location / {

         proxy_pass http://$host:1270;

         proxy_set_header   Host             $host;

         proxy_set_header   X-Real-IP        $remote_addr;

         proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

      }


      # 可选

      error_log /var/log/nginx/error_ft.log error;

    }

}

2. 远程内网计算机 Windows/Linux/Mac

::: warning 开放Windows桌面3389端口或是linux22端口等等,请务必将内网机器的密码设置复杂点,因为一旦使用内网穿透技术将你的内网机器暴露到公网则有可能被黑客攻击。已有很多用户因为使用弱密码被勒索病毒攻击。 :::

客户端配置如下,内网有两台主机,ip如下: appsettings.json

"ClientSettings": {

  "Server": {

    // [必选] 与服务端通讯协议(来自服务端配置文件的urls参数)

    // 可选参数:ws(http)或wss(https)

    "Protocol": "ws",

    // [必选] 服务端ip/域名(来自服务端配置文件的urls参数)

    "ServerAddr": "test.cc",

    // [必选] 服务端监听的通信端口(来自服务端配置文件的urls参数)

    "ServerPort": 1270

  },

  "Forwards": [

    {

      "LocalIp": "192.168.0.100", // linux主机

      "LocalPort": 22,            // ssh远程默认端口号

      "RemotePort": 12701

    },

    {

      "LocalIp": "192.168.0.101", // windows主机

      "LocalPort": 3389,          // windows远程桌面默认端口号

      "RemotePort": 12702

    }

  ]

}

ssh远程内网linux主机 (ip:192.168.0.100)

假设内网主机的用户名为 root,服务器ip为x.x.x.x,访问内网的两个主机分别如下

ssh -oPort=12701 root@x.x.x.x

mstsc远程桌面Windows主机(ip:192.168.0.101)

被控制端设置

::: warning Windows家庭版不支持被控制,可能不存在下图所示的选项 :::

控制端设置


更多精彩文章浏览...
点击右上角图标分享到朋友圈
官方网站:http://www.clicksun.cn
咨询热线:400-186-1886
服务邮箱:service@clicksun.cn