本文首发于 Ficow Shen’s Blog,原文地址: Docker 中使用 scratch 镜像构建 Go 应用镜像,容器报错:X509: Certificate Signed by Unknown Authority。
内容概览
- 前言
- 将证书添加到镜像中
- 不使用 HTTPS
- 总结
前言
当使用 FROM scratch 构建基于 scratch 镜像的 Go 应用镜像时,如果没有向镜像中添加证书颁发机构(CA, Certificate Authority)发布的证书,您就有可能遭遇这个错误:X509: Certificate Signed by Unknown Authority。
其实,解决的方法比较简单,只需要将部署该容器的服务器的证书导入到镜像中即可。或者,采用下策,不使用 HTTPS。
将证书添加到镜像中
最终运行该容器的服务器的操作系统的不同,证书在文件系统中存储的位置就会有所不同。
对于多数 Linux 发行版来说,这个目录是:/etc/ssl/certs。比如,在 Ubuntu 20.04.1 LTS 中,我们可以使用 ca-certificates.crt。
使用 s

在使用scratch镜像构建Go应用的Docker镜像时,遇到X509: Certificate Signed by Unknown Authority错误。解决方法包括将服务器证书导入镜像或不使用HTTPS。导入证书可通过将证书文件复制到镜像指定目录,并更新代码。不推荐直接切换到HTTP,因为这将暴露网络请求信息。

2627

被折叠的 条评论
为什么被折叠?



