登录
首页 >  Golang >  Go问答

Github Actions Go lambda 项目的不同 sha256 校验值

来源:stackoverflow

时间:2024-02-21 23:00:24 324浏览 收藏

大家好,今天本人给大家带来文章《Github Actions Go lambda 项目的不同 sha256 校验值》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我有 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 二进制文件具有相同的大小,但我怀疑内容是否不同。请首先检查二进制文件的哈希值以确认这一点。

要获得可重现的构建,除了其他明显的要求之外,您还需要:

  1. 确保 cgo 构建可重现(工具链、依赖项等),或禁用 cgo。您已经设置了 CGO_ENABLED=0 (此信息由另一个已删除的问题提供)。
  2. 使用 -trimpath 标志。也许 GitHub 操作总是将源代码放在同一目录中。为了安全起见,我们指定此选项。
  3. 设置 -buildvcs=false。默认情况下(“自动”),版本控制信息将被标记到二进制文件中(如果可用)。这解释了为什么仅自述文件中存在差异的两次提交会产生不同的二进制文件。

参考文献:

终于介绍完啦!小伙伴们,这篇关于《Github Actions Go lambda 项目的不同 sha256 校验值》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>