云服务器搭建Ngrok内网穿透服务器需要做哪些准备工作

第一部分:准备工作

  1.  域名解析(一般域名解析需要10分钟生效,所以我们第一步来做域名解析)

       由于我的备案主体在腾讯云,所以我就以我的域名为例子

        一定要添加一条主机记录为* 的这样我们才能通过 *.域名.com *为任意值 访问到应用。  记录值为服务器的公网IP

     2.服务器的基本环境

      Centos6.8 64位  1H、2G、1M  固定公网IP (安全组放开所有端口)     连接服务器工具:MobaXterm

 第二部分:搭建开始

 一、安装Git等

yum -y install zlib-devel openssl-devel perl hg cpio expat-devel gettext-devel curl curl-devel perl-ExtUtils-MakeMaker hg wget gcc gcc-c++ git

二、Go语言环境

 1. 下载Go语言包 (使用的是Go语言中文网的下载地址)

wget https://www.studygolang.com/dl/golang/go1.8.3.linux-amd64.tar.gz

 2. 解压到指定位置

tar -C /usr/local -xzf go1.8.3.linux-amd64.tar.gz

3. 配置环境变量

vim /etc/profile

4. 打开文件后在最下面添加下面的内容

export PATH=$PATH:/usr/local/go/bin

 5. 使环境变量生效

source /etc/profile

 6. 查看是否成功及版本

go version

 三、下载Ngrok源码包

 
  
  1. mkdir /ngrok

  2. cd /ngrok

  3. #这一步有点小慢

  4. git clone https://github.com/inconshreveable/ngrok.git

四、生成证书文件

 
  
  1. cd ngrok

  2. mkdir cert #创建一个文件夹用于存放证书

  3. cd cert #进入这个存证书的目录

  4. #无需修改复制直接执行即可 ↓

  5. openssl genrsa -out rootCA.key 2048

  6. #修改 /CN=你的域名 ↓

  7. openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=example.com" -days 5000 -out rootCA.pem

  8. #无需修改复制直接执行即可 ↓

  9. openssl genrsa -out device.key 2048

  10. #修改 /CN=你的域名 ↓

  11. openssl req -new -key device.key -subj "/CN=example.com" -out device.csr

  12. #无需修改复制直接执行即可 ↓

  13. openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 5000

 

 五、覆盖原证书(此处我根据https://segmentfault.com/a/1190000010338848 搭建的,使用人家博客写的我的服务端一直报 iled to read message: remote error: bad certificate )然后我自己手动复制的证书。

 1. 以下是上面链接所给覆盖证书的步骤:上面的注释是我加的,既然知道了是个什么意思就拷贝出来加工一下再复制到指定目录就行了吧

 
  
  1. #意思是:rootCA.pem复制到/ngrok/ngrok/assets/client/tls/并改成ngrokroot.crt

  2. yes|cp rootCA.pem /ngrok/ngrok/assets/client/tls/ngrokroot.crt

  3. #意思是:device.crt复制到/ngrok/ngrok/assets/server/tls/并改成snakeoil.crt

  4. yes|cp device.crt /ngrok/ngrok/assets/server/tls/snakeoil.crt

  5. #意思是:device.key 复制到/ngrok/ngrok/assets/server/client/tls/并改成snakeoil.key

  6. yes|cp device.key /ngrok/ngrok/assets/server/client/tls/snakeoil.key

  7. #注意第一个和第二三个的路径是不同的。

使用工具找到文件,然后拉出来到桌面,修改一下 再上传到指定 tls/下

 六、编译生成一个Linux的服务端 (时间也稍微有点长,经过三天的实验发现,早晨起来最好,网络还比较正常,下午晚上就容易卡住,迷之操作)

 在/ngrok/ngrok/下执行如下:

make release-server release-client

完成结果:

 七、编译生成一个Windows服务端

在/ngrok/ngrok/下执行如下: 

GOOS=windows GOARCH=amd64 make release-client  

完成结果:

 八、服务端与客户端的位置以及启动方式

 说明:ngrokd是Linux服务端的启动程序,下面windows_amd64 是保存的windows 64位的客户端启动程序,需要将此拷贝到本地电脑。

1. 服务器端启动

./ngrokd -tlsKey="/ngrok/ngrok/assets/server/tls/snakeoil.key" -tlsCrt="/ngrok/ngrok/assets/server/tls/snakeoil.crt" -domain="example.cn"  -httpAddr=":80" -httpsAddr=":443"

 Linux后台运行 

setsid ./ngrokd -tlsKey="/ngrok/ngrok/assets/server/tls/snakeoil.key" -tlsCrt="/ngrok/ngrok/assets/server/tls/snakeoil.crt" -domain="example.cn"  -httpAddr=":80" -httpsAddr=":443"

 启动结果:

 2. 客户端启动

1)新建文件 ngrok.cfg

 
  
  1. server_addr: "example.cn:4443"

  2. trust_host_root_certs: false

 2)新建一个启动的批处理文件 startup.bat

 
  
  1. @echo OFF

  2. color 0b

  3. Title Ngrok启动程序 By 小阿草

  4. Mode con cols=109 lines=30

  5. :START

  6. ECHO.

  7. Echo ==========================================================================

  8. ECHO.

  9. Echo Ngrok启动

  10. ECHO.

  11. Echo 作者: 小阿草

  12. ECHO.

  13. Echo ==========================================================================

  14. Echo.

  15. echo.

  16. echo.

  17. :TUNNEL

  18. Echo 输入需要启动的域名前缀,如“test” 请勿使用“www”,即分配给你的穿透域名为:“test.example.cn”

  19. ECHO.

  20. ECHO.

  21. ECHO.

  22. set /p clientid= 请输入域名前缀:

  23. echo.

  24. set /p port= 请输入内网端口:

  25. echo.

  26. ngrok -config=ngrok.cfg

  27. ngrok -config=ngrok.cfg -log=ngrok.log -subdomain=%clientid% %port%

