一键式部署本地项目到公网--ngrok-一键式部署本地项目到公网--ngrok

最近把玩自己的云服务器和域名部署web网站时候,不小心把自己的云服务器搞崩了。联系了腾讯云的工程师,前前后后弄了一整天,最终的结果还是重装系统 QAQ

这其中原委,咱用的是学生优惠下的白菜价的云服务器,整点个人博客网站就差不多了。要是部署的项目并发和性能要求高了,分分钟瘫痪。(所以云服务器一开始把依赖和环境安装好了,记得尽可能弄个快照以便日后重装)

但对于技术的渴望,让我试着去解决这个问题。我一直想,要是能在本地去试着部署web到公网,这性能问题也得到了调试了,可控性和可玩性也大大增强。

试过几种失败的方法后,我把眼光放在了一款叫做“ngrok”的软件上。

说起ngrok,我上手后,发现真的是一款神器。

ngrok 是一个运用反向代理和内网穿透,通过在公共端点和本地运行的 Web 服务器之间建立一个安全的通道,实现了内网主机的服务可以暴露给外网。
ngrok的内网穿透,见一言以蔽之就是,实现了内网+端口转换为外网,不过这里的外网域名是ngrok随机生成的,要是想有固定域名生成需要付费购买拓展内容。购买功能拓展

ngrok的使用非常简单,主要步骤都可以参考官网下载官网中文版,官网中文版的文档非常容易上手。

具体的上手操作都在官网上,我这里就说一下,我在使用中遇到的一个非常难解决的问题。

我一开始想部署一个前后端分离的项目,前端用react,后端用的Flask,这前后端分离后,分别要用两个端口。本身ngrok免费权限中是有4个端口的功能的,我们至少都可以开启四个端口的功能。但我在参考了网上国内国外的资源,以及官网中文版的文档,把ngrok.yml配置修改后,使用ngrok start --all,会提示找不到文件的报错信息。

这里我查阅了很多国内外的资料后,发现问题出在配置文件的空行上。就是ngrok.yml文件中,配置语句的空格与我想象中的不一样。下面展示下正确的ngrok配置文件与SpringBoot的配置文件对比

authtoken: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
# 新增多隧道
tunnels:
    flask:
        proto: http
        addr: 8080
    react:
        proto: http
        addr: 3000

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/sales?setUnicode=true&characterEncoding=utf8&useAffectedRows=true
    username: root
    password: 123456
  thymeleaf:
    cache: false

这里大家对比下,俩处配置文件的空行。前面ngrok的空行比正常的SpringBoot配置文件等一系列主流配置文件要多出一倍,当然也只有这样才能配置成功,命令行才能运转。很多地方的资料都没提到这一点,我也不知道这是官方的bug还是我不知道的技术原因。

调整过配置文件的缩进后,运用命令行语句后,项目成功跑起来了。如图所示,分别我的3000、8080端口都被映射为了两个ngrok的链接到公网。
[图片上传失败...(image-64551b-1667782385617)]

ngrok非常适合调试微信小程序、网站demo等。但这里跟使用MacOS的朋友说个小技巧(大佬绕路),我们下载了ngrok的二进制Unix执行文件,如果不想放在自己的终端执行路径中,可以在自己的.zshrc文件中,用alias功能把ngrok二进制文件路径替换成ngrok命令,如

alias ngrok="/Users/XXX/Desktop/something/code/放置/ngrok"

这样一来,就可以直接使用ngrok命令行语句了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,179评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,229评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,032评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,533评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,531评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,539评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,916评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,813评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,568评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,654评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,354评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,918评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,152评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,852评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,378评论 2 342

推荐阅读更多精彩内容