QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5843|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    7 ^. i/ s; s$ o0 a6 R1 ]0 Q前言
    . D4 K! Q& D" g& \% Z" @) w5 a2 I7 E, B1 Y
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
      {8 l  e$ Z+ `5 o3 i* S
    3 F8 A6 c% E% w, C3 |' t, `7 |: ^关键字:Linux、Docker、Tomcat
    % B7 V6 h5 O% q$ [) m1 o! Z! a' w5 V: G; s* D' b2 b/ d
    一、问题重现
    : u7 Z7 n- {' r5 I" ~
    $ |! e3 `) d0 T项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    0 P- |9 y8 ?4 q$ C( V
    8 n" X6 F: X8 ~: w$ s% B[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)5 J0 a3 j6 E9 c
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时9 e- b! s5 {4 ]4 V- j- z
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]% E+ I  K" J3 k( ]$ _1 |5 l
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]7 t9 }& _3 X( a) |( i. N
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]' S% P/ s8 ?( T# x' x2 [5 v
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id& q" R1 o# h+ d: a1 q2 \1 W4 [$ @& U
    Thu May 28 02:50:42 UTC 2020
    8 ]  T4 d3 `" w) b2 j[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    2 c& C! ]/ B$ F/ QThu May 28 14:19:38 CST 2020; _9 I! H8 G+ t* ]2 v
    [root@iZh4ntc7dmrvkzZ ~]#
    ) o4 @" Z1 ~: x* R4 R# f1
    ! [: U( l& M" O+ e4 P2" R) F$ B0 [, x) X. j: j$ b$ M
    3
    5 D) {+ c+ R" a6 k: {4' e1 ]! h% d+ p1 j1 Y
    52 ?8 V* Z* M5 |3 ]& v
    6
    & M1 }  C! Z! T5 c' y! k* B7
    ! ^4 a& x) e% i$ c  z8
    5 B: r0 @8 {9 n9 M9
    % x. v! I3 Q! ?" J) K0 h& F明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    ! I6 n6 p7 `, z+ \8 [# K# S
    ; Y, l# k5 p+ O- n二、分析问题
    " }7 L7 g, }5 p: i/ b# e7 t/ k, b5 u# Q
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    5 @/ a7 S5 m; D; ~  K) r# V$ n; e* G* y
    / Y6 {) H! \2 M# u4 I三、修改 docker 容器的时区
    9 {$ P1 q4 b  D+ E; Q! n$ M3 P4 C5 D/ a/ t: g# \
    1、进入需要修改时区的 docker 容器$ R& P! O9 q, A0 @1 f

    % _& n  Z0 M& |1 r- a[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash: p' _5 y! q$ ]" r0 `
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹) w* H. ?8 h( ^: f
    1
      B* X' D, T. \% u$ A6 l- j2、复制上海(Shanghai)时区到 localtime& [+ |' F* L# L: i0 Z8 p0 R5 K9 G

    . a& s  R0 A/ Z! |root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制1 s. n4 ?/ S5 g1 r  k) j
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    + K% n8 q9 {6 a  F  w. Sexit' B* e7 S$ a% \) t3 i
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器( g; u* f9 K" Y" {
    965abb1fb546
    * U5 ^) B0 C: o9 ?* q[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了7 m) E8 c9 M* P# m$ W- i$ K
    Thu May 28 11:12:12 CST 2020+ i4 I2 {, ~0 F) N0 w
    13 E- p9 [; Q" f& H. V1 o) u' A
    2( c( I4 w' D/ \6 l7 G
    3
    5 b0 Q. |/ @: p6 V: W; R. L4. N3 d1 V( c( Q
    5
    # F/ u+ W1 n* G5 X6, d, t! F& O8 m
    四、验证(重启容器并查看日志)
    # ]" J: [; t0 F
    , D! {) a% L. ?* t" N& B) w/ I6 X7 F( A[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546) D8 X* O0 O% @7 D0 z
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    3 V8 u' [8 t# k4 G* G% Y' D2 K28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version:            3.10.0-862.14.4.el7.x86_649 [9 m- B; q4 T8 `! _/ Q6 |! J3 O
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64% M/ I* ?1 y6 }0 D7 v8 f! Q: U
    1
    ' J, m! s' L% B& |5 Y& r2
    ( {5 `' t5 X! B& J3
    5 z; s. D+ @) J7 ]5 E) W可以看到打印的日志已经和当前时间相同了。
    ' g0 ]2 j# m" @1 }2 Q) F+ V9 P1 [. p0 a# v1 R& B
    五、说明
    1 T9 i% r9 F" I3 u  n  u# r( O% s/ N. h' F* i5 J4 w5 X) q6 t% }
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?4 ?& Q! K) f6 ]. ?9 d1 |% j
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。6 F$ D3 X& t9 ?
    2 D1 F$ X/ T5 R/ ?' E
    六、参考1 V0 c$ p7 ^4 X) o
    4 [1 ^! |3 A0 h# z
    参考文章
    ( I# X1 s& ~% V
    / P( ~3 j& n6 y% i/ e& k1 ?* f总结
    , `: T- I. n- Y3 h- N5 N) ]- t4 ^2 G4 t  f
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    : X7 [2 [2 U8 C& F9 \% L————————————————
    & a2 D$ g$ W" W  N' M版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    1 y& N7 O4 J' n( a5 p$ @3 V3 l原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093+ F) p* Y% U% @' o* B7 {3 [' _
    / Y% n9 T1 u2 ?5 ^6 _# ~6 N

    ! u7 B# l& i9 V
    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, 2026-4-17 22:59 , Processed in 0.437235 second(s), 56 queries .

    回顶部