GoModule来了,企业私有代理你准备好了吗_

本文字数:1015 字

精读时间:5 分钟

也可在 3 分钟内完成速读

随着 go module 的不断普及,通常情况下,我们可以直接使用 goproxy.io 公共服务来解决海外依赖问题,但是有时候公司内部的仓库就很难办了,这些 git server 通常运行在企业内网环境下,开发人员既想能快速的下载海外依赖,又想能下载到公司内部的代码库。这时候可以在公司内部部署一个属于自己的 goproxy.io 服务来解决这个问题。还有哪些场景需要我们自己部署公司内部的 goproxy server 呢?

访问公司内网的 git server防止公网仓库变更或者消失,导致线上编译失败或者紧急回退失败公司审计和安全需要防止公司内部开发人员配置不当造成 import path 泄露cache 热点依赖,降低公司公网出口带宽

编译

确保要运行的服务器是已经安装了 go 命令,goproxy 项目是开源的,用 go 语言开发,使用 go modules 可以很方便的进行编译:

git clone https://github.com/goproxyio/goproxy.gitcd goproxymake

服务运行模式

编译好的文件位置是 ./bin/goproxy , 使用 ./bin/goproxy -h 查看参数使用说明:

Usage of ./bin/goproxy:-cacheDir stringgo modules cache dir[指定 Go 模块的缓存目录]-exclude stringexclude host pattern[proxy 模式下指定哪些 path 不经过上游服务器]-listen stringservice listen address [服务监听端口,默认 8081]-proxy stringnext hop proxy for go modules [指定上游 proxy server,推荐 goproxy.io]

Proxy Mode

如果服务没有访问海外资源的需求,只访问公司内部资源可以不指定上游服务器,启动服务:

./bin/goproxy -listen=0.0.0.0:80 -cacheDir=/tmp/test

Router Mode

direct+----------------------------------> private repo| match|pattern|+---+---+ +----------+go get+-------> |goproxy| +-------> |goproxy.io| +---> golang.org/x/net+-------+ +----------+ router mode proxy mode

使用 -proxy 参数启用 Router mode, Router 模式下你将可以配置哪些仓库从海外获取,哪些仓库从公司内部获取, 启动服务命令如下:

./bin/goproxy -listen=0.0.0.0:80 -cacheDir=/tmp/test -proxy-exclude "git.corp.example.com,rsc.io/private"

使用 docker 运行服务

如果上面这些你感觉非常麻烦,可以直接用 docker hub 上编译好的镜像来运行这个服务:

docker run -d -p80:8081 goproxy/goproxy

这样服务就运行在本地的 80 端口服务上了。

测试

在本地开发机上,通过环境变量将 proxy server 指定到你刚部署的服务器:

Mac 和 Linux 用户:

export GO111MODULE=onexport GOPROXY=http://[你的服务器IP]:80

如果是 windows 用户:

$env:GO111MODULE="on"$env:GOPROXY="http://[你的服务器IP]:80"

接着运行下面命令,查看是否成功,观察服务器日志输出是否正常。

go get github.com/pkg/errors

最后再给自己的服务绑定个域名就大功告成了。有任何问题和bug,欢迎点击这里进行反馈。

点击“阅读原文”, 进入 goproxy 项目地址。

欢迎联系 GoCN

国内最具规模和生命力的 Go 开发者社区

演讲

成为 Gopher Meetup /Gopher China 讲师

投稿

展示个人/团队原创技术

内容

聪明又努力的 Gophers,让我知道你“在看”