QQ登录

只需要一步,快速开始

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

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

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

5273

主题

81

听众

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 中时区和宿主机相隔八个小时的解决方案之一
    ! x" F0 Z9 i+ [9 X; S) Y前言! _) u* T' M% o3 V

    8 I. l8 a& q9 k. n9 D项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    3 X3 ?6 {, n( J
    ) e# K! p$ I# }2 q关键字:Linux、Docker、Tomcat
    # M5 v8 I- c/ Q3 U& L" {8 u
    7 Y& ~2 `/ W& x一、问题重现
    7 _* K  s/ H  g' _% M; }& C1 ]5 }1 I0 N  Y
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
      U8 d: h$ @2 ~; @/ @, X* g& x1 @9 a/ S% y
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    : Z- K4 Q/ r' y& A& K- A! u; c) S2 G# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    + T' R! h- X- f5 H! z28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]8 L/ Q+ v' k* o
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    ; \' d  V" l4 K* f4 M3 w8 c28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]$ E. ^7 p6 l- e. c( i* t
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id  {. \5 Y  N: D2 z0 L2 v& Q) v$ O
    Thu May 28 02:50:42 UTC 2020
    ' T7 c% @4 [' t. e/ l[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间% Z" a: n: n" b
    Thu May 28 14:19:38 CST 2020* q* h2 R& M) e
    [root@iZh4ntc7dmrvkzZ ~]#
    2 u7 G. b( `$ R4 j6 j% r, R6 `1; Q  n" h, y2 G; ?  d/ I0 Z& M1 I
    2
    7 y/ q  T( U7 @4 g3
    0 v- G! h5 N! J2 m44 _6 z, U  y; A
    5
    9 A1 @; ~7 K2 p& s5 \0 V* f2 k6
    1 b  Q1 t2 C0 Y/ U7 n( @7
    : |- J! Q! M% l7 `& x8
    * f) w4 k$ i) L98 k- d& R- u9 J
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。; h! [8 {, q3 C- N6 Q+ K8 Y

    ' I8 A2 u4 M6 S' b  T" _2 S二、分析问题
    0 a0 L% v/ U. w+ ^% s$ J9 A) K
    7 q  G; t8 B5 R; M  `0 F7 \刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。6 L) r. Z$ Z0 j2 g6 T

    7 t% z2 P1 b% G4 r+ v, g8 a% W6 M三、修改 docker 容器的时区
    0 A) X& \, O1 N6 X$ c" ~$ u( k  M
    1、进入需要修改时区的 docker 容器- H& l! E& W2 w% b1 ~  Q/ \' G

    4 h* b3 d  }, q9 b[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash2 T' H+ \) v8 _4 _& C, i; l
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    ! r. @1 Q) p9 x' D+ P11 \* }1 [7 r4 A2 }) I2 S
    2、复制上海(Shanghai)时区到 localtime
    ! E3 }' E' u, r; g: C, u) O) P0 K
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
      m4 X- ]; L9 P& Troot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器$ W7 q7 X, H- w2 {! _* s' N2 U, A
    exit  s2 T1 o& c  [
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    ; K3 ?# d. x- w; T  T2 b/ l. ]965abb1fb546* J# e# f8 M2 |9 ^4 {, U
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了4 ]- T: {- S0 c/ k# K6 S/ V
    Thu May 28 11:12:12 CST 2020" u5 D. p$ `" F6 A6 U2 ]
    1
    # ?$ Z8 S# V9 p3 l! E/ m2, C7 D% Q0 T- c, ?8 g: l, ~
    3
    % _5 o: F" V1 Z" f, f' N) B8 r4; g9 s( @* X( Q+ f
    5; v5 Y, u1 H% y, \" L5 w$ ]! i
    6, L$ N# K5 x. Z. l- w2 S2 g
    四、验证(重启容器并查看日志)' ?" F! l$ z* Z3 Q0 A1 S7 s  [

    : D5 a9 L1 Q  B& f1 n6 _4 q[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546& q& E' m, Y; x
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    - K' r* k6 v& E- a  W' f% b6 b28-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) ]' R! N" |# e( ~' q# c
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    . G. Q% l8 }1 Q$ ?( T19 {2 ^4 y# U+ C0 D! E
    27 H1 }4 S  \7 P3 i7 p, C% L7 Z
    3
    ) {. F* ~) w5 a9 n  Q可以看到打印的日志已经和当前时间相同了。
    0 S" k% h& s  L/ Y. ^! S
    2 F1 b& q* E" u2 ], z9 K5 K五、说明+ F5 w6 m% A! i/ r# O
    ' [: {) j0 B4 L3 l: V
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?6 Y/ ~: U' f( H6 m
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。( G5 x2 ^0 ^5 ~4 o
    . s$ q4 G* ~1 I5 F. W. W/ n
    六、参考
    " Y. Z9 a4 W/ S' M6 J8 h1 {; |$ X: \! W
    参考文章
    * B1 b5 n8 l+ g6 u9 x5 C/ p) w1 S
    ' w# N! W( i' J8 C+ ^) m3 O总结
    , b( [8 B0 R6 ]: S! P3 s7 ]- q1 P& v
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。# z/ t4 U9 ~; ~0 V( ^
    ————————————————9 C, ?+ L5 t; L# d6 B- r! G
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    & i" Z( C$ a2 N  a原文链接:https://blog.csdn.net/weixin_42816285/article/details/1064030939 \0 ^' P; q6 @& W" ^

    & n$ Z! X8 C$ `1 H$ R8 J! m; |$ t- Y$ n$ q4 ]
    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-5-10 03:03 , Processed in 1.200407 second(s), 55 queries .

    回顶部