QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5844|回复: 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 中时区和宿主机相隔八个小时的解决方案之一, f8 O& e7 m7 R; G" ]; a
    前言
    ! v2 B4 E* x" S; U  ?  Q$ o
    + g% S4 E$ {" Q% R4 D项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。  w: _' J. O% \" p$ O  k3 G

    / [4 [7 i4 H  W5 V1 J关键字:Linux、Docker、Tomcat. O+ N% K6 d3 H$ X' k+ f! A

    0 Q6 ]+ w. n7 l& W  Y% d" U一、问题重现
      E7 p2 B7 Y2 l8 C6 |( h
    " F) C8 k1 ^" a* f, r6 n, g项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    # ~: F9 V' Z2 T3 y, j' e9 a/ ~3 b
    - u* e: R  _& C- \5 e& t- p) R[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)6 q: \1 v( ]! p3 `" o, x" J/ n
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时) ~4 x" D4 O6 P* K! B: N' ^
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]3 r% P1 x* X( @* @$ E7 k/ h
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    ! Q* b5 ]! ?) ^$ C" E& ^: U2 n& E5 q28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    * L8 o$ d- c0 C6 F[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    ( i( x) Y2 V) C1 ^5 {6 L3 \Thu May 28 02:50:42 UTC 20201 l/ F& |& ^! i
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间* b* {" i; O5 h, i% h
    Thu May 28 14:19:38 CST 2020
    0 d) @. H! h' _2 w. Q[root@iZh4ntc7dmrvkzZ ~]#
    7 `3 ~0 r* T8 w; q8 [0 [" W1 k  q4 u% y17 m9 j( P5 N0 A# q' U/ d
    2$ r4 m! z! \" C% V8 _
    32 J8 b5 w+ y  }& [
    4
    6 I( L7 |. s( M5
    6 `$ G$ M( F/ x; B& s, T6) J! \, ]( h: z, y0 e/ _
    7' l8 h, T8 H2 U2 ?9 T
    8
    9 W1 G  X6 l2 I: {; y2 }5 \# D9
    8 w) ?/ ^" {* U: \  e明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。. v, h: |4 b7 Y- t
    9 V* c+ h6 n# L: i1 X
    二、分析问题
    / _: o* e2 ]* S- N. `( w
    1 S+ V! X' e  m: w( x刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。" ^4 w* @! S3 L! c4 j
    . [' }- C6 @# s( T! l' ~. W9 F5 n4 B
    三、修改 docker 容器的时区# ?3 Z8 `8 y7 a8 |: e
    1 \; e( m+ s5 m# U' y5 F5 [& A
    1、进入需要修改时区的 docker 容器
    # `( r4 m; B* n. l6 S& G' u
    " q9 j$ M) a& r- l  z- v# {; G[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    + ?! B: R, Q* `' [" C) S. Jroot@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹! C7 p% A! t/ ^/ R. |2 o8 k! Y
    1' O) u2 z2 R7 N$ ^: b; R
    2、复制上海(Shanghai)时区到 localtime
    ) J; z& H' `5 v5 ^
    , @8 `. J; V* J6 s( \" troot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制7 a/ V1 a2 m( @4 f- z  h' T2 n! s' h
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器5 L8 Z0 b4 }; D  W
    exit" @0 u2 F4 `- f3 b
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    9 L! T6 O( l% b& N. R965abb1fb5462 M. `# D: G; c7 h
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    7 z$ O; @4 R9 s" m: [- k  ]1 _/ d6 P, rThu May 28 11:12:12 CST 20204 f( u. c  ^. q( x( `# M9 H2 r
    1
      t8 H8 K" o: G* v2
    ! @, R( D1 n& u0 l. U3
    ) s* B8 M& h! b5 D7 S( \9 U+ E7 @/ O  R4
    ! ]- K7 T- H# Q9 _% q9 Y6 G2 K7 G' x5! N) u2 `* h' h/ z8 Q/ H% g6 t
    6/ v5 T1 U: V/ |7 _: M8 |1 ?
    四、验证(重启容器并查看日志)
    $ ?8 p. w9 [% M) n( X, s
    ; [+ f) S4 a- z[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    ; X4 [2 L+ P2 A% i, A. p0 S28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux8 \  g5 P3 S3 h% e
    28-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
    # _, \3 ?0 U3 n9 [! x8 Y28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    ) o! ], Z  s/ y( d+ }, p9 c" \1. y. U% ?7 x/ j8 _
    20 i! c2 v0 I! Z: ]& f# ?
    3
    - U8 w  c1 M9 P  p, J( _. j可以看到打印的日志已经和当前时间相同了。- f3 h/ T1 q& n, n, a7 g
    # D" u; S/ J& P' ]6 x. L& t- u" @
    五、说明
    7 I  f" D$ l$ ?7 H: A; L5 J
    - K  e/ m: a! u6 O+ W0 _+ z4 x为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?& `. T$ K" Z. ^7 X" g
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。- o2 c  L2 X9 t: W0 x' b" q6 J( W
    2 Z) w7 N& p' ~' K, o
    六、参考  F, V! S; n' g; u/ C/ t

    # V. b4 d( Z  m7 ?2 A) y' S参考文章. i% D# T# Z1 I( Z' h( l3 Y2 L8 [/ k

    ) r  [$ a; K, E4 m' ~1 s总结( ?; {( j9 J' n% a" [

    9 z$ v' r/ b0 o, G% q8 c时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。" A4 c8 G) p: [7 t
    ————————————————# Y3 P- O: U2 D/ i# g6 p# V2 E( s
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    3 e* b5 M/ a+ N3 B2 a* K9 i原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    0 x- j6 M- W7 C1 w
    ( K% c  q! x& j2 d+ \0 S% }' P/ X3 h4 `( n# B9 ^4 X. 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, 2026-4-18 10:31 , Processed in 0.424106 second(s), 56 queries .

    回顶部