最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题

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上创建一个项目

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第1张图片

然后clone项目并初始化

git clone https://gitee.com/liuyijiang/commoncode.git
go mod init gitee.com/liuyijiang/commoncode

注意: mod的名称一定要是gitee上项目的地址路径!注意不要有.git

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第2张图片

简单的编写一些模块代码

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第3张图片

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 "[email protected]"

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第4张图片

step2.2 把公钥添加到gitee

把上一步得到的公钥内容复制到gitee

cat ~/.ssh/id_ed25519.pub

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第5张图片

测试连通

在这里插入图片描述

对从https://gitee.com拉取代码的请求的替换为ssh

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第6张图片

如果项目是使用Jenkins等自动化发布平台的话,需要把id_ed25519.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitee

step3 go env 配置私库

注意:必须要配置私库 域名地址 否则 go get无法拉取到模块代码

例如使用 go get gitee.com/liuyijiang/commoncode 再未配置私库的情况下无法找到对应的模块

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第7张图片

使用如下命令添加私库

go env -w GOPRIVATE=gitee.com
go env -w GOPRIVATE=gitee.com,xxxx.com #配置多个私库

添加完成后可以看到

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第8张图片

再次 go get gitee.com/liuyijiang/commoncode 可以成功添加模块

在这里插入图片描述

gopath 下也可以看到拉取的模块代码了

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第9张图片

step4 测试使用公共模块

现在可以使用import导入公共包,并开发了
最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第10张图片

测试成功

基于gitlab私库

更多的场景是公司自己部署gitlab私库 来保存代码,并且自己搭建的gitlab不支持https

step1 创建项目

先gitlab上创建一个项目 注意自己搭建的gitlab不是https的

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第11张图片

然后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

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第12张图片

简单的编写一些模块代码

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第13张图片

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

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第14张图片

这里nginx 服务器上9922对应gitlab的 ssh端口 nginx默认是没有安装tcp 反向代理的需要使用 --with-stream模块开启

step2.1 先创建ssh公钥

使用ssh-keygen命令生成公私钥 注意使用自己的邮箱

$ ssh-keygen -t rsa -C  "[email protected]"

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第15张图片

step2.2 把公钥添加到gitlab

把上一步得到的公钥内容复制到gitlab

cat ~/.ssh/id_rsa.pub

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第16张图片

step2.3 配置本地ssh使用端口与公钥

需要配置一下ssh使用的端口 否则会有以下错误
最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第17张图片

在 ~/.ssh 文件夹下创建config文件 (注意config文件没有后缀名) 添加如下内容

在这里插入图片描述

测试连通 ssh -T [email protected]

在这里插入图片描述

如果项目是使用Jenkins等自动化发布平台的话,需要把id_rsa.pub复制到Jenkins的服务器上,或者在Jenkins服务器上在生成一个公钥添加到gitlab**

step2.4 配置http 替换为 ssh

对从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

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第18张图片

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访问域名

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第19张图片

以上配置完成后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导入公共包,并开发了

最详细的golang + 私库(gitlab gitee) 模块开发 这一篇文章解决所有问题_第20张图片

测试成功

你可能感兴趣的:(golang,gitee,golang,gitlab,linux,nginx)