QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5884|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    ) n2 R$ ?" z4 j9 @( G" R3 r前言& M" z9 j  i7 F( w

    / a/ R) Q7 {! A. v4 [项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    + _- U' O" D; r0 v7 v, a- \
    . o, W: x3 k  F5 g( Y3 a5 R' L7 _关键字:Linux、Docker、Tomcat
    - I$ d' M2 K9 b: A: Y: Y! @+ L& ]( K$ @# ~  C3 ~/ H+ U2 A/ M5 B
    一、问题重现
    6 {) [7 m) g! |* h1 R  @' i$ h4 F' @  q+ z" n7 S! R
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。( d- J* ]9 ]3 v8 }* W
    5 X/ }' b: `, S% V1 w
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)) g  z% F1 }8 \0 i4 @9 q4 g3 h
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    . b, h8 ]& S& E28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]) A" j- i) }# X# K2 }, F: N
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    1 o, i/ d: D6 Z* t9 c$ L( x28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]' _1 a1 R$ I. H1 o
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    ; Y, v2 B# F2 T1 q1 MThu May 28 02:50:42 UTC 2020% _8 U1 I# w' O0 A! h4 B
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间% @+ ?6 U1 _3 p! c4 l; q8 Q8 v
    Thu May 28 14:19:38 CST 2020
    6 K2 A! g1 @. K; Y# `* O2 [4 x[root@iZh4ntc7dmrvkzZ ~]#
    ! t  g$ m1 y0 z* u1
    9 B7 X& ~1 J, x6 h2 X+ p2
    9 L% C8 Z0 U$ h- [2 m  `3
    ; {; \$ j: @, G5 w  o44 y2 P% `8 ]- z! z7 Z
    5: u  {: I* x5 l# t
    61 o, R# s5 R  e4 }( f+ O% N
    7
    & M) c+ }6 h! y. z" `" k8: F, f* A' |5 z( F& h
    9; |* B1 a4 C+ J7 i2 l$ H' j
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。4 B* C0 q& }1 N( I% M

    : b: Z9 i6 w6 j. a二、分析问题
    , k$ r2 G7 Z# f: Q
    / ]- z! s# t% o, @/ W刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。+ A$ o1 I6 i9 q$ h: r0 h) V
    3 ~+ [( A& o3 a" p  j
    三、修改 docker 容器的时区
    : N9 S; `& s3 Y# q9 }/ p
    + {4 N( P! _& T6 h1、进入需要修改时区的 docker 容器7 {  k* C; O8 J- j$ X+ N  p) U
    - b; g# d) r; e8 R. a% P
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    7 @! x0 U& A/ T* d) X2 droot@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹& M" j: {# N7 i) o. c: l5 M% @
    1
    ( p4 v2 ~2 }( c) J& D8 d4 O2、复制上海(Shanghai)时区到 localtime
    6 n! a% n6 G* N0 L
    ! v& q. ~) U+ F. @9 Iroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制+ q- }4 V6 h' m
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器. a" ?; X+ ~% S; [- X
    exit
    8 Z0 p! t+ g7 J+ C" O% ]4 ~* Z[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器+ U6 P* s; R) L  x& J9 h
    965abb1fb546$ ~& ?, O% c% S  w7 Z
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了' [$ W0 ?* e' K1 t* L9 F
    Thu May 28 11:12:12 CST 2020
    $ D8 a6 u+ T) m  j7 N, B1
    * y8 f- I3 j! h% ?2  L8 H$ w1 I" m
    3/ E  `1 X$ g" I; k% K) `
    4
    " J% y. g& m/ B; ]  Z5
    : l9 ~( |8 F2 ^! ~: }. K6
    1 z# u, l  S! @5 u. s1 n+ L3 D四、验证(重启容器并查看日志), g. N, z9 h2 O! t

    + n- `6 c% [, c0 |, l4 M6 S[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546! S6 B% F" V( {: ?4 k
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux3 K; X4 s9 l( g( m
    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
    6 }$ z8 G' Z" o4 `9 s3 {28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    $ M: E* W+ h+ p1 H6 @: C1' i7 x+ t  K4 O# K% ^
    2
    6 X! Z7 Y; D/ X3
    4 f* P2 e# q/ D1 c7 c可以看到打印的日志已经和当前时间相同了。2 ]) ~8 v, o/ D* U0 w: x

    * m. W% L% S* O6 u五、说明( l5 J* b: b% m
    % p) n) n) s& n$ I% W0 N
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?& D6 M! h3 W0 V5 X6 v
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。2 W4 c5 a- E7 \0 E6 u  x! X  e- v4 i
    & J( ?- d) B- l1 v6 o. f/ [2 ?
    六、参考3 @) B: {9 ~* ~/ e0 C5 c6 R
    $ I4 F( I. d% A* r: @# }( G/ R* G" R
    参考文章# z! O, f5 g  D& ~  L" v- [! g

    4 z" e' g* I! _& l总结3 K& d$ h$ y. E5 B

    - q2 @- q$ v9 n4 O& W. d2 U+ Z时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。8 h* U% w& w" \1 i  c, `
    ————————————————
    ( C9 I* j; W/ j9 Q/ g版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    9 }) m4 f+ S# z0 X/ [3 n原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    + Y$ J2 E9 P6 A& i8 N" M0 m
    9 U: h8 I  {) J. ^  ^8 z/ u- ]+ u
    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 18:16 , Processed in 0.441634 second(s), 56 queries .

    回顶部