目录结构:

 双击批处理文件启动客户端。

输入完成后回车。出现下面的界面,则表示成功!

 访问测试

 九、附录

 1. 其他平台编译

 
  
  1. #Linux 平台 32 位系统:GOOS=linux GOARCH=386

  2. #Linux 平台 64 位系统:GOOS=linux GOARCH=amd64

  3. #Windows 平台 32 位系统:GOOS=windows GOARCH=386

  4. #Windows 平台 64 位系统:GOOS=windows GOARCH=amd64

  5. #MAC 平台 32 位系统:GOOS=darwin GOARCH=386

  6. #MAC 平台 64 位系统:GOOS=darwin GOARCH=amd64

  7. #ARM 平台:GOOS=linux GOARCH=arm

 十、其他相关教程

 1. https://segmentfault.com/a/1190000010338848

 2. 10分钟教你搭建自己的ngrok服务器_yjc_1111的专栏-CSDN博客_ngrok服务器搭建

业务搭载离不了云服务器,选择合适的平台最重要!

从目前国内云计算市场的格局来看,国内云计算前三强分别是阿里云、腾讯云和华为云,阿里云、腾讯云作为背靠互联网平台的企业,更偏向于B端用户;华为与作为传统的通信巨头,更偏向于G端。

本人从事云计算相关工作至今已有多年,国内主流的云平台都接触过,包括他们的销售及技术团队,对各家的产品也小有了解,并且指导过数百家企业迁移上云,对云平台选择也有一定的发言权!

网上有很多评测,评测数据也五花八门,说谁好的都有,这个两篇博文分析汇总的非常详细,分享给大家,文档地址:

博文1:云服务器哪家好!阿里云、腾讯云、华为云的服务器配置及价格对比?​

博文2:阿里云服务器突发型t6、n4、s6、c5、c6怎么选?和腾讯云服务器标准型s3、sn3ne、s4、s5、sa2相比哪家好?全面解析

如果是高并发,高IO业务场景,需要确定服务器规格,可让业务应用性能发挥到最佳,参考官方文档:

阿里云服务器规格:规格实例族 - 云服务器 ECS

腾讯云服务器规格:规格实例族 - 云服务器CVM

你可能感兴趣的:(服务器,运维,linux)