我有 golang aws lambda 项目。我使用 terraform 脚本将其部署在 github actinos 上。 我有这样的情况: 构建#1
-rwxr-xr-x 1 runner docker 14717304 jan 1 2022 atest
-rw-r--r-- 1 runner docker 7776780 jan 1 2022 atest.zip
我在某个文件中做了 1 处更改,该更改甚至未在任何其他文件中导入,并且 构建#2
-rwxr-xr-x 1 runner docker 14717304 jan 1 2022 atest
-rw-r--r-- 1 runner docker 7776755 jan 1 2022 atest.zip
zip 大小已更改,但二进制文件未更改
这是我的 makefile 的重要部分
build: ## Build Linux binary with path consistent with passed functionction layere (layer) and functionction name (function)
build: resolve-env
@$(BUILD_FLAGS) ${GOCMD} build ${LDFLAGS} -o ${BINARY_PATH} ${GO_PKG}
@touch -t 202201010000.00 ${BINARY_PATH}
.PHONY: package
package: build
@cd ${DST} && ${ZIPCMD} -X -q --latest-time ${ABS_ZIP_PATH} ${function}
@touch -t 202201010000.00 ${ABS_ZIP_PATH}
当我在本地进行相同的更改,并使用 terraform 或名为“act”的工具运行构建时,没有这样的更改..仅在 github actions 上。 我需要保持相同的大小,这会影响 sha256sum (以避免部署每个 lambda )。 可能是什么原因?
正确答案
这个答案重点关注 go 二进制文件的可重复构建。
虽然它显示 go 二进制文件具有相同的大小,但我怀疑内容是否不同。请首先检查二进制文件的哈希值以确认这一点。
要获得可重现的构建,除了其他明显的要求之外,您还需要:
- 确保 cgo 构建可重现(工具链、依赖项等),或禁用 cgo。您已经设置了
CGO_ENABLED=0
(此信息由另一个已删除的问题提供)。 - 使用
-trimpath
标志。也许 GitHub 操作总是将源代码放在同一目录中。为了安全起见,我们指定此选项。 - 设置
-buildvcs=false
。默认情况下(“自动”),版本控制信息将被标记到二进制文件中(如果可用)。这解释了为什么仅自述文件中存在差异的两次提交会产生不同的二进制文件。
参考文献:
- Go 对可重复构建的支持
- x/build/cmd/relui:确保完全可重现的构建,包括 tar.gz/zip档案
- doc:为可重现的构建添加文档页面
- 按字节复制 GO 二进制文件
以上就是Github Actions Go lambda 项目不同的 sha256sums的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756