QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5706|回复: 1
打印 上一主题 下一主题

Docker 中时区和宿主机相隔八个小时的解决方案之一

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-5-30 15:21 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    Docker 中时区和宿主机相隔八个小时的解决方案之一# C, o; P- b. n' T
    前言! Y8 B1 [/ e0 }; L' O

    ! Y* M$ i2 Z' r项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    6 ]  I/ `; ?4 W6 X* W" e9 F7 I6 ~+ A5 z& Q, U4 m
    关键字:Linux、Docker、Tomcat) b0 ~5 ^& W2 K5 h8 R6 g0 Z0 T* M- B
    0 F6 u' E& _/ [
    一、问题重现
    1 E: ]6 R7 i3 _1 g& P
    5 E, h5 [% f+ B. u1 R, Y项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    ; [! g0 p4 X& d* ?, `; A; C1 q. O% V. X$ q. I  _$ f* J6 d8 \4 d
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)4 [# A$ ]% P* P! p) F. @. O5 g5 ^
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时8 {8 B/ j* [: R& _! N) c  x: |4 l" t6 ]2 G
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    ! U  e/ P1 l$ C7 p28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]* B3 g6 v9 P  a( K
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]; R5 @" a8 [, A7 d$ n
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    8 u7 S0 F) S- O% E' g" m6 g) yThu May 28 02:50:42 UTC 20204 S- I' w) b! I8 ?% t7 L
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间3 V" _6 h0 `, Z+ T1 m, d' s% M1 Y
    Thu May 28 14:19:38 CST 2020, Q: w$ O% _2 D  x, R' I5 C
    [root@iZh4ntc7dmrvkzZ ~]#
    9 r7 A# r; P% e2 X$ z7 W: C* W1- v7 L' r+ l1 m8 b9 ?- b% O0 @
    29 j8 z8 |* B; E/ a% F1 \. b) j& L: A; O
    33 O0 Y- g1 C, I& i6 t5 X
    4, S3 o  a5 {! w7 S: C, {
    5
    8 }% _1 n) _+ r: q) i$ n3 D  x65 G& B4 P6 d3 E% l' W
    7* R  d" k( D/ Z% Q% r/ F( |/ N* r0 l) M9 n
    8
    - ~, l# Q6 j9 ^+ x# v- L! b93 }) X! V* J3 U- ^& O
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。$ p7 I$ w7 o' F+ \/ P! t% B, q

    : q$ n6 o& ]0 F二、分析问题, c& M. O/ T$ j' O* x( ~

    3 T, d1 a7 Z: O0 O6 U' m刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。7 R, t, ^7 R+ V! I8 o* x. }

    $ Z) [6 h, o3 s; a三、修改 docker 容器的时区. |2 D& u/ E& c. g; w

    1 ~7 @. v9 p! f+ S6 {1、进入需要修改时区的 docker 容器
    1 V  v6 c+ _8 n. a5 `2 \+ B. ]  y5 q& C* {* f0 O- q1 {
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    ! E" a7 P- Z  |# V" P' l' r7 O" v7 Croot@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    + `8 A  J7 S4 y4 N9 i, m4 [- H1" [6 \# i7 u# S8 P
    2、复制上海(Shanghai)时区到 localtime& H$ K6 S( ^# J9 ~3 k
    ( t3 r6 O& k( m8 [9 t
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    & N1 E9 t$ x' s7 N- D  Kroot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
      g0 v9 u$ _7 V8 j& U' O2 z0 Q7 }exit. h( e' u9 a" I- ], \" C
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器2 V: r2 |1 X2 f9 _: y
    965abb1fb546  j* u$ b6 ]/ J# A, K- }  c$ E& y
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    - b6 {" x4 C4 v- c9 o% x# QThu May 28 11:12:12 CST 2020, x& B6 z& c. ]' l6 f1 L2 \, {
    1
    $ i2 P' @; m  k3 Y  r$ [2
      i1 m7 E& d4 _- X3
    & ?1 I6 y: f' A7 g/ ^4
    . r8 r9 ~) w# O5
    3 T* N% E% h# c9 y( C  c% X6* m% ^# j: G0 @, v
    四、验证(重启容器并查看日志)
    7 W9 u6 S5 i/ J9 p; u% D+ M
    " T1 \/ s! T- B2 F1 J[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546$ d1 m7 u" Y" D( y% c, [$ A% n
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    ! v/ J  ^, E% C28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version:            3.10.0-862.14.4.el7.x86_64  i( b2 u; a+ M+ [" d+ Q
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    - J& r$ L3 s/ g' W1' j4 j  |' Y' R9 A' G
    2# z3 P. o8 D/ d  y
    3
    * _2 M" _# Q% C$ U/ M可以看到打印的日志已经和当前时间相同了。
    0 i, l+ J6 r1 E5 Z8 J2 v# [6 m- z% N9 P# F9 @4 b% c/ R
    五、说明; y0 v5 _. b6 R8 ~! Y
    ( a* M) [8 E/ x4 L( Z
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?. K4 q1 }6 c* d6 [! h" {! z
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
      x; O+ a- O# E7 S& D4 I, Z6 F% I
    : W3 _: F0 M; I# P% V4 U% W6 c( I六、参考
    5 ?2 c  O% K- m
    1 F  ~& z- g9 J: X; I参考文章
    . \9 W, A) r4 O; V6 \7 W; V
    ; ?: _" t/ v7 w9 [. w) L总结; b" A, H( ?' m
    ( N) p; b  p. ?1 y$ o* s
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    2 {; o, Q  Q/ H4 S8 E4 Y# r————————————————+ W5 A) p! k' X7 X$ A
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    6 W# ^- h) m/ ]原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093" `! R# C2 T: I

    4 R; X4 E8 m$ G9 m8 _
    ) S: ?! b: X6 n- W8 a$ k, d
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    0

    主题

    1

    听众

    6

    积分

    升级  1.05%

    该用户从未签到

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-9-19 15:28 , Processed in 1.986919 second(s), 56 queries .

    回顶部