搭建ngrok实现内网穿透和远程桌面

发布于 2019-12-16  1 次阅读


域名

首先需要一个域名,现在的域名非常便宜,可以自行申请。

VPS

选择轻量应用服务器有着5M的带宽可以满足基本建站和远程桌面需求,地域选择华东地区,因为服务器在上海对东南很有优势

配置

1.系统选择Ubuntu 18.04 ,使用xshell等工具连接服务器,先执行更新命令:

    apt-get update
    apt-get upgrade

2.安装git 和Golang

    apt-get install build-essential golang mercurial git

Go语言支持,因为Ngrok是基于Go语言编写的
3.获取 ngrok 源码:

    git clone https://github.com/tutumcloud/ngrok.git ngrok
    cd ngrok

4.生成并替换源码里默认的证书

        NGROK_DOMAIN="XXX.com" //这里是自己的域名
        
        openssl genrsa -out base.key 2048
        openssl req -new -x509 -nodes -key base.key -days 10000 -subj "/CN=NGROK_DOMAIN" -out base.pem
        openssl genrsa -out server.key 2048
        openssl req -new -key server.key -subj "/CN=NGROK_DOMAIN" -out server.csr
        openssl x509 -req -in server.csr -CA base.pem -CAkey base.key -CAcreateserial -days 10000 -out server.crt
        cp base.pem assets/client/tls/ngrokroot.crt
        cp server.crt assets/server/tls/snakeoil.crt
        cp server.key assets/server/tls/snakeoil.key

如果出现Can't load /root/.rnd into RNG请输入

    cd /root
    openssl rand -writerand .rnd

5.开始编译:

    sudo make release-server release-client

6.启动服务端

    ./bin/ngrokd -tlsKey=server.key -tlsCrt=server.crt -domain="XXX.com" -httpAddr=":80" -httpsAddr=":443"

7.编译客户端

(1)windows

    GOOS=windows GOARCH=amd64 make release-client 
(2)mac

    GOOS=darwin GOARCH=amd64 make release-client

执行对应的命令会在bin目录下生成相对应的windows、mac目录,ngrok.exe就存放在对应目录下。将对应的ngrok.exe下载到本地。
8.设置本地客户端

(1)在同级目录下新建一个配置文件ngrok.cfg

     server_addr: "XXX:4443"
    trust_host_root_certs: false
    tunnels:
      mstsc:
        remote_port: 3389 //这里是远程端口
        proto:
          tcp: "127.0.0.1:3389" 

(2)同级目录下新建一个启动脚本startup.bat

    ngrok.exe -config=ngrok.cfg start mstsc

其中,-config指向配置文件,-log存放日志文件位置,-subdomain为自定义的域名前缀。8080为端口号。
(3)启动,点击启动脚本startup.bat完成启动。
9.设置为系统程序,并后台运行。
服务器在运行ngrok时,如果关闭会话窗口,会导致服务中断,很显然这不是我们想要的结果,我们需要服务不断的在后台运行,当需要的时候在停止。

    cd /etc/systemd/system/

然后:

    vi ngrok.service

内容为

    [Unit]
    Description=ngrok
    After=network.target
    
    [Service]
    ExecStart=/root/ngrok/bin/ngrokd -tlsKey=/root/ngrok/server.key -tlsCrt=/root/ngrok/server.crt -domain="XXXXX.com" -httpAddr=":80" -httpsAddr=":443"
    
    [Install]
    WantedBy=multi-user.target

按esc 然后shift+两下Z退出编辑
10.执行
开启服务:

    systemctl start ngrok.service

查看服务运行状态:

    systemctl status ngrok.service

停止服务:

    systemctl stop ngrok.service

连接

不但电脑可以,手机也可以连接,手机连接上OTG接上鼠标键盘可以当作电脑用。


本当の声を響かせてよ