Golang

关注公众号 jb51net

关闭
首页 > 脚本专栏 > Golang > go.mod与go.sum区别

一文详解go.mod与go.sum有什么区别

作者:ghostwritten

流行的现代编程语言一般都提供依赖库管理工具,如Java的Maven 、Python的PIP、Node.js的NPM和Rust的Cargo等,Go最为一门新生代语言,自然也有其自己的库管理方式,这篇文章主要介绍了go.mod与go.sum有什么区别的相关资料,需要的朋友可以参考下

前言

这是 Go 模块机制里最基础、也最容易被误解的一组文件

我用 一句话 + 对照表 + 实际场景,把 go.modgo.sum 讲透。

一句话先记住

go.mod 负责“声明我要用什么”
go.sum 负责“证明我用的就是它”

go.mod 是什么?

go.mod模块的“需求说明书”

它告诉 Go 工具链三件事:

  1. 这个项目是谁
  2. 依赖哪些模块
  3. 用哪些版本规则

示例 go.mod

module github.com/example/myapp

go 1.22

require (
    github.com/gin-gonic/gin v1.9.1
    go.uber.org/zap v1.27.0
)

go.mod 的核心作用

作用说明
模块名module 路径
Go 版本编译语义
直接依赖require
替换规则replace
版本收敛indirect

📌 go.mod 决定“依赖关系图”

go.sum 是什么?

go.sum依赖完整性的“校验账本”

它记录的是:

某个模块的某个版本,对应的内容哈希

示例 go.sum

github.com/gin-gonic/gin v1.9.1 h1:abcd...
github.com/gin-gonic/gin v1.9.1/go.mod h1:efgh...

go.sum 的核心作用

作用说明
校验完整性防止依赖被篡改
可复现构建每个人拉到的内容一致
安全防供应链攻击

📌 go.sum 决定“内容是不是同一个”

二者的本质区别(重点)

对比点go.modgo.sum
关注点依赖关系依赖内容
是否声明依赖
是否参与校验
是否可手写可以不建议
是否必须提交

一个真实的工作流(非常重要)

写代码 / 加依赖

go get github.com/gin-gonic/gin

👉 Go 会自动:

构建 / CI

go build

Go 会:

  1. go.mod 决定要拉哪些模块
  2. go.sum 校验模块内容
  3. 校验失败 → 直接报错

为什么不能删 go.sum?

很多人问:

“我能不能删 go.sum,让它重新生成?”

生产项目不应该这么做

原因:

常见误区(你可能踩过)

误区 1:只提交 go.mod

构建成功(我机器)
CI 失败(别人机器)

👉 因为 依赖内容不一致

误区 2:手改 go.sum

go.sum 是 机器生成文件

你手改它 ≈ 手改校验和,毫无意义

误区 3:go.sum 里有没用到的依赖

这是 正常现象

一个非常形象的类比(最好记)

文件类比
go.mod购物清单
go.sum收据 + 防伪码

在你这种工程场景里的实际建议

结合你做 Kubernetes / 平台 / Operator / Helm 的背景:

一句工程师级总结

go.mod 解决“依赖关系”问题
go.sum 解决“依赖可信与可复现”问题

到此这篇关于一文详解go.mod与go.sum有什么区别的文章就介绍到这了,更多相关go.mod与go.sum区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文