QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5701|回复: 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 中时区和宿主机相隔八个小时的解决方案之一% v$ {6 |, |$ d/ R9 i
    前言
    ( L% H& l' b; V. m, k* B( a; Y+ ~4 M" a# q( u" i2 U0 ~3 E
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。$ w* N( ^# r9 i( O7 X
    1 Y' I* s9 `9 B! K
    关键字:Linux、Docker、Tomcat
    - i) {; ?6 O# G* J* G% f
    " b3 G+ M! a; K! o! T) q一、问题重现
    & r: m6 _  m( E/ f9 b
    ) c% r4 v5 M1 ^, O5 z+ g" f: `项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    4 _/ u! c8 g- ~  H7 @/ R( {$ S& t; U" I! w) [9 l  i' d6 _
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    ) A" s# ^8 U+ y+ j" _# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    + Q% Q& q6 l/ D; b28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]8 s: i- z6 X) K( \* O2 S
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]$ @$ L( w% V" n: u& y1 @
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    6 v' m3 z& _1 d) A, d[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id6 s$ K. f4 Q/ e% X
    Thu May 28 02:50:42 UTC 20207 l6 M# @7 G! @/ e6 }0 g3 i
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间9 J6 R9 r& A& `; y$ V% Y
    Thu May 28 14:19:38 CST 20208 ^5 `% K5 M8 |) t  |" W
    [root@iZh4ntc7dmrvkzZ ~]#
    , W7 ?/ J" t7 m& s1
    8 K9 y' l+ [$ e; F' f' b2
    8 E, r* L; e) o3+ r7 e& ^8 V" G) D, C. \
    4
    ) ^. u& j* t4 e# D4 K9 F6 s5
    + C+ o( H$ M$ {+ z6& r1 R# H& u6 h" r8 }0 n
    7
    7 t( Y5 ~) T, l0 J8
    ; j: ^! Y. z- P' l8 u) a7 w98 W0 H% S- K, E2 f! e
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    % K6 ]* |0 N6 h" U1 X8 h8 L' |" A& P! s& i
    二、分析问题9 B( m- m$ m( G* h+ A" J

    / ?* y7 U  Q3 ~! W9 j1 H刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    ) d! {+ D1 V4 S8 O
    : Q4 {. y4 S5 k9 L; k$ X' o三、修改 docker 容器的时区
    5 q0 ~+ U3 P/ q9 _) ~8 S: D# z& |7 _9 E" G, q5 U+ Y
    1、进入需要修改时区的 docker 容器
    / Q  F+ [* f" c/ u8 ^0 ?' X4 F4 _
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    ( z& d2 ~$ V2 M0 F+ lroot@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹; V( I% U7 Q' v7 `6 y
    1& H4 N" @1 `/ t! V% L  L' O
    2、复制上海(Shanghai)时区到 localtime
    7 `1 f$ p$ w! \+ s& b
    7 A7 {& M8 n7 \- ^root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    . P  C; ^% T3 J8 ~" kroot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    1 K9 H  O  R1 c* ]# i. ~exit$ H* t& K# g) u
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    " a4 t/ ?7 n6 B7 n6 `2 l! Q965abb1fb546
    1 Q6 D4 E6 p, T$ n, H[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    ) g! n( s+ U( ?) c! N- b2 IThu May 28 11:12:12 CST 2020
    + c  f( j/ J- O) _& m1, _9 j1 X) }& U# p
    2; R7 `6 O3 R5 N: [
    3" a* ]# y2 e2 x" {' u9 d5 W
    4
    , E' l( G9 G' a1 J5
    ( k( H! y6 ?- N1 m6 g3 _6% i- v& B% n- E; ]
    四、验证(重启容器并查看日志)
    - ^- w4 P7 C7 ?3 {& G4 d" s/ f/ r  k& M9 |3 H
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546: X0 o! h$ }! K% C8 h
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    : M6 K% ]4 |) R' ?" F9 E6 X28-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$ {' e' o5 }/ o  U6 Z
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    9 p7 x: b7 N/ s2 v9 @; \1% _+ Y! V1 N' r8 f$ \) j& O9 w$ n
    2& d) c! @; @4 M
    3
    / r- T7 D6 `* h1 B' ]) F可以看到打印的日志已经和当前时间相同了。
    * r- R6 u1 `4 m( T  m! X) p& \3 j7 }9 O
    五、说明
    5 A6 R$ L" F6 F' s2 f7 {0 I; G
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    ! w% W8 n! U5 Q是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    ) j% b6 h* S* ]1 \0 Z: `! ~0 P9 F
    7 ?6 E& w' g/ w" ?& i六、参考+ q% }" q8 h+ [* o

    ; |/ i, L& k4 u2 k% P/ U1 e参考文章* e; q( E) U5 V4 l% W5 Y- K

    # P; f- V* {# r9 W1 d6 S总结3 X  n! [5 I- f7 o

    4 a) H" g/ n3 K. ]1 M7 K1 d时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。) B0 c2 `" U" v3 ?4 I. a$ [2 l
    ————————————————
    ' I6 t0 A( _/ I, R8 }版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。9 k0 b' A* x$ V! c0 r" k6 _( q+ W  U
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    4 X2 D4 w" I5 o3 c# l+ ^) n& J6 x5 D

    4 _3 ^+ r6 b8 [" d( H
    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-16 11:00 , Processed in 0.431577 second(s), 55 queries .

    回顶部