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