Ngrok内网穿透配置详细教程

在现代的开发和运维工作中,内网穿透技术的需求逐渐增加,特别是在开发、测试和远程访问时,Ngrok作为一种常用的工具,提供了方便、简单的内网穿透解决方案。

Ngrok内网穿透

一、什么是Ngrok?

Ngrok是一款开源的反向代理工具,能够将本地开发环境暴露到公网,使得你可以通过互联网访问在内网中运行的本地服务。通过Ngrok,你可以将本地的Web应用、API服务或其他网络服务快速暴露给外部用户,而无需进行复杂的路由或防火墙配置。

二、Ngrok的工作原理

Ngrok的工作原理相对简单。它通过创建一个隧道,将你的本地服务器与Ngrok的公共服务器进行连接,从而将本地服务暴露到公网。Ngrok会分配一个临时的公网地址(如http://xxxxx.ngrok.io),并将来自公网的请求转发到你的本地服务。

三、Ngrok的使用场景

  1. 本地开发与测试:开发人员可以在本地开发环境中运行应用并通过公网访问,方便测试和展示。
  2. 远程访问内网服务:在无法访问公司内网的情况下,可以通过Ngrok远程访问内网服务,如数据库、Web应用等。
  3. Webhook调试:如果你需要调试第三方服务(如支付网关、GitHub等)的Webhook回调,可以使用Ngrok将本地服务暴露到公网。
  4. 演示与共享:Ngrok可以方便地将本地的Web应用分享给其他人,供展示和协作。

四、如何使用Ngrok进行内网穿透

I. 安装Ngrok

首先,访问Ngrok官网下载适合你操作系统的版本。Ngrok支持Windows、macOS和Linux平台。以Windows为例,安装步骤如下:

  • 下载并解压Ngrok压缩包。
  • 将解压后的ngrok.exe文件放在系统的环境变量路径下,或者在命令行中直接使用Ngrok的绝对路径。

Ngrok download

II. 注册并获取Ngrok令牌

为了使用Ngrok的所有功能,你需要注册一个Ngrok账户并获取一个身份令牌。具体步骤如下:

  1. 访问Ngrok官网,点击Sign Up进行注册。
  2. 注册完成后,登录到Ngrok Dashboard。
  3. 在“Auth”页面中,你将看到一个authtoken。复制这个令牌,它将用于配置Ngrok客户端。

III. 配置Ngrok

在命令行中输入以下命令来配置Ngrok:

ngrok authtoken YOUR_AUTH_TOKEN

替换YOUR_AUTH_TOKEN为你从Ngrok官网获取的身份令牌。配置完成后,Ngrok将记住你的账户信息,允许你使用更多的功能。

IV. 启动Ngrok隧道

Ngrok的基本用法是将本地服务暴露到公网。假设你有一个本地Web服务运行在localhost:8080端口,你可以使用以下命令启动隧道:

ngrok http 8080

执行命令后,Ngrok会输出一个类似下面的信息:

ngrok by @inconshreveable                                                                                                                                                                   

Session Status                online                                                                                                                                                   
Account                       your_account_name (Plan: Free)                                                                                                                             
Version                       3.0.0                                                                                                                                                      
Region                        United States (us)                                                                                                                                         
Web Interface                 http://127.0.0.1:4040                                                                                                                                     
Forwarding                    http://xxxxxxxx.ngrok.io -> http://localhost:8080                                                                             
Forwarding                    https://xxxxxxxx.ngrok.io -> http://localhost:8080

Ngrok

此时,你可以通过公网地址(如http://xxxxxxxx.ngrok.io)访问到本地运行的服务。如果你的服务是HTTPS协议,你将会得到一个HTTPS地址(如https://xxxxxxxx.ngrok.io)。

V. 配置不同协议

除了HTTP协议,Ngrok还支持其他协议的内网穿透。你可以使用以下命令来暴露其他类型的服务:

  • TCP隧道:如果你需要将一个TCP服务暴露到公网(例如数据库、FTP服务),可以使用以下命令:
ngrok tcp 3306

这样就会将本地的MySQL服务(假设运行在3306端口)暴露到公网。

  • 自定义端口:如果你的本地服务使用的端口不是默认的,你可以指定任意端口进行内网穿透。例如:
ngrok http 8000

这样,Ngrok会将localhost:8000暴露到公网。

VI. 管理和查看隧道

Ngrok提供了一个Web界面,便于查看请求的日志和管理隧道。你可以通过访问http://127.0.0.1:4040 来查看所有进入你隧道的请求、响应以及相关日志。这对调试非常有帮助。

五、Ngrok高级功能

I. 自定义域名

Ngrok提供了自定义子域名的功能,允许你为隧道指定一个易于记忆的地址(仅限付费用户)。例如,你可以将http://xxxxxx.ngrok.io替换为http://myapp.ngrok.io。这对于展示和长期使用非常有帮助。

配置命令如下:

ngrok http -subdomain=myapp 8080

II. 隧道持久化

在免费的Ngrok账户中,每次启动隧道时,分配的地址都是随机的。如果你需要固定的地址,可以选择付费方案,这将允许你使用固定的子域名或IP地址。

III. 使用API管理Ngrok隧道

Ngrok提供了REST API,允许你通过编程方式管理隧道。这对于自动化部署、CI/CD流程等场景非常有用。

六、常见问题解答

  1. 如何关闭Ngrok隧道?

    你可以在命令行窗口中按Ctrl+C来停止Ngrok隧道。也可以直接关闭Ngrok的控制台窗口来断开连接。

  2. 使用Ngrok时访问速度慢怎么办?

    由于Ngrok将请求从公网转发到本地服务器,所以访问速度可能会受到网络条件的影响。你可以尝试升级Ngrok账户,以获得更高的带宽和更快的连接速度。

  3. 是否支持多个隧道?

    是的,Ngrok支持同时启动多个隧道,你只需在不同的终端窗口中启动不同的隧道即可。

七、总结

Ngrok作为一款强大的内网穿透工具,广泛应用于开发、调试和远程访问等场景。通过简单的配置,开发者可以快速将本地服务暴露到公网,进行远程访问和测试。

4.7/5 - (3 votes)

资源教程代理,内网穿透

Posted by 老杰克