刺球网络安全社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 1233|回复: 1

Ngrok搭建服务器(阿里云centos6.8列)

[复制链接]

 成长值: 214049

新浪微博达人勋

  • TA的每日心情

    2017-11-18 23:38
  • 签到天数: 6 天

    [LV.2]偶尔看看I

    1108

    主题

    1681

    帖子

    38万

    积分

    管理员

    技术指数:★★★★★

    Rank: 9Rank: 9Rank: 9

    积分
    385551

    社区QQ达人最佳新人活跃会员热心会员推广达人宣传达人灌水之王突出贡献优秀版主荣誉管理论坛元老

    QQ
    发表于 2017-3-31 17:55:11 | 显示全部楼层 |阅读模式
    *
    * 首先,附上成品,如果实在搭建不成功的,可以使用我的客户端,以解你的燃眉之急!
    *链接:http://pan.baidu.com/s/1nvBKqXN
    *密码:k2qb
    *另外,本屌有个基于centos的一键搭建ngrok的脚本,如有需要可加群向本屌索取*
    *上面是windows64位版本的,现在已经支持32位版本及linux版本和mac版本,
    *需要的请移步:http://ngrok.ciqiuwl.cn下载!
    *


    一、ngrok简介及作用

    ngrok 是一款用go语言开发的开源软件,它是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。下图简述了ngrok的原理。

    ngrok.jpg

    ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放。

    这些看上去很麻烦,我们更需要的是了解ngrok的用途。

    • 完美代替“花生壳”软件。

    “花生壳”是一款老牌的内网穿透软件,一年的内网版服务要两百多块钱,都快可以买一年垃圾点的VPS服务器了。而免费版的“花生壳”稳定性较差,隔三差五的不能访问,每个月只有1G流量,以前做项目没少被坑。ngrok是一款免费开源的软件,稳定性极强,我曾做过测试,将ngrok客户端所在计算机的网络断开一阵子,再连接另一个网络,ngrok很快会自动重连,几乎不受影响。

    • 用于对处在内网环境中,无外网IP的计算机的远程连接。

    ngrok可以做TCP端口转发,对于Linux可以将其映射到22端口进行SSH连接。Windows的远程桌面可以将其映射到3389端口来实现。同理,如果要做MySQL的远程连接,只需映射3306端口即可。

    • 用作临时搭建网站并分配二级域名,可用作微信二次开发的本地调试。

    微信公众平台二次开发时,服务器必须要能通过外网访问,而且必须是80接口。我们一般会在自己的电脑上写代码,但是由于电信运营商将80端口屏蔽了,甚至很多人通过无线路由器上网,根本就没有公网ip。在这种情况下,我们每次都要上传代码到服务器对微信公众平台进行接口调试,十分的不方便。而ngro可以将内网映射到一个公网地址,这样就完美的解决了我们的问题。

    ngrok官方为我们免费提供了一个服务器,我们只需要下载ngrok客户端即可正常使用,但是后来官方的服务越来越慢,直到ngrok官网被完全屏蔽。现在我们已经无法使用ngrok官方的服务器了。所以,接下来我们自行搭建属于自己的ngrok服务器,为自己提供方便快捷又稳定的服务,一劳永逸。

    二、环境准备
    这里以阿里云ECS为例,操作系统为CentOS7(64位)。
    域名
    将一个域名或二级域名泛解析到VPS服务器上。例如将*.xiaomiqiu.cn解析到VPS的IP。要注意,此时还需要将ngrok.xiaomiqiu.cnA记录设置为VPS的IP。
    软件下载地址:
        go的下载地址:http://www.golangtc.com/download
    准备映射的域名:ngrok.xiaomiqiu.cn
    安装git
    1、安装git,我安装的是2.6版本,防止会出现另一个错误,安装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++
    2、下载git
    tar zxvf git-2.6.0.tar.gz
    3、解压git
    tar zxvf git-2.6.0.tar.gz
    4、编译git

            cd git-2.6.0
            ./configure --prefix=/usr/local/git
            make
            make install
    5、创建git的软连接
    ln -s /usr/local/git/bin/* /usr/bin/
    安装go环境
    准备go环境,我的系统是64位的centos所以我下载amd64的包32位的下载386的包即可
    1、下载go的软件包
    wget http://www.golangtc.com/static/go/1.4.2/go1.4.2.linux-386.tar.gz

    2、解压出来可以随便指定位置
    [mw_shl_code=applescript,true]tar -zxvf go1.4.2.linux-amd64.tar.gz
            mv go /usr/local/(*如果此处移动失败 请使用先复制到该目录再删除的方法)[/mw_shl_code]
    3、go的命令需要做软连接到/usr/bin

    ln -s /usr/local/go/bin/* /usr/bin/

    编译ngrok
    cd /usr/local/
    git clone https://github.com/inconshreveable/ngrok.git
    export GOPATH=/usr/local/ngrok/
    export NGROK_DOMAIN="ngrok.xiaomiqiu.cn"(*此处改为你自己的域名即可)
    cd ngrok
    为域名生成证书
    openssl genrsa -out rootCA.key 2048
    openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=$NGROK_DOMAIN" -days 5000 -out rootCA.pem
    openssl genrsa -out server.key 2048
    openssl req -new -key server.key -subj "/CN=$NGROK_DOMAIN" -out server.csr
    openssl x509 -req -in server.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out server.crt -days 5000
    在软件源代码目录下面会生成一些证书文件,我们需要把这些文件拷贝到指定位置
    cp rootCA.pem assets/client/tls/ngrokroot.crt
    cp server.crt assets/server/tls/snakeoil.crt
    cp server.key assets/server/tls/snakeoil.key

    修改代码
    按理来说,跳过这一步直接进行后续的编译工作没有什么问题。但是由于google无法访问,造成编译的时候从code.google.com上自动下载依赖包log4go超时而编译失败。
    所以,我们需要将依赖包的下载地址改为github上的地址
    vim /usr/local/ngrok/src/ngrok/log/logger.go
    将第四行改成下面的
            log "github.com/keepeye/log4go"

    指定编译环境变量,如何确认GOOS和GOARCH,可以通过go env来查看
    编译服务端
    cd /usr/local/go/src
    GOOS=linux GOARCH=amd64 ./make.bash
    cd /usr/local/ngrok/
    GOOS=linux GOARCH=amd64 make release-server
    编译客户端(按自己的客户端选择编译即可)
    适用于mac os 64位操作系统
    cd /usr/local/go/src
    GOOS=darwin GOARCH=amd64 ./make.bash
    cd /usr/local/ngrok/
    GOOS=darwin GOARCH=amd64 make release-client

    适用于Windows的客户端编译
    cd /usr/local/go/src
    GOOS=windows GOARCH=amd64 ./make.bash
    cd /usr/local/ngrok/
    GOOS=windows GOARCH=amd64 make release-client

    客户端配置文件(新建ngrok.cfg,将配置信息粘贴进去就行

    server_addr: "ngrok.xiaomiqiu.cn:4443"
    trust_host_root_certs: false

    服务端启动

    ./usr/local/ngrok/bin/ngrokd -domain="$NGROK_DOMAIN" -httpAddr=":80"

    注意,想让程序一直在后台运行可以执行

    nohup ./usr/local/ngrok/bin/ngrokd -domain="$NGROK_DOMAIN" -httpAddr=":80" &  

    想要结束后台进程可以
    ps -A   #找到PID

    kill xxxid  

    客户端使用
    ./ngrok -config=./ngrok.cfg -subdomain=blog 80
    setsid ./ngrok -config=./ngrok.cfg -subdomain=test 80 #在linux下如果想后台运行

    出现这个错误说明我们需要安装hg
    package code.google.com/p/log4go: exec: "hg": executable file not found in $PATH
    解决办法
    yum install hg -y

    编译到 go get gopkg.in/yaml.v1 的时候卡住不走了,说明是git比较低,版本需要大于1.7.9.5以上
    fatal: Unable to find remote helper for 'https' 出现这个问题,可以重新安装 curl curl-devel 然后再重装git
    安装git-corewget https://www.kernel.org/pub/softw ... re-0.99.6.tar.gztar zxvf git-core-0.99.6.tar.gzcd git-core-0.99.6make prefix=/usr/libexec/git-core installexport PATH=$PATH:/usr/libexec/git-core/

    如果大家有什么疑问可以加入交流群150134730(刺球网络安全社区)进行讨论(里面大牛多多哦)















    楼主热帖
    [发帖际遇]: 刺球 发帖时在路边捡到 4 金球,偷偷放进了口袋. 幸运榜 / 衰神榜
    回复 天涯海角搜一下: 百度 谷歌 360 搜狗 搜搜 有道 谷粉 雅虎 必应 即刻

    使用道具 举报

     成长值: 214049

    新浪微博达人勋

  • TA的每日心情

    2017-11-18 23:38
  • 签到天数: 6 天

    [LV.2]偶尔看看I

    1108

    主题

    1681

    帖子

    38万

    积分

    管理员

    技术指数:★★★★★

    Rank: 9Rank: 9Rank: 9

    积分
    385551

    社区QQ达人最佳新人活跃会员热心会员推广达人宣传达人灌水之王突出贡献优秀版主荣誉管理论坛元老

    QQ
     楼主| 发表于 2017-5-10 21:21:30 | 显示全部楼层
    只编译了windows 64版的客户端,如果有需要其他版本的客户端的可以联系我,我再帮你编译!

    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

    本版积分规则

    
     
     
    技术支持
    点击这里给我发消息
    在线客服
    点击这里给我发消息
    点击这里给我发消息
    刺球网安群①:
    刺球网安社区交流群①
    刺球网安群②:
    刺球网安社区交流群②
    在线时间:
    8:30-21:00
     

    刺球网安 渝公网安备 50011402500080号 ( 渝ICP备15001097号-1 )申请友链|小黑屋| 刺球网络安全社区  

    GMT+8, 2018-2-24 00:06 , Processed in 0.347956 second(s), 53 queries , Gzip On.

    Powered by 刺球网安

    © 2014-2025

    快速回复 返回顶部 返回列表