相差8小时:时区设置导致docker中的openGauss时间问题

2024-05-01 15:20

本文主要是介绍相差8小时:时区设置导致docker中的openGauss时间问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • (一)问题
  • (二)解决
    • (2.1)确认服务器时间
    • (2.2)确认和修改docker时间
      • (2.2.1)失败的尝试
      • (2.2.2)成功的尝试
    • (2.2)确认和修改openGauss时间
    • (2.3)one more thing
    • (2.4)two more thing

(一)问题

前面用docker装好了openGauss。
跑应用时候发现时间不对,比实际时间晚了8小时。

看就知道是时区的问题。
但是如何解决呢,经查docker可以指定环境,创建容器的时候指定时区。

> docker run -it -e TZ=Asia/Shanghai ……

但是俺前面有些数据的操作,不想再弄一遍了,怎么办呢。

(二)解决

(2.1)确认服务器时间

先确认服务器时间(时区):
没问题东八区。

> date -R
Tue, 30 Apr 2024 14:17:52 +0800

(2.2)确认和修改docker时间

再确认docker时间(时区):
果然晚8小时且不是东8区。

> docker exec -it og501 date -R
Tue, 30 Apr 2024 06:21:47

(2.2.1)失败的尝试

按照网上的说法,进入docker,链接文件到我们自己的时区。
然后重启虚拟器。

> docker exec -it og501 /bin/bash
root@a3a9789a9866:/# ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
root@a3a9789a9866:/# exit
exit
> docker restart a3a9789a9866

再看时区并没有变。
仔细检查下,原来docker里面根本没有/usr/share/zoneinfo,蛤这镜像,连tzdata都没有。
所以我刚才只是新建了一个空链接localtime,链接到不存在的文件Asia/Shanghai而已。

(2.2.2)成功的尝试

那么就从外面拷贝吧,
这样刚才的链接就有效了。
由于太懒,我只拷贝了上海。。。

docker cp /usr/share/zoneinfo/Asia/Shanghai a3a9789a9866:/usr/share/zoneinfo/Asia/Shanghai

噢,应该先建目录再拷贝。
忘写了。

(2.2)确认和修改openGauss时间

重启后docker里面正常了。

> docker exec -it og501 date -R
Tue, 30 Apr 2024 14:34:49 +0800

但是数据库里的时间依然不对。

> select now()
> "2024-04-30 06:36:12.740174"

看看时区呢:

> show timezone;
> "UCT"

这我无语了,谁拼写的这玩意儿,再怎么说也应该是UTC吧。
反正吧改成中国吧(我只改自己的库,坑继续留给其它人)。

> alter database postgres set timezone='PRC';

看看时间:

> select now()
> "2024-04-30 14:42:16.178802+08"

再看看时区:

> show timezone;
> "PRC"

(2.3)one more thing

修改数据库时间后,之前已入库的错误时间记录是不会变的(它们是数据啊)。
所以要么从业务层面上去更新,要么留着不管。

(2.4)two more thing

还是设为自己的时区比较好,
强行改时间,都设为UTC,咋看是没啥问题……如果你的系统不用跨国的话……

这篇关于相差8小时:时区设置导致docker中的openGauss时间问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/952012

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在