前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Golang】项目go mod的改造

【Golang】项目go mod的改造

作者头像
runzhliu
发布2021-05-27 11:28:58
1.1K0
发布2021-05-27 11:28:58
举报
文章被收录于专栏:容器计算

最近在整理组里的旧项目的时候,发现原来一些不太标准的操作,举个例子。最下面是一个叫 A 项目的 go.mod,两个 common 模块是需要指向本地的文件夹中的,这就意味着,换了其他环节编译这个 A 项目的时候,你必须在上层文件夹目录提前下载好两个 common 项目,这就不太标准了,比较好的做法就是直接将依赖指向内部仓库的这两个 common 项目。

在这里插入图片描述
在这里插入图片描述

查看一下原因,原来这两个 common 项目的 module path 竟然是一个不存在的仓库名,因此以前老做法是把这两个 common 包 git clone 下来到 A 项目的父目录,然后通过 go.mod 的 replace 重新指向的。

关于 module path 是啥,其实就是 go.mod 文件的第一行,如果项目是通过 go mod init 创建的,可以看看 Go 的官方文档,指个路。

在这里插入图片描述
在这里插入图片描述

当然了,一些历史原因,以及这两个既然叫做 common,那么修改 module path 是有风险的,万一忘记修改依赖 common 的其他项目的 go.mod,那么就会编译失败了。

所以这里要做一些 trick,去改造一下,首先把 common 包的 module path 改成内部仓库的地址,然后修改 A 项目的 go.mod 文件,把 replace 部分去掉,然后将 require 部分重新写成 common 的内部仓库地址即可。

通过上面的改造,下次编译 A 项目的时候,就会去远程仓库下载对应版本的 common 依赖了,否则不管是编译还是构建镜像,这都会很麻烦。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/03/14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档