二级域名 端口映射什么意思(如何理解端口映射)

   谷歌SEO    

内网穿透,又叫NAT端口穿透,翻译过来就是本地应用/无对外域名端口的可以可以直接被你朋友访问。 通常我们的电脑是无法自己被访问的。因为我们的电脑缺少自己的独立的ip地址。现在ip稀缺,电信运营商已经不会随便分配固定ip给个人。

通常实现内网穿透,是通过路由器上端口映射来实现的。但是路由器通常不是每个人都有权限可以访问和设置,而且可能存在多级路由器较为复杂的网络结构。端口映射也无法实现。

因为微信开发者,来调试各种功能,需要80或443端口,方便进行调试的话,可以选择使用需要ngrok来实现了。

ngrok 建立一个隧道,将主机A的http请求 传递给 主机B,从而实现内网穿透。

ngrok分为client端(ngrok)和服务端(ngrokd)


原理图

实际部署架构图

它的工作流程如下:

访问端输入域名->DNS->ngrok服务端->请求映射到ngrok客户端->客户端返回响应到ngrok服务端->ngrok服务端返回响应到访问端

centos7 64位 (其它环境请自行尝试,原理上是通用的)

关于域名: 我们声明两个概念:一个是基础域名,可以是顶级或者二级,它用来为ngrok服务端本身提供外部访问(ngrok客户端连接用)。二就是基于基础域名的二级或者三级域名,它用来映射到你的本地服务器,我称它为映射域名。它可以设置多个,这取决于你的需要。例如 abc.com 和 ngrok.abc.com / ngrok2.abc.com,每个映射域名对应一个ngrok客户端

如果你需要使用顶级域名作为基础域名,那么请将 abc.com 泛解析到服务器ip,然后将你需要使用的二级域名通过A记录解析到服务器ip,例如 ngrok.abc.com

如果你需要使用二级域名,那么先将你的二级域名 xxx.abc.com 通过A记录解析到服务器域名。然后将三级域名(比如 test.xxx )通过CNAME的方式解析到 xxx.abc.com ,这次 xxx.abc.com 便成为了客户端与服务端的连接域名, test.xxx.abc.com 则是映射域名.


一,安装git和go以及其它依赖

完成后会在当前目录生成ngrok目录

生成:

替换(提示overwrite输入y)

切换回ngrok目录,以下命令按需生成

所有程序都将生成在bin目录中,不同平台将建立不同的子目录

目录中,ngrok是客户端,ngrokd是服务端

启动服务器:

其它配置:

-httpAddr=":80" http服务的访问端口 默认80

-httpsAddr=":443" https服务的访问端口 默认443

-tunnelAddr=":4443" 客户端连接服务端的端口 默认4443

以上端口,如若与系统其他服务有冲突,开启服务时请自行配置其他端口。

ps:客户端出现reconnection... 那就是服务端未启动或者端口无法访问,可以找正常访问互联网的机器进行telnet对应的服务端口,如果正常,则可以排除端口的问题。

新建配置文件ngrok.cfg

运行客户端

-subdomain用来指定域名的前缀(也就是映射域名的前缀),如上设置ngrok,当访问ngrok.abc.com时,ngrok服务端接收到请求后,便会将客户端http相应返回给访问端。80用来指定本地http服务的端口

此时,ngrok服务便搭建完成。


以上由个人亲自实践后得出的总结结论,请参考。

客户端正常运行请见以下截图,出现 online 即为成功启动穿透服务。

 标签:

评论留言

我要留言

欢迎参与讨论,请在这里发表您的看法、交流您的观点。