今天在生产环境中运行我的一个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
... ...

李杰
15 声望4 粉丝