QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5882|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    $ D  Y3 c" r4 ~前言
    4 S0 j3 Y6 Z0 f  c) A" X
    ! J- `: j) y- B  s+ Y' J6 ^项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。) K" r/ |( [% b) H3 l% B) q% @: ?
    0 ]$ Y& ?$ _2 W$ L
    关键字:Linux、Docker、Tomcat
    4 t# m: n6 c) k3 X& W3 v8 z
    , P# q: s( w) |7 q6 J一、问题重现+ y8 C6 a# s$ M  V+ X7 I

    : k/ G# K7 M+ X# j1 _' B项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    5 A9 l/ d7 Y8 e; h2 V( b' b( t! l+ R7 K1 I9 x3 C: ]% P
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    6 C4 G7 R7 z3 H  l# 打的日志上面的信息会比当前的时间(北京时间)少8个小时3 j& c6 g- Z( c) |  L' ]
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]/ q5 s& ?+ K* n) u
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    & {9 y: U/ t) y. p. d28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    9 d5 \3 I7 T6 L. s; b[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    , \, z$ e: Z: q! @Thu May 28 02:50:42 UTC 2020
    % q% X( i1 w: Q+ h- A' Y[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间+ F% s, e) S% e6 j9 p
    Thu May 28 14:19:38 CST 2020
    ) k" W- s( A' R; x[root@iZh4ntc7dmrvkzZ ~]#
    ; `& g: q1 v+ A3 R' F6 G, q7 `1' [6 C- N/ S9 r* m3 Z
    2
    5 o) k( r- f) K5 Q: ^8 H3
    " e2 r# q3 d* ^6 s! p) D5 ^4' K; [! Y" y4 `; z9 t
    5
    " d! ^) |! l4 u; [+ x3 o6
    2 B* x9 r5 |. g7; V6 U. F- d  h
    88 q( H: j, I" I! w+ A# w) s- i
    9& s( A; V5 T) [8 M
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。$ R% ?: N6 A2 \/ C# o* p
    ! \) j) m9 c3 k, K+ Z: D1 P
    二、分析问题6 |* i' r; ~  p" z- e
    # I$ o4 `  o) X7 p4 F- _
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。3 E& O, J1 V! k

    + e$ _; B, t% R5 Q三、修改 docker 容器的时区
    ( c( i4 d+ J, ]8 Z2 p
    $ F7 Q5 I2 n, \! ^! M; d1、进入需要修改时区的 docker 容器
    / i. s5 z; J+ o8 K* E1 `
    5 Y1 T2 @8 R2 ?  o( S9 B[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    # x" T* \% [8 G, _2 V; O) Groot@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    * K0 G5 {3 O! V- |1" G8 ?8 q/ f  t! y$ ^( r
    2、复制上海(Shanghai)时区到 localtime
    3 }2 o; ~! x( w& [$ s' j' F6 y) z& i: Y' G- U0 ]) }3 x* b( A
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制6 M& c  ~( V7 |
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    , d: ^: x. V; ]# Dexit1 t1 ^' |3 l$ x: p4 |
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器6 Z; i- ~' f7 J; U5 z
    965abb1fb546+ D) s. M! W9 K- a
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    ' c- q4 Q& C2 m, q+ {+ \Thu May 28 11:12:12 CST 2020/ V" ]5 S- Y3 P
    1
    % `: ]/ w# [( Q! w7 l, ^6 R5 t! x, w21 @: S. M+ i' b7 e5 P' B
    3# B" H( a# T; \$ D. y, g
    4
    . G1 \( W+ K- V  ~) J6 S54 R. G) a4 n1 N/ o6 _* h
    6
    2 I" O# P5 I$ N  m: |- |四、验证(重启容器并查看日志)) @$ Q9 ~4 h! c+ ?; _; Z

    * e& _) B8 G3 P. S5 T' s; B# `[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb5466 C8 D, y+ s. [* ~2 Y
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    + W) }  F' r1 M+ r& L28-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/ t$ b5 [# T) E* W* M4 b4 r
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64, ~5 i/ [2 \+ Z; I/ A5 e! ^+ x
    1
    8 s/ g& B6 `: }' {9 r/ A3 A2
    7 k+ I' ~* _/ y  @7 \& ^0 _1 i  h3
    5 o! D% _( C* g% U# L( K可以看到打印的日志已经和当前时间相同了。
    8 X: {$ d8 w7 `! |
    & N# l& k, G/ \/ J0 r8 {9 r五、说明' X6 h& P7 w5 ]$ V# D( p! I$ a. o

    - G  m/ p: E6 T" f5 p为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    0 m5 u& n: ?8 @+ U. m7 w" t是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    $ V5 c% S0 q) \& {/ o3 S$ E5 B7 C# n2 M, P
    六、参考
    " S/ g% }" z9 n# z8 i- l
    6 y( C1 ^8 Q4 z2 f7 d参考文章  l/ R: @8 a3 e8 v( Y  ^

    & O, p  I" i! ~$ {9 i" X总结- @; a6 J) W4 G6 Z- @. q

    9 V8 N: V$ B4 P- i4 p, w% V时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    3 D  D8 p5 ]% M2 p' Y( x————————————————
    - }/ u* A: ]8 a: q; k+ R- z0 Z, P) C0 f版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    % o$ W/ @; t% j5 Q" M原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    : |# B% f! ?6 ~5 ]- X- X+ L
    0 G7 ]( F- J$ T9 n
    2 l0 l0 Q; @' c+ l% M- F
    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-6-8 10:37 , Processed in 0.543174 second(s), 56 queries .

    回顶部