ngrok如何实现内网穿透?

ngrok 是一款开源的网络隧道工具,可将本地服务(如 Web 服务器、SSH 等)安全地暴露到公网,生成临时域名供外部访问,适用于开发调试、演示、远程访问等场景,支持 HTTPS、TCP 隧道等功能。


Linux 安装 ngrok 详细步骤

步骤 1:下载 ngrok 客户端

打开终端,通过官方源下载最新版(以 64 位 Linux 为例):

cd /tmp
wget https://bin.equinox.io/c/bNyj1mQVY4c/ngrok-v3-stable-linux-amd64.tgz

注意

  • 其他架构设备请访问 ngrok 下载页 获取对应链接。
  • 始终从官网下载以确保安全,避免第三方篡改。

步骤 2:解压并安装

tar xvzf ngrok-v3-stable-linux-amd64.tgz  # 解压文件
sudo mv ngrok /usr/local/bin/             # 移动到系统路径
ngrok version                             # 验证安装(显示版本号即成功)

步骤 3:配置认证令牌(Authtoken)

  1. 注册 ngrok 账户(免费版可用)。
  2. 在 Dashboard 获取您的 Authtoken
  3. 终端执行:
    ngrok config add-authtoken <YOUR_AUTHTOKEN>  # 替换为实际令牌

    令牌保存在 ~/.config/ngrok/ngrok.yml,一次配置永久生效。

步骤 4:启动隧道服务

示例 1:暴露本地 Web 服务(端口 80)

ngrok http 80

示例 2:暴露 SSH 服务(端口 22)

ngrok tcp 22

运行后终端将显示公网地址(如 https://1a2b-34-56-78-90.ngrok-free.app),通过此地址即可访问本地服务。


进阶配置(可选)

设置为系统服务(Systemd)

创建服务文件:

sudo nano /etc/systemd/system/ngrok.service
```以 HTTP 隧道为例):
```ini
[Unit]
Description=Ngrok Tunnel
After=network.target
[Service]
ExecStart=/usr/local/bin/ngrok http 80
Restart=always
User=your_username  # 替换为实际用户名
[Install]
WantedBy=multi-user.target

启用服务:

sudo systemctl daemon-reload
sudo systemctl start ngrok
sudo systemctl enable ngrok  # 开机自启

自定义域名(付费版)

在 Dashboard 绑定域名后,启动命令添加 --domain 参数:

ngrok http --domain=yourdomain.ngrok.io 80

常见问题解决

  1. 连接失败

    • 检查 Authtoken 是否配置正确:ngrok config check
    • 确保防火墙放行 ngrok 流量:sudo ufw allow 80/tcp(按需替换端口)
  2. 服务意外停止
    使用 --log=stdout 参数查看日志:

    ngrok http 80 --log=stdout
  3. 免费版限制
    免费账户隧道会话 2 小时超时,并发连接数受限,需升级付费版解除限制。


安全注意事项

  • 🔒 勿暴露生产环境:ngrok 适用于测试,暴露数据库等高危服务可能导致攻击。
  • 🔑 启用身份验证:对敏感服务添加密码保护:
    ngrok http 80 --basic-auth="user:password"
  • 📜 遵守政策:禁止滥用隧道进行违法操作,违反将导致账户封禁。

官方文档参考

  • ngrok 官方文档
  • Linux 服务配置指南
    更新于 2025 年 10 月,适用于 ngrok v3 版本,安装前请确认官网是否有更新。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4659.html

(0)
酷番叔酷番叔
上一篇 2025年6月16日 13:26
下一篇 2025年6月16日 13:43

相关推荐

  • Linux系统如何不重启完成配置更新与服务生效?

    在Linux系统中,许多日常运维操作无需重启即可完成,这不仅提升了系统可用性,也减少了因重启导致的服务中断风险,以下从服务管理、内核参数调整、网络配置、软件管理、日志处理、用户管理、文件系统操作、硬件管理及系统优化等多个维度,详细说明不重启系统的操作方法,在Linux系统中,服务是最常需要动态调整的组件之一,通……

    2025年9月22日
    3800
  • Linux环境下编程语言的实际应用该如何入门与实践?

    在Linux环境下进行编程,依托于开源生态和丰富的工具链,开发者可以选择多种编程语言实现不同场景的需求,从系统级开发到应用层脚本,Linux提供了完善的编译、调试、运行环境,本文将详细介绍如何利用Linux编程语言进行开发,涵盖语言选择、环境搭建、核心工具使用及项目实践,Linux作为开源操作系统,其编程环境的……

    2025年9月22日
    4900
  • Linux如何退出当前普通用户账户?

    在Linux系统中,退出普通用户操作根据不同场景有多种实现方式,涵盖终端会话退出、用户切换、图形界面注销以及进程终止等需求,以下是详细操作方法和注意事项,帮助用户全面掌握退出普通用户的各类技巧,终端会话退出:基础退出方法当用户通过SSH登录虚拟终端(TTY)或使用图形界面的终端模拟器(如GNOME Termin……

    2025年10月4日
    2700
  • 如何安装最新LTS版JDK?

    准备工作更新系统终端执行:sudo apt update && sudo apt upgrade # Ubuntu/Debiansudo yum update # CentOS/RHEL检查现有Javajava -version若已安装旧版本,建议卸载避免冲突(sudo apt remove o……

    2025年6月20日
    8200
  • Linux系统下使用R语言安装R包的具体操作步骤是什么?

    在Linux系统中管理和安装R语言包是数据分析和科学计算的重要环节,正确的方法能确保环境稳定、依赖完整且高效运行,本文将详细介绍Linux环境下R包的安装途径、管理技巧及常见问题处理,帮助用户快速搭建符合需求的R环境,R语言环境准备在安装R包前,需确保Linux系统已正确安装R语言环境,不同Linux发行版的安……

    2025年10月5日
    2400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信