文章目录

  • 前言
  • docker镜像介绍
    • 使用
  • 编译配置介绍
    • 没有证书
    • 有自己域名证书
    • 注意
    • 关键编译脚本
    • 编译结果
  • 比较有参考性的文章

前言

  1. ngrok是golang编写的开源内网穿透工具,1.x是开源 2.x是闭源,目前免费的服务器也没有几个。
  2. ngork的主要配置在于公网服务器的域名。但是由于遍以后的客户端和服务端将ca文件生成在了代码中一起打包编译,所有修改域名和ca文件都需要重新编译。
  3. 恰逢双十一买了服务器和域名,有使用需求遍把编译环境制作成docker环境,使用docker交叉编译快速获得可执行的客户端和服务端。

docker镜像介绍

组件 版本 备注
golang 1.16.10 编译ngrok需要1.16及以上版本
alpine 3.13 3.14有问题,目前可用最新的版本,提供git version 2.30.2
openssl OpenSSL 1.1.1 用于生成ca证书
ngrok 1.7 fork ngrok代码挂载docker镜像减少

ngrok fork代码 实在推送不上去了,dockerfile如下:

FROM golang:1.16.10-alpine3.13
RUN apk add --no-cache git make openssl
ADD . /ngrok
WORKDIR /ngrok
ENV GOPATH=/ngrok
ENV PATH=$PATH:$GOPATH/bin
ENV PATH=$PATH:$GOPATH/bin
RUN go env -w GOPROXY=https://goproxy.cn,direct
RUN go env -w GOSUMDB=off
RUN go env -w GO111MODULE=auto
CMD ["sh","-c","go version && openssl version"]

使用

# 使用进行运行命令
docker run --rm marsbug/go-ngrok-alpine:latest sh -c 'go version && openssl version && git version'
# 输出版本如下
go version go1.16.10 linux/amd64
OpenSSL 1.1.1l  24 Aug 2021
git version 2.30.2

编译配置介绍

配置 事例 作用
NGROK_DOMAIN “xxxx.com” 公网ip的域名,此域名如果错误会导致ca证书无法通过,这里最好同部修改dns添加对应域名解析记录
USE_CUSTMER_CA 0表示不使用 1表示使用 公网ip的域名,此域名如果错误会导致ca证书无法通过

ngrok镜像使用例子
目录结构

bin/     编译的客户端和服务端目录
ca/      证书挂载目录
build.sh 交叉编译脚本
script.sh 交叉编译例子

没有证书

# USE_CUSTMER_CA = 0
# NGROK_DOMAIN = 签发证书的域名./script.sh NGROK_DOMAIN USE_CUSTMER_CA

有自己域名证书

# USE_CUSTMER_CA = 1 替换ca目录下的三个文件
cp yourrootCA.key ca/rootCA.key
cp yourrootCA.pem ca/rootCA.pem
cp yourdevice.crt ca/device.crt
# NGROK_DOMAIN = 签发证书的域名./script.sh NGROK_DOMAIN USE_CUSTMER_CA

注意

主域名dns要解析道服务端,否则客户端将出现 nuknow host
*主域名dns要和ca证书域名一致,否则客户端将出现 *
每次主域名修改需要修改证书
每次证书修改需要重新编译

关键编译脚本

脚本主要使用挂载目录进行交叉编译,如果存在自己的ca证书,则不会创建ca证书。如果想要生成ca证书,需要删除ca目录文件夹重新执行。
script.sh

# $1 自定义域名 $2 是否使用自己的ca(0是 1不是)
docker run --rm  \
-v "$PWD"/ca:/ngrok/ca  \
-v "$PWD"/bin:/ngrok/bin \
--env NGROK_DOMAIN=$1  \
--env USE_CUSTMER_CA=$2  \
marsbug/go-ngrok-alpine:latest sh -c  \
'echo "--------------------- 公网 NGROK_DOMAIN : $NGROK_DOMAIN  ---------------------" \
&& if [ $USE_CUSTMER_CA == 1 ];then \
echo "--------------------- 使用自己证书 ... 生成中 ---------------------" \
&& if [ ! -e ca/rootCA.key ]; then
echo "--------------------- rootCA.key不存在,生成中 ---------------------" \
&& openssl genrsa -out ca/rootCA.key 2048; fi  \
&& if [ ! -e ca/rootCA.pem ]; then \
echo "--------------------- rootCA.pem不存在,生成中 ---------------------" \
&& openssl req -x509 -new -nodes -key ca/rootCA.key -subj "/CN=$NGROK_DOMAIN" -days 5000 -out ca/rootCA.pem; fi  \
&& if [ ! -e ca/device.key ]; then  \
echo "--------------------- device.key不存在,生成中 ---------------------" \
&& openssl genrsa -out ca/device.key 2048; fi  \
&& if [ ! -e ca/device.crt ]; then \
echo "--------------------- device.crt不存在,生成中 ---------------------" \
&& openssl req -new -key ca/device.key -subj "/CN=$NGROK_DOMAIN" -out ca/device.csr; fi  \
&& if [ ! -e ca/device.crt ]; then  openssl x509 -req -in ca/device.csr -CA ca/rootCA.pem -CAkey ca/rootCA.key -CAcreateserial -out ca/device.crt -days 5000; fi \
&& echo "--------------------- 证书生成完毕 ... 替换旧证书 ---------------------" \
&& cp ca/rootCA.pem assets/client/tls/ngrokroot.crt \
&& cp ca/device.crt assets/server/tls/snakeoil.crt \
&& cp ca/device.key assets/server/tls/snakeoil.key; fi \
&& echo "--------------------- $NGROK_DOMAIN证书就绪 ...编译中 ---------------------" \
&& make release-server \
&& make release-client \
&& CGO_ENABLED=0 GOOS=linux GOARCH=arm make release-client  \
&& CGO_ENABLED=0 GOOS=linux GOARCH=amd64 make release-client \
&& CGO_ENABLED=0 GOOS=windows GOARCH=amd64 make release-client \
&& CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 make release-client \
&& echo "--------------------- 编译完成 ---------------------" '

