golang独立模块开发流程
大纲
- 基本概念与背景
- 模块开发流程总结
- 基于gitee私库
- 基于gitlab私库
基本概念与背景
java项目开发过程中,有不同的项目组,有的项目组做业务开发,有的项目组做公共jar包的开发等。业务项目需要依赖公共jar包的时候,我们都使用nexus等maven私库+maven构建项目
golang也类似,这里的公共jar包就是golang中的公共模块,maven 变成了go get nexus变成了自己搭建的gitlab 或者 github gitee等
模块开发流程总结
golang 中引入模块的方式是 import
import (
"gitee.com/liuyijiang/gopjutils"
)
如果是私库则会对应自己的私库域名例如:
- gitee.com
- git.domain.com[这是一个Gitlab的域名]
所以在构建自己的模块前,我们需要先搞定私库
注意本次测试 golang版本为1.19
注意本次测试 golang版本为1.19
基于gitee私库
step1 创建项目
在创建golang 模块项目前,首先构思好模块的名称,因为这对应gitee(github gitlab)上的路径。模块名称需要和仓库路径一致否则go get的时候会出现如下错误
module declares its path as: ×××
but was required as: ×××
先gitee上创建一个项目
然后clone项目并初始化
git clone https://gitee.com/liuyijiang/commoncode.git
go mod init gitee.com/liuyijiang/commoncode
注意: mod的名称一定要是gitee上项目的地址路径!注意不要有.git
简单的编写一些模块代码
git commit push 后模块就可以在其他项目中使用了
step2 在机器上创建ssh公钥
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
go get 是使用https获取仓库的go模块代码,(但是Go更新依赖时,会强制校验CA证书来确保依赖库的安全性) 我们自己的仓库一般是内网环境所以并未配置https证书 并且如果直接GOINSECURE忽略校验CA证书又需要账号密码不方便, 所以需要使用ssh的方式拉取go模块代码
这里以gitee为例子(使用gitee作为私库是不需要配置ssh 因为gitee是支持https证书验证) 后面会有gitlab的例子
step2.1 先创建ssh公钥
使用ssh-keygen命令生成公私钥
ssh-keygen -t ed25519 -C "liuyijiang3430@qq.com"
step2.2 把公钥添加到gitee
把上一步得到的公钥内容复制到gitee
cat ~/.ssh/id_ed25519.pub
测试连通
对从https://gitee.com拉取代码的请求的替换为ssh
如果项目是使用Jenkins等自动化发布平台的话,需要把id_ed25519.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitee
step3 go env 配置私库
注意:必须要配置私库 域名地址 否则 go get无法拉取到模块代码
例如使用 go get gitee.com/liuyijiang/commoncode 再未配置私库的情况下无法找到对应的模块
使用如下命令添加私库
go env -w GOPRIVATE=gitee.com
go env -w GOPRIVATE=gitee.com,xxxx.com #配置多个私库
添加完成后可以看到
再次 go get gitee.com/liuyijiang/commoncode 可以成功添加模块
gopath 下也可以看到拉取的模块代码了
step4 测试使用公共模块
现在可以使用import导入公共包,并开发了
测试成功
基于gitlab私库
更多的场景是公司自己部署gitlab私库 来保存代码,并且自己搭建的gitlab不支持https
step1 创建项目
先gitlab上创建一个项目 注意自己搭建的gitlab不是https的
然后clone项目并初始化
git clone http://git.kfc123.com/liuyijiang/gocode.git
go mod init git.kfc123.com/liuyijiang/gocode
注意: mod的名称一定要是git.kfc123.com上项目的地址路径!注意不要有.git
go mod init git.kfc123.com/liuyijiang/gocode
简单的编写一些模块代码
git commit push 后模块就可以在其他项目中使用了
step2 在机器上创建ssh公钥
注意: 由于gitlab服务不支持https 并且我们更多的时候会频繁的go get 模块不想配置账号密码 所以这一步需要使用ssh方式拉取代码
go get 是使用https获取仓库的go模块代码(底层还是git命令),(但是Go更新依赖时,会强制校验CA证书来确保依赖库的安全性) 我们自己的仓库一般是内网环境所以并未配置https证书 并且如果直接GOINSECURE忽略校验CA证书又需要账号密码不方便, 所以需要使用ssh的方式拉取go模块代码
注意 一般自己搭建的gitlab 会有一个nginx做反向代理,这里需要配置nginx的tcp 反向代码支持ssh
这里nginx 服务器上9922对应gitlab的 ssh端口 nginx默认是没有安装tcp 反向代理的需要使用 –with-stream模块开启
step2.1 先创建ssh公钥
使用ssh-keygen命令生成公私钥 注意使用自己的邮箱
$ ssh-keygen -t rsa -C "liuyijiang3430@qq.com"
step2.2 把公钥添加到gitlab
把上一步得到的公钥内容复制到gitlab
cat ~/.ssh/id_rsa.pub
step2.3 配置本地ssh使用端口与公钥
需要配置一下ssh使用的端口 否则会有以下错误
在 ~/.ssh 文件夹下创建config文件 (注意config文件没有后缀名) 添加如下内容
测试连通 ssh -T git@git.kfc123.com
如果项目是使用Jenkins等自动化发布平台的话,需要把id_rsa.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitlab**
step2.4 配置http 替换为 ssh
对从http://git.kfc123.com拉取代码的请求的替换为ssh
git config --global url."git@git.kfc123.com:".insteadOf "http://git.kfc123.com/"
所有以 http://git.kfc123.com/ 开头的url 都替换为 git@git.kfc123.com:
例如
http://git.kfc123.com/liuyijiang/gocode
会被替换为
git@git.kfc123.com:liuyijiang/gocode
step2.5 关闭私库校验CA证书
如果私有库不支持https协议,会报如下的错误。这是因为Go更新依赖时,会强制校验CA证书来确保依赖库的安全性。
如果私有库不支持https协议,还需要配置go 环境变量中的GOINSECURE参数使其使用http方式访问
go env -w GOINSECURE=git.kfc123.com
go env -w GOINSECURE=git.kfc123.com,xxx.com #配置多个http访问域名
以上配置完成后go get整体流程是
输入go get git.kfc123.com/liuyijiang/gocode
1 先发出https请求
2 https失败后切换为http
3 由于配置了替换 http请求变成了ssh
使用 go get -v -x git.kfc123.com/liuyijiang/gocode 可以看到详细的执行流程
step3 go env 配置私库
注意:必须要配置私库 域名地址 否则 go get无法拉取到模块代码
go env -w GOPRIVATE=gitee.com,git.kfc123.com #配置多个私库
使用 go get git.kfc123.com/liuyijiang/gocode 获取go模块
成功拉取代码
step4 测试使用公共模块
现在可以使用import导入公共包,并开发了
测试成功