Maison >développement back-end >Golang >Comment définir le fuseau horaire dans la langue Go

Comment définir le fuseau horaire dans la langue Go

青灯夜游
青灯夜游original
2023-01-09 10:27:453512parcourir

Deux méthodes de paramétrage : 1. Fuseau horaire fixe, syntaxe "var c = time.FixedZone("CST", 8*3600)" et "time.Now().In(c).Format("time")" ;2. Charger le fuseau horaire, syntaxe "var c, _ = time.LoadLocation("Asia/Shanghai")" et "time.Now().In(c).Format("time")".

Comment définir le fuseau horaire dans la langue Go

L'environnement d'exploitation de ce tutoriel : système Windows 7, GO version 1.18, ordinateur Dell G3.

Division des fuseaux horaires

Le monde prend Greenwich, Londres, Angleterre comme point de départ de la longitude de zéro degré. Tous les 15 degrés de longitude sont un fuseau horaire. La longitude de 15 degrés est le méridien central. du fuseau horaire. Il est divisé en 24 fuseaux horaires. Un fuseau horaire augmente tous les 15 degrés de longitude d’ouest en est, et inversement, un fuseau horaire diminue tous les 15 degrés de longitude vers l’ouest. Le fuseau horaire de la Chine est Est 8.

Format de l'heure

L'heure actuelle time.Now() renvoie l'heure dans le fuseau horaire local : time.Now()返回的是当地时区的时间:

func main() {
    t := time.Now()  
    fmt.Println(t) //2020-12-16 09:34:19.5828312 +0800 CST m=+0.004002201
}

CST时间

CST可以代表如下四个不同的时区:

  • Central Standard Time (USA) UT-6:00:美国标准时间
  • Central Standard Time (Australia) UT+9:30:澳大利亚标准时间
  • China Standard Time UT+8:00:中国标准时间
  • Cuba Standard Time UT-4:00:古巴标准时间

time.Now()返回的 +0800 CST 表示的就是中国标准时间,与UTC时间有如下的转化:

GMT + 8 = UTC + 8 = CST

Monotonic Clocks 和 Wall Clocks

Wall Clocks表示挂钟时间,存储的是自1970 年 1 月 1 日 0 时 0 分 0 秒以来的时间戳,当系统和授时服务器进行校准时间时间操作时,有可能造成这一秒是2018-1-1 00:00:00,而下一秒变成了2017-12-31 23:59:59的情况。
Monotonic Clocks,意思是单调时间的,所谓单调,就是只会不停的往前增长,不受校时操作的影响,这个时间是自进程启动以来的秒数。
time.Now()返回的m=+0.004002201就是表示Monotonic Clocks

时区设置

go语言中如果不设置指定的时区,通过time.Now()

func main() {
    t := time.Now()   //返回本地时区格式
    fmt.Println(t)
}

Heure CST

CST peut représenter les quatre différents suivants fuseaux horaires :

  • Heure standard du centre (États-Unis) UT-6:00 : heure standard des États-Unis
  • Heure standard du centre (Australie) UT+9:30 : heure standard d'Australie li>Heure standard de la Chine UT+8:00 : heure standard de la Chine
  • Heure standard de Cuba UT-4:00 : heure standard de Cuba
heure. Now() Le +0800 CST renvoyé représente l'heure standard de Chine, qui a la conversion suivante avec l'heure UTC :

var cstZone = time.FixedZone("CST", 8*3600)         // 东八
fmt.Println(time.Now().In(cstZone).Format("2006-01-02 15:04:05"))

Horloges monotones et horloges murales

Les horloges murales représentent l'horloge murale heure, le stockage est l'horodatage depuis 0:00:00 le 1er janvier 1970. Lorsque le système et le serveur de synchronisation effectuent des opérations d'étalonnage de l'heure, cette seconde peut être 2018-1-1 00:00:00 et la suivante. la deuxième est devenue la situation du 2017-12-31 23:59:59.
Les horloges monotones signifient un temps monotone. Le soi-disant monotone signifie qu'il ne fera que croître et ne sera pas affecté par l'opération de réglage du temps. Ce temps est le nombre de secondes depuis le début du processus.
time.Now() Le m=+0.004002201 renvoyé signifie que les horloges monotones

paramètre de fuseau horaire

la langue go n'est pas spécifiée si il n'est pas défini Le fuseau horaire obtenu via time.Now() est le fuseau horaire local :

var cstSh, _ = time.LoadLocation("Asia/Shanghai") //  上海
fmt.Println(time.Now().In(cstSh).Format("2006-01-02 15:04:05"))
Le langage Go n'a pas la possibilité de définir le fuseau horaire globalement à chaque fois que la sortie est effectuée. l'heure doit être modifiée, une fonction In() doit être appelée.

🎜Il existe deux façons de définir le fuseau horaire : 🎜🎜🎜1. Fuseau horaire fixe (recommandé)🎜
FROM golang:alpine as build
RUN apk --no-cache add tzdata  //构建阶段加载时区
WORKDIR /app
ADD . /app
RUN CGO_ENABLED=0 GOOS=linux go build -o myapp

FROM scratch as final

COPY --from=build /app/myapp .
### 下面这行是新加的,复制时区相关的信息到最终镜像中,否则程序会找不到改时区
COPY --from=build /usr/share/zoneinfo /usr/share/zoneinfo
ENV TZ=Asia/Shanghai  //在最终阶段设置时区环境变量

CMD ["/myapp"]
🎜Fixez le fuseau horaire du district de Dongba. Mais ce n'est pas un paramètre global pour le programme. Le fuseau horaire doit être corrigé à chaque fois qu'il est obtenu 🎜🎜2 Chargement du fuseau horaire 🎜rrreee🎜Chargez le fuseau horaire spécifié. Mais si vous utilisez cette méthode sans environnement go, le chargement échouera car les informations de fuseau horaire sont placées dans le package d'installation go. 🎜🎜Remarque : configurez le fuseau horaire dans Docker🎜🎜Si vous utilisez la deuxième méthode pour charger le fuseau horaire, vous devez configurer le fuseau horaire lors de la création de l'image Docker. Le fichier de configuration est le suivant : 🎜rrreee🎜[Recommandations associées. : 🎜Tutoriel vidéo Go🎜, 🎜Enseignement de la programmation🎜】🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn