QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5842|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    ( U& ?9 P0 Y& i6 j# H前言9 a# Q+ |7 N* o% ]7 z3 n" ]

    ' y2 Y0 A" y1 k9 h4 q. D. P/ ?项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    6 N2 @1 P, o/ Y# E4 d6 n8 n8 }# h6 E& g$ p' J3 t- D  ^7 C
    关键字:Linux、Docker、Tomcat1 `1 i( Q* S/ I- S
    / n9 C" \0 y* t9 C( r
    一、问题重现
    # r8 V" _* g6 }1 Q
    4 {, o% O- P# g4 N* k6 S项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    / M" ~3 ]. P: L
    ; M6 P! Q. s) O5 e0 @: T7 H+ ?[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    $ h0 k; u- m4 \* X8 ~% X# 打的日志上面的信息会比当前的时间(北京时间)少8个小时  H6 \6 S1 |$ @+ N8 {9 h
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]8 A3 J1 ~9 r( }# Y* j4 G- s
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]  V+ T+ G! n% E7 |5 \% H
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]$ {4 G3 N- b' [# V
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id! q$ T  ^4 W' X3 q6 \' z
    Thu May 28 02:50:42 UTC 20200 Q3 m$ ^" O6 ~0 S# w
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间% M2 v/ |- o; ]
    Thu May 28 14:19:38 CST 2020
    4 S) C- N+ g$ a( @  q[root@iZh4ntc7dmrvkzZ ~]# " m8 l' b. H3 b4 z4 C
    17 z0 U9 n" D; V7 h4 V1 C) s, q
    2
    ; e( O/ H+ I7 o: x: B; s% H3
    ( ~( J1 U) b# |* G40 D* O: _8 T- }1 t- C. A5 a
    5
    ; h: \8 J( d7 A66 K  F4 T/ I' `1 {
    7
    & N# j/ A$ ]8 b5 U  c" \8
    $ b9 D9 B$ X8 @+ X9 @  |90 v) t) j* t( {6 r* \
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    0 D/ Q! B, h# J) C" j, c5 g
    ( c1 `$ V9 ]4 Q二、分析问题
    0 J1 {% C2 R* z, o3 j$ A3 r5 W
    * l  a1 ~- m( K! |, B! s刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    + S8 R5 g- s; p" X  b# V* t
    + f& P, M: R1 c/ g9 q5 U  W三、修改 docker 容器的时区) S& g9 E& O; K

    , t6 T* y- w8 K9 q. a1、进入需要修改时区的 docker 容器4 Z9 c3 B5 a: T* U  C; U
    7 Q( Q' |/ n# ~1 L4 \# \$ S
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash5 c  R8 j/ P  S6 s4 x2 C  Q. Z
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹1 E; q$ W+ b" ?4 z& w  U
    1. p, X$ [; r7 R2 _$ S  U: y
    2、复制上海(Shanghai)时区到 localtime) I" }/ I% I. b+ e. k

    3 ^! @1 s0 \$ Z4 m+ f, Froot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制& B7 z# \! J+ b8 N( ^  e
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器5 l+ `; Y- L0 B
    exit) t5 ^1 i8 Z7 D; {4 a) {1 i
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器: t+ {0 A* Q5 \6 `; s
    965abb1fb546
    4 x0 s( x/ J) _0 T+ W' M% u! \[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    0 ^' J- J9 {# V+ z6 WThu May 28 11:12:12 CST 2020) l- H6 z' n- _1 z$ j
    1
    2 E: p: t1 S2 o- {4 _2# Q# [0 I  l6 w' @, q7 i- ?5 x
    3
    ( ?) v6 Z4 S( M8 a/ P. Y4
    - _( F6 v1 J& N54 |) L: J' _$ j  ]" Q& O9 {9 g
    6! Z9 w. y, @8 x6 b7 R
    四、验证(重启容器并查看日志)
    % [: g3 C. b. K: U2 I+ n9 S& f+ }2 a8 C1 R
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    ! t' \$ Y& D, b8 P! A6 _2 ~28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    : ?3 g* ~$ ~! O28-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
    9 Z8 K) ^( }; O, }28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd646 r3 |; J+ z" T2 C3 B$ o& x
    1+ f0 S$ l! W3 T. }% a+ ~
    2
    ; a+ G& r/ N, a! S7 {  `- i: l$ B37 f7 W/ A" O; P1 b7 ~2 M, A3 z- L
    可以看到打印的日志已经和当前时间相同了。
    ' N0 V2 c' |$ k6 k  d- n- H9 d1 W- I# L. ^0 N& F$ |9 n' e
    五、说明9 B8 m  k/ u) l! D2 _2 _. E8 [& s9 [
    ; s" s' A% U3 ]' k1 U
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?1 d. f- P" A8 G! D7 k
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。3 f2 N. z$ _9 O' s4 q: K; `% ?% q

    " h6 U5 W. U( H8 N  \六、参考
    1 y' i4 P1 L' ?# P7 j
      V4 A- l1 ]4 \* U% v% s参考文章( P+ v; `, j/ l3 i# X& a% w  D

    / ^  d3 Z+ l3 a. n# v1 b, ?总结
    8 a7 u4 h) B, f4 x  \' O1 L7 f5 X3 w5 ~& S
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    2 C  K, s. \$ g8 x& q0 W————————————————# N' V9 E1 [0 e0 g' d
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    9 Y; H9 \% }! o# X; z1 Q原文链接:https://blog.csdn.net/weixin_42816285/article/details/1064030937 E8 Y( R1 F. Q, ^" d) [; T
    " }5 s+ v& P# {0 l9 T. c

    4 }& r6 t* O* S" z6 Q: _
    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-17 22:37 , Processed in 0.492950 second(s), 55 queries .

    回顶部