明天在生产环境中运行我的一个golang代码时,忽然呈现个报错,就感觉很奇怪,本地运行的好好的,放到服务器运行就报错。。。

找到办法解决了问题,顺便记录一下,以供各位大佬参考


1、问题阐明

在线上运行 Go 语言中的工夫时区 这里的一段代码时,竟然报错了,导致程序 panic,谬误的内容为:

could not load time location: unknown time zone Asia/Shanghai

2.问题起因

这就难堪了,因为在本地运行得很好的,所以就找了一下,起因发现居然是因为我用的 Base Image 是 alpine,当然,如果你用的是 busybox 也是会有问题的,因为他们都没有 Go 所需的 timezone 的配置。

3.问题解决

所以解决办法就是须要在镜像中装置这个tzdata 包,在Dockerfile中退出以下这一段即可。

FROM golang:1.14.3-alpine... ...FROM alpine... ...RUN apk update && apk add tzdata... ...