目录1. Go的依赖管理发展2. go.mod 文件分析3. go mod依赖下载工具4. 可能出现的问题汇总1. go的依赖管理发展 GOPATH 所有的依赖都放置在同一路径下,
module xx/xx/xx/v2
go 1.16
require (
xx/xx/xx v1.3.3
xx/xx/xx v0.0.0-20200330080233-e4ea8bd1cbed
xx/xx/xx v2.2.1+incompatible
xx/xx/xx v0.3.0 // indirect
)
exclude (
xx/xx/xx v1.3.3-rc.0
)
replace xx/xx/xx => xx/xx v1.3.3
retract (
v1.0.0 // 废弃的版本,请使用v1.1.0
)
module xx/xx/xx/v2
是指该项目的module路径,/v2
是指版本信息,可以省略。
go 1.16
是指项目需要的最低go的版本
require()是项目需要的其他依赖:
xx/xx/xx v1.3.3
指明了项目需要的依赖以及版本号。xx/xx/xx v0.0.0-20200330080233-e4ea8bd1cbed
是时间戳性质的版本号。xx/xx/xx v0.3.0 // indirect
是指依赖需要的依赖xx/xx/xx v2.2.1+incompatible
是指依赖的库的major版本大于引用的版本,不合规范。exclude()
指引用依赖时,跳过某些版本
replace xx/xx/xx => xx/xx v1.3.3
指替换某些依赖
retract()
声明废弃的版本
go get xx/xx/x@${parameter}
${parameter}可以选择的参数如下:
go mod tidy 根据go.mod文件添加或者删除项目所需要的依赖
go get -u xx/xx/x
这个操作会升级依赖的依赖,有可能会引发依赖版本不兼容问题导致的编译不通过,比如thrift的0.13与0.14不兼容。
循环依赖问题:
要注意避免循环依赖问题。
到此这篇关于一文详解go mod依赖管理详情的文章就介绍到这了,更多相关go mod依赖管理内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 一文详解gomod依赖管理详情
本文链接: https://lsjlt.com/news/121013.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0