QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5548|回复: 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 中时区和宿主机相隔八个小时的解决方案之一" Q7 U. I' i% ?# d7 L
    前言! F" v3 s6 B% S) u0 X" Z0 ?. A

    ' ?3 m; [. i- O) B3 t( N项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。1 x0 V( Y2 O! R$ k
    5 [2 v1 M6 }6 q7 Z: l0 w
    关键字:Linux、Docker、Tomcat
    # R& Y) b4 K, |6 f
    2 {& k& |2 K: K+ D一、问题重现
    ! p  w6 J4 J3 n' v5 G* ]# B  y9 D; O! R' l+ E' K' J
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。" e' l+ X0 A  s: @6 T( f
    ' a6 a, d8 k8 ]
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
      V9 M! S; S6 M' x2 `# 打的日志上面的信息会比当前的时间(北京时间)少8个小时  P( z+ j  T5 O4 P. k
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    / |4 ]8 m( V# a4 b3 I: ]. E9 M28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    / ]4 _4 {# r1 ]0 h' @28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    ' ^: p/ {# K2 \8 c[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id. y% V) P( M6 ]4 V$ ]6 N) ]2 Y
    Thu May 28 02:50:42 UTC 2020( l$ z# M. g8 I6 W  v" j7 z
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间* E( |) C6 \* a3 q0 D$ s
    Thu May 28 14:19:38 CST 2020! ~/ e* Z: b/ z- Z
    [root@iZh4ntc7dmrvkzZ ~]# 3 F5 S3 w  V+ O. T! a
    1, h8 d4 o' I) K6 U/ ]% O2 L
    2
    5 f$ t: g  x+ N8 x2 G0 n: m% g37 N/ \6 h, I  z. A4 i
    4
    3 N5 A$ z' x1 O5( J: W- E0 S& i0 s% q8 S) h# `+ X
    6
      Q) s, |/ R$ |5 n9 o7
    # v+ n) K* X' t2 a* D7 ]8
    1 Y; Q  u1 E  u$ V" U" ^9
    4 u% v( ~; z  |. N明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。, }/ m+ N0 \# R" v

    0 a/ @; M0 ~' r9 _: `$ w二、分析问题0 o5 `+ c4 ?2 \
    % |+ O; Q) v. c4 T3 f2 W3 D. ^- S
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    1 [' B) X$ G& f! ~6 S: w5 E3 }( Q1 a6 `8 u4 f
    三、修改 docker 容器的时区
    1 L( d0 C& Y7 Q7 _8 E. L3 A5 ]7 ]# m7 y  C6 ^) A  w' }
    1、进入需要修改时区的 docker 容器
    + H% E/ |+ U7 w# N2 O! C
    % U/ B# \( X3 j[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash  a" l/ `1 j& g- Z9 V$ N6 O' }
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹5 w7 Z+ Z6 P, g0 a+ _9 r
    1+ ]7 i' ]. |1 @) S2 |
    2、复制上海(Shanghai)时区到 localtime" A' l+ D! q+ e2 D2 t

    3 _  {* E# D( y! P* c& ]+ F4 E3 g& T: Aroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制) g# {: }1 U# l& o; k
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    6 @" L7 G3 `0 fexit) h0 S0 O' O/ r4 A7 @. A( ?4 h
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    " }0 S! O$ _: ^2 j( U- g965abb1fb5465 E+ r7 Q- V0 r: z6 {
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    . R9 T5 `5 z: N2 I0 ^; EThu May 28 11:12:12 CST 2020
    % X& n1 Q% t  B, f; T) Z1
    ) x5 @6 }  J- F2
    2 P6 j) P) I% X4 K39 y. ]1 u: K9 p9 R: Y% g- P
    4- ^6 r* c0 G! E, F) }% B
    5
    * z% N+ F/ N6 |6
    ) b. p+ A# ^- k9 Y/ X四、验证(重启容器并查看日志); n6 @6 }' X- Z7 u1 l

    # j$ Y" j8 r8 B[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb5466 q2 W. i) B) U* N3 H: h
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    ( v, r4 H0 ?! X5 _$ W28-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: j" n( X" ?) Z2 `8 S# O" r
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    / J+ ?7 c" o3 Q2 a! }5 \12 c2 i2 ?" ?( a& P
    2; {. |# H) H6 W
    33 q* _/ J6 j8 c' U* k1 M
    可以看到打印的日志已经和当前时间相同了。
    , @' a4 Q/ X5 t0 ^1 M$ I
    & ~4 U4 |4 \' d8 o五、说明! g% ]) Q+ z+ U+ C+ L0 H
    , b0 k0 K# m- N2 O% Y/ l& o
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?4 G7 y' h' n0 K8 e) G+ M% f
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。" E& X1 t, p, j: V$ ^

    ( O+ y* w) T1 d2 Y4 ?$ [# b7 C( D六、参考
    2 S4 S8 y+ M* [) j1 V; g' l+ j& I- \8 x+ R& R; `1 }' O
    参考文章
    7 y: y. f4 \) f8 c6 ~9 ~+ P+ H2 V
    ! b- B# M  b0 o% r3 s总结; Y; j4 D! a: T
    / f% }2 N# ?' y1 i9 z% F
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。& `0 X2 t" ~8 Q9 p5 I  Y
    ————————————————1 P6 e0 j* z( z  q- x$ W: I: M
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。: T: H, l  |3 a2 q7 T0 P5 L
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    , T5 v$ u7 s' c8 F% t) {
    - p/ C) o( }, r' j, Q
    3 \6 e" v: p5 M. K" e$ C+ s
    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-6-28 05:15 , Processed in 0.634547 second(s), 55 queries .

    回顶部