2018-12-05使用Docker部署Ngrok实现内网穿透

栏目: 编程工具 · 发布时间: 5年前

内容简介:在laradock添加文件夹,建议叫ngrok。文件夹下面存放三个文件。如:目录结构如下图所示:

准备工作

域名解析:

我的在:laradock - nginx - sites - [xxx.conf] 配置域名ngrok.yuling.net 或*.ngrok.yuling.net增加两条A记录解析到你的服务器。这样你可以使用subdomain的方式,来实现穿透。
如:
server {

    listen 80;
    listen [::]:80;

    server_name ngrok.yuling.net *.ngrok.yuling.net;
    root /var/www/yellow-croaker/public;
    index index.php index.html index.htm;

    location / {
         try_files $uri $uri/ /index.php$is_args$args;
    }

    location ~ \.php$ {
        try_files $uri /index.php =404;
        fastcgi_pass php-upstream;
        fastcgi_index index.php;
        fastcgi_buffers 16 16k;
        fastcgi_buffer_size 32k;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        #fixes timeouts
        fastcgi_read_timeout 600;
        include fastcgi_params;
    }

    location ~ /\.ht {
        deny all;
    }

    location /.well-known/acme-challenge/ {
        root /var/www/letsencrypt/;
        log_not_found off;
    }

     error_log /var/log/nginx/apidemo_error.log;
     access_log /var/log/nginx/apidemo_access.log;
}

配置:

在laradock添加文件夹,建议叫ngrok。文件夹下面存放三个文件。

如:

2018-12-05使用 <a href='https://www.codercto.com/topics/20577.html'>Docker</a> 部署Ngrok实现内网穿透

image.png

目录结构如下图所示:

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png

可以看到,有必须的Dockerfile文件,build.sh是编译ngrok的脚本,config.yml是客户端使用的配置文件,下面分别介绍下。

Dockerfile

FROM golang:1.7.1-alpine
ADD build.sh /
RUN apk add --no-cache git make openssl
RUN git clone https://github.com/inconshreveable/ngrok.git --depth=1 /ngrok
RUN sh /build.sh
EXPOSE 8081
VOLUME [ "/ngrok" ]
CMD [ "/ngrok/bin/ngrokd"]

基于golang:1.7.1-alpine这个镜像来构建

build.sh

#!/usr/bin/env bash
export NGROK_DOMAIN="ngrok.yuling.net"
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 device.key 2048
openssl req -new -key device.key -subj "/CN=$NGROK_DOMAIN" -out device.csr
openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 5000
cp rootCA.pem assets/client/tls/ngrokroot.crt
cp device.crt assets/server/tls/snakeoil.crt
cp device.key assets/server/tls/snakeoil.key

make release-server
GOOS=linux GOARCH=386 make release-client
GOOS=linux GOARCH=amd64 make release-client
GOOS=windows GOARCH=386 make release-client
GOOS=windows GOARCH=amd64 make release-client
GOOS=darwin GOARCH=386 make release-client
GOOS=darwin GOARCH=amd64 make release-client
GOOS=linux GOARCH=arm make release-client

注意需要把上面的NGROK_DOMAIN修改为你自己的域名

构建镜像

有了这两个文件之后, cd ngrok 可以执行:

docker build -t ngrok .docker build . -t ngrok 来构建镜像,如下图:

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png

成功状态:

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png

等执行完成之后,可以使用如下命令来启动:

docker run -it  -p 8081:8081 -p 4443:4443 -v /Users/wenyuling/Desktop/Projects/laradock/ngrok/bin:/root/ngrok/bin/ -d ngrok /ngrok/bin/ngrokd -domain="ngrok.yuling.net" -httpAddr=":8081"

同样的,修改上述的 domain 为你自己的域名名同时路径: /Users/wenyuling/Desktop/Projects/laradock 改成自己的本地路径

客户端部分

打开ngrok官网: https://dashboard.ngrok.com/get-started ,选择性登录后如图所示:

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png

按步骤1、2、3、4依次执行,即可。

1、

下载

2、

解压

3、

找到下载的目录,在终端执行: ./ngrok authtoken [你的 token]
我的目录如图所示:

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png

4、

最后执行: ./ngrok http 80

看到如下输出,则说明成功了。

2018-12-05使用Docker部署Ngrok实现内网穿透

image.png


以上所述就是小编给大家介绍的《2018-12-05使用Docker部署Ngrok实现内网穿透》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数学规划

数学规划

黄红选 / 清华大学出版社 / 2006-3 / 45.00元

《数学规划》以数学规划为对象,从理论、算法和计算等方面介绍,分析和求解常见的最优化问题的一些方法,全书共分8章,其中第l章介绍了数学规划的实例、模型以及在分析最优化问题时所涉及的基础知识,第2章至第8章分别讨论了凸分析、线性规划、无约束优化、约束优化、多目标规划、组合优化和整数规划以及全局优化等七个方面的内容,此外,书中每章的最后一节给出了一些习题,书末列出了参考文献和索引。《数学规划》可作为应用......一起来看看 《数学规划》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码