编译结果

bin/ngrokd 为服务端
bin/*/ngrok 各个平台下的客户端

比较有参考性的文章

https://www.xiaomiqiu.com/article/7

ngrok私有服务搭建(docker交叉编译)相关推荐

  1. 搭建 NPM 私有服务搭建入坑记

    前两天刚写完如何基于 CNPM 搭建一个私有服务,然后搭建到了线上正式服务器上,结果今天就栽坑里了.具体坑如下. 一.服务器磁盘空间被爆满 笔者搭建了两私有服务,一套在测试机器,一套在线上机器,然而自 ...

  2. 微服架构基础设施环境平台搭建 -(二)Docker私有仓库Harbor服务搭建

    微服架构基础设施环境平台搭建 -(二)Docker私有仓库Harbor服务搭建 通过采用微服相关架构构建一套以Kubernetes+Docker为自动化运维基础平台,以微服务为服务中心,在此基础之上构 ...

  3. 搭建docker私有仓库 配置用户名密码

    文章目录 1.系统配置 2.搭建服务端 3.配置Windows客户端 4.配置centos客户端 5.查看效果 6.注意点 1.系统配置 服务端:centos 7 客户端:Windows 10 2.搭 ...

  4. WMware Harbor 开源 Docker 私有库搭建

    WMware Harbor 开源 Docker 私有库搭建 Harbor简介 Harbor 的主要功能 基于角色的访问控制 基于镜像的复制策略 图形化用户界面 支持 AD/LDAP 镜像删除和垃圾回收 ...

  5. 搭建Docker本地私有镜像仓库

    在使用Docker service create创建容器时,Docker首先默认从Docker Hub官方去下载镜像,这很不方便,很多时候我们的镜像都是使用Dockerfile自定义私有镜像,不对外公 ...

  6. 基于 registry 搭建 Docker 私有镜像仓库

    dockerhub: https://registry.hub.docker.com/_/registry 安装命令 docker run -p 5000:5000 -d -v /opt/regist ...

  7. Nexus 搭建docker本地仓库(hosted)和私有仓库(proxy)

    本文主要参考"使用 Nexus 搭建 Docker 仓库",在安装过程中遇到一些问题,本文中一并总结.在此对原作者表示感谢! 环境说明: Centos 7.4 OpenJDK 8 ...

  8. 群晖nas中使用registry搭建docker镜像私人服务器以及设置群晖远程docker服务

    群晖nas中使用registry搭建docker镜像私人服务器以及设置群晖远程docker服务 折腾群晖服务器很有快感,一是因为自家群晖ds216+低功耗,24小时开机也不觉得费电,二是因为群晖系统也 ...

  9. 搭建Docker私有镜像仓库

    一.Docker镜像和容器的区别 Docker的整个生命周期由三部分组成:镜像(image)+容器(container)+仓库(repository) 容器等于镜像加上可读层,容器是由镜像实例化而来的 ...

最新文章

  1. [每日一题] OCP1z0-047 :2013-08-14 如何理解USING INDEX?...................................41
  2. Ansible PLaybook template 模板详解
  3. Kubernetes二进制集群部署+Web管理界面+kubectl 命令管理+YAML文件详解(集合)
  4. const constexpr C++ 解释
  5. php下载当前页面,php实现当前页面点击下载文件的简单方法
  6. httpclient 不支持国密ssl_Hyperledger Fabric成都见面会:TWGC国密改造介绍
  7. 前端调数据会经常用到的事件处理
  8. 简单计算器 -python
  9. iOS DLNA
  10. 平时碰到系统CPU飙高和频繁GC,你会怎么排查?
  11. python中import和from...import...有关头文件的使用方法及工作原理
  12. CSR8670 — 说说什么是ANC、CVC、DSP降噪
  13. 微信 打开html文件,微信文件在电脑上打开文件
  14. 鼠标滑轮成了页面缩放的解决方法
  15. c++/c memcpy函数用法(拷贝数组的内容)
  16. ssm基于微信小程序的电影影评交流平台系统 uni-app
  17. 季节前面为什么用in_季节前面用in还是on
  18. 强化网络互连设备安全配置脚本
  19. 数字图像处理实验——图片压缩与解压(opencv)
  20. 序列化Serializable、Parcelable

热门文章

  1. 在windows上部署IIS web服务
  2. 《数据库系统概论》:DBA的职责有些
  3. IDEA 安装快捷键提示工具:Key promoter X
  4. Java—String类的intern方法的学习
  5. 解决webSocket中使用@Autowired注入为空的办法
  6. python条形图和线形图的绘制,并显示数据
  7. 对比了论坛,博客和微博
  8. linux虚拟机和电脑ping通(可上网)
  9. 页面返回 上一页 下一页
  10. storyboard 苹果启动图_iOS 13使用LaunchScreen.storyboard适配各尺寸启动图