最常见的使用场景就是微信开发:微信服务器需要主动调用或回调开发者服务器
如果把代码直接部署到公网服务器,开发阶段也不便于 debug,此时 ngrok 就派上用场了
当本地运行一个服务时,它能把本地的一个端口反向代理到公网,这样全世界都可以访问
Ngrok
先到官方注册一个账号:https://dashboard.ngrok.com/signup,它会给你一个 Authtoken
再把这个工具下载下来:https://ngrok.com/download
然后执行下面这个命令,这样就配置好了
./ngrok config add-authtoken YourAuthtoken
接下来启动,这样就可以在控制台看到分配的公网域名了(每次执行后,公网域名都会变化)
./ngrok http 2000
Pagekite
它也能实现和 ngrok 一样的效果(同样的,二者的速度都很慢,均不推荐)
其官网为:http://pagekite.net,按照下载页面的提示,很容易就弄好了,下面是效果图

SunnyNgrok
有良心网友免费搭建了一个 ngrok 服务器:http://www.ngrok.cc
下面是使用效果图(也可以自己搭一个 ngrok 服务,网上有教程)

2016-11-04 19:08 更新:今天同事推荐了另一个免费的:http://ngrok.2bdata.com,也挺好用
小米球Ngrok
2024-06-19 21:22 更新:ngrok.2bdata不能用了,ngrok.cc需要2.00元实名认证 + 最少10.00元/月的费用
最近又发现一个热心猿友提供的:https://www.xiaomiqiu.cn/,只需要0.5元的实名认证费,也很良心!
而且,它代理出去的公网地址,也是固定的 URL,并且也支持 HTTP / HTTPS / TCP,值得推荐!!
FRP
如果有一台具备公网 IP 的服务器,那么也可以搭一个 FRP(Fast Reverse Proxy) 服务,实现内网穿透
下载地址:https://github.com/fatedier/frp/releases,它分服务端和客户端
补充:v0.52.0 开始,不再推荐使用 INI 配置文件,改为 YAML / TOML / JSON 格式,详细介绍如下:
https://www.cnblogs.com/huang-savesblog/articles/17787700.html
https://github.com/fatedier/frp/blob/master/conf/frps_full_example.toml
另外:网上也有免费的,但没试过效果:https://freefrp.net/docs
服务端配置
将下载的 frp_0.65.0_linux_amd64.tar.gz 解压后,删掉 frpc 和 frpc.toml(这俩是客户端用的)
然后也删掉 frps.toml 和 LICENSE(最后只剩下 frps 一个文件)
这里使用 YAML 文件,所以创建一个 frps.yaml
bindAddr: 0.0.0.0
bindPort: 8801
auth:
method: token
token: xuanyuv_token
webServer:
addr: 0.0.0.0
port: 8802
user: xuanyuv
password: xuanyuv_dashboard
log:
# 启动时,若本地不存在logs文件夹,那么frps会自动创建
to: ./logs/frps.log
level: info
maxDays: 300
subDomainHost: xuanyuv.com
vhostHTTPPort: 8800
vhostHTTPTimeout: 600
再编写一个启动脚本:startup.sh
#!/bin/bash
cd /app/software/frp_0.65.0_linux_amd64/
nohup ./frps -c ./frps.yaml > /dev/null 2>&1 &
客户端配置
将下载的 frp_0.65.0_windows_amd64.zip 解压后,删掉 frps 和 frps.toml(这俩是服务端用的)
然后也删掉 frpc.toml 和 LICENSE(最后只剩下 frpc.exe 一个文件)
这里也用 YAML 文件,所以创建一个 frpc.yaml(注意:这里是 frpC.yaml,不是 frpS.yaml)
serverAddr: 服务端的公网IP
serverPort: 8801
auth:
method: token
token: xuanyuv_token
log:
# 启动时,若本地不存在logs文件夹,那么frpc.exe会自动创建
to: ./logs/frpc.log
level: info
maxDays: 300
transport:
tls:
enable: false
proxies:
- name: qss-xuanyuv
type: http
subdomain: qss
localIP: 127.0.0.1
localPort: 1100
- name: mpp-xuanyuv
type: http
subdomain: mpp
localIP: 127.0.0.1
localPort: 2100
再编写一个启动脚本:startup.bat
@echo off
title FRP内网穿透工具【玄玉制作】
color 02
echo;
echo FRP Client Startup....
echo;
echo http://qss.xuanyuv.com:8800/
call frpc.exe -c frpc.yaml
服务端和客户端均启动后,通过 http://服务端的公网IP:8802/ 就可以登录到 FRP 后台,查看代理情况
然后访问:http://qss.xuanyuv.com:8800/,就能看到 http://127.0.0.1:1100/ 对应的服务了
下面补充几个网络相关的注意事项:
- 代理本地 HTTP 服务时,还要将 xuanyuv.com 解析到服务端的公网IP,且域名已备案
- 服务端的 bindPort 端口,应开放,且,仅开放给 frpc.exe 所在的客户端
- 服务端的 vhostHTTPPort 端口,开放给需要访问本地服务的互联网用户
- 服务端的 webServer.port 端口,开放给管理员即可