最近有一个用户反馈, 他使用 golang:1.13.1-alpine3.10 这个镜像来编译的可执行程序无法在云函数的环境运行, 报错信息如下:
fork/exec /var/user/main: no...such file or directory
在 macOS 下编译则没有这个问题
问题定位
还未来得及定位问题, 用户便反馈说换了一个镜像就没问题了, 于是没能获得更多信息
过了几天, 有一个同事在群里贴出了...Go 程序链接出错的信息, 看起来也是在 Alpine Linux 下编译的, 有人回复道 Alpine Linux 使用的不是 glibc
啊哈, 终于有线索了, 写代码验证一下
package main...readelf -d)
$ ldd main
not a dynamic executable
程序太简单了, 没有依赖动态库
搜索了一下, 发现 Go 的仓库有一个 issue #33019...(完整的出错信息可通过使用 Go 的 os/exec 包启动 main-alpine 获得)
解决方案
问题的原因在于云函数的运行环境(CentOS)提供的是 glibc, 而 Alpine Linux