大纲
java项目开发过程中,有不同的项目组,有的项目组做业务开发,有的项目组做公共jar包的开发等。业务项目需要依赖公共jar包的时候,我们都使用nexus等maven私库+maven构建项目
golang也类似,这里的公共jar包就是golang中的公共模块,maven 变成了go get nexus变成了自己搭建的gitlab 或者 github gitee等
golang 中引入模块的方式是 import
import (
"gitee.com/liuyijiang/gopjutils"
)
如果是私库则会对应自己的私库域名例如:
所以在构建自己的模块前,我们需要先搞定私库
注意本次测试 golang版本为1.19
注意本次测试 golang版本为1.19
在创建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 后模块就可以在其他项目中使用了
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
注意: 如果使用gitee作为私库这一步不是必须的 可直接到step3
go get 是使用https获取仓库的go模块代码,(但是Go更新依赖时,会强制校验CA证书来确保依赖库的安全性) 我们自己的仓库一般是内网环境所以并未配置https证书 并且如果直接GOINSECURE忽略校验CA证书又需要账号密码不方便, 所以需要使用ssh的方式拉取go模块代码
这里以gitee为例子(使用gitee作为私库是不需要配置ssh 因为gitee是支持https证书验证) 后面会有gitlab的例子
使用ssh-keygen命令生成公私钥
ssh-keygen -t ed25519 -C "[email protected]"
把上一步得到的公钥内容复制到gitee
cat ~/.ssh/id_ed25519.pub
测试连通
对从https://gitee.com拉取代码的请求的替换为ssh
如果项目是使用Jenkins等自动化发布平台的话,需要把id_ed25519.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitee
注意:必须要配置私库 域名地址 否则 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 下也可以看到拉取的模块代码了
测试成功
更多的场景是公司自己部署gitlab私库 来保存代码,并且自己搭建的gitlab不支持https
先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 后模块就可以在其他项目中使用了
注意: 由于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模块开启
使用ssh-keygen命令生成公私钥 注意使用自己的邮箱
$ ssh-keygen -t rsa -C "[email protected]"
把上一步得到的公钥内容复制到gitlab
cat ~/.ssh/id_rsa.pub
在 ~/.ssh 文件夹下创建config文件 (注意config文件没有后缀名) 添加如下内容
测试连通 ssh -T [email protected]
如果项目是使用Jenkins等自动化发布平台的话,需要把id_rsa.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitlab**
对从http://git.kfc123.com拉取代码的请求的替换为ssh
git config --global url."[email protected]:".insteadOf "http://git.kfc123.com/"
所有以 http://git.kfc123.com/ 开头的url 都替换为 [email protected]:
例如
http://git.kfc123.com/liuyijiang/gocode
会被替换为
[email protected]:liuyijiang/gocode
如果私有库不支持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 可以看到详细的执行流程
注意:必须要配置私库 域名地址 否则 go get无法拉取到模块代码
go env -w GOPRIVATE=gitee.com,git.kfc123.com #配置多个私库
使用 go get git.kfc123.com/liuyijiang/gocode 获取go模块
成功拉取代码
现在可以使用import导入公共包,并开发了
测试成功