版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
问题现象
1. A服务引用B包的版本 v0.1.1
2.B包进行升级添加了子包httpclient和工具文件env.go,并发布了版本v0.1.2
3.在A服务的go.mod模块将B的引用升级到v0.1.2
4.在A服务依次执行go mod tidy; go mod vendor继续升级,没有错误,提示成功。
5. 进入到vendor的对应目录进行检查,确实出现了工具文件env.go,证明确实引用升级到了最新的版本;但是并没有子包httpclient。
问题原因
目前,我也没找到确切的原因,暂时考虑是缓存的问题。
解决方案
当然,没找到原因,并没意味着问题就不能解决,毕竟解决问题才是王道。解决方案如下:
1. 直接在go.mod中删掉原来版本的引用,而不是进行版本的更新
gitlab.*****.me/****/****-lib v0.1.4
2.紧接着执行go mod vendor。这一步的目的是清除掉vendor中老版本的****-lib的包。
但是,如果在Goand进行执行的话,go.mod会自动检测到代码对****-lib的引用,所以执行go mod vendor就会进行删除旧的并引用新的,执行输出如下:
➜ *** git:(master) ✗ go mod vendor
go: finding module for package gitlab.***.me/***/***-lib/sign
go: finding module for package gitlab.***.me/***/***-lib/common
go: finding module for package gitlab.***.me/***/***-lib/httpclient
Enter passphrase for key '/Users/****/.ssh/id_rsa':
go: found gitlab.***.me/***/***-lib/common in
gitlab.***.me/***/***-lib v0.1.4
go: found gitlab.***.me/***/***-lib/httpclient in
gitlab.***.me/***/***-lib v0.1.4
go: found gitlab.***.me/***/***-lib/sign in
gitlab.***.me/***/***-lib v0.1.4