QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5885|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    / N7 b  k; X9 U  l5 M9 d$ j/ N; \前言" o$ b4 p) L+ O$ S: }7 a. \% g
    ( R4 y6 M* f5 e2 ?$ F) O
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    " l7 Y1 ~- u. o" k" h3 X! f; ^- M# b' a. l
    关键字:Linux、Docker、Tomcat. G) [0 @) N5 V. Q2 q) {: u& s; ^; E
    ; V3 g) l) I/ O4 V1 O
    一、问题重现
    " Y" ]) o+ j# |1 Z5 P2 U! H
    . D, F: @, U! C5 W" x# P" V+ o项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    % D* _/ d8 P) H: w" [. t! k; A
    % b: i1 W3 a4 \, h2 j[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    1 N, j6 {! c8 |( g; k2 K; c7 C# 打的日志上面的信息会比当前的时间(北京时间)少8个小时9 [# x- b; A/ ]: k
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]$ j/ l# M. }4 C; _1 ~( x
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]7 l3 Z  i8 W3 s9 a
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]4 b# `* b1 P. n' w0 Z/ ~2 |
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id+ h5 @  m' v9 M5 D0 d
    Thu May 28 02:50:42 UTC 2020% n. U/ I) ]' ], G& r0 A" z% r3 \
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间8 I8 K$ A# ^% N, O! R
    Thu May 28 14:19:38 CST 20208 \  s( B/ h& n5 Y, r6 A
    [root@iZh4ntc7dmrvkzZ ~]#
    ( \/ A3 ^" |0 c/ u6 d1
    ; \4 d; t1 f" d4 i  s2
    0 H( F" f. q$ q" o5 h) P3
    4 B/ D$ H/ P+ }. e  G& Z4  P7 I/ n/ I3 @2 p) H/ @
    5. [; {9 I# @$ Q" O  o
    6& Q$ R6 N' I9 \
    7
    7 {. H% I+ z' j& F* _% }8  c8 g% T; \8 }# m4 y8 U
    97 l% @1 O1 O( Y" B9 o
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。( K+ j* c) @' N/ f3 D- G" q  V! n
    * [6 j4 a6 M! j1 Y' w7 T9 f  S% r
    二、分析问题
    # ]- J  e9 ~0 g0 \! I' d  F; T% @6 ^, G
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    : ]  Y  A2 b' {3 M- ]4 Z+ e# N, B# [5 m5 e0 T4 v
    三、修改 docker 容器的时区
    ( e5 \. i7 f; E7 |1 ^6 i* `3 I5 ~: S7 B* c5 j" K4 s: K
    1、进入需要修改时区的 docker 容器
    ) z# O+ t, g$ G- a5 I1 g; K, k1 A# y; w3 p; ~) S' V, H
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash/ w. L! z$ c' A5 Q- B1 o7 Q& L6 F
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹2 S. A) C2 m( Y' i! ?) H* X
    15 W7 z$ j8 A( W8 {1 h
    2、复制上海(Shanghai)时区到 localtime
    : I( V/ p+ Q& N, n! t
    / M% ?# T; z. P5 k0 j4 N9 H* O* Jroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制+ K6 h$ d! y% K% E* I. @
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器0 Z$ }6 Y! @) M8 `6 z8 A) k6 `5 q/ N
    exit
      `% W- j+ e" E$ J[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    ; x) a! U  A: x2 S965abb1fb546
    2 s0 i5 n* U' a2 r0 W2 x" Z0 `[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了' A% ~7 O. o9 ?* I( v/ W: C
    Thu May 28 11:12:12 CST 2020
    2 E9 |- W$ H# T' b: W% ^+ B7 y/ N1% a/ o) t0 |* m+ d5 h' x/ ~1 q$ @2 V
    2
    * s7 U0 l+ w7 t1 J9 ^38 N5 z/ b* f$ l! C4 [
    4
    ! O6 J0 d8 q8 q" i2 x( P5
    ; T& k. q" s+ a1 N3 h! o, ], ^69 d1 I6 _8 S5 @, K) [1 f
    四、验证(重启容器并查看日志)+ Q3 s5 F3 z- Z7 ^7 z: b5 k3 u- q

    & g$ _3 ]" p  r: Y' n- }' B[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    4 c4 {7 H& H1 {28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    ' [5 ^' F! B  U: C28-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
    - V3 X' m. T6 p9 ~; F28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64: }+ W# Z6 L: |8 ]
    1
    $ ?% [, P; Z% |4 [2
    : K; T: L. H7 z2 c: L% v6 [1 g$ j& G3/ Q. P" x7 T! D0 M3 K
    可以看到打印的日志已经和当前时间相同了。
    7 W$ \7 B: M2 O
    # ^: H, ~/ F# b) R五、说明7 B/ V6 d$ |' m: g

    7 `# t: v9 m" j* K! y; _为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    ' @6 J8 y' I& R! V8 o是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    . O2 F- y' j9 j) \9 p! E& s
    ) v1 I! m5 x2 A  S六、参考
    ) }' Z* f8 a' }5 G
    ; {6 \1 f0 x4 U/ K- i参考文章: R! K# `& R+ `6 B5 j" X% D
    + W* m8 U! m) F. x
    总结( r9 ~) q3 s' O1 W& r2 u1 A# }
    . h8 R* d- {! O/ }& k7 t# ], K
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    ! b1 L4 J! B4 U% V1 w; G, A————————————————! u2 G  ]6 y6 Z7 [- g
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。, L8 W, S- ?/ v( \6 O
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    ) P" f$ y/ Z; c9 i3 Z4 R
    % L; m) G# l6 s0 R+ z
    " w, t  [! C* 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-6-8 21:25 , Processed in 0.453076 second(s), 58 queries .

    回顶部