QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5851|回复: 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. U1 l" k' a# _4 {* B+ k0 j
    前言* R# I4 s5 }% Y( K8 G, B5 G- ?
    # e& J* ~! ^4 \/ J4 L1 [4 [
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。1 m7 u% B$ Q. F

    / F2 |/ M5 [" ?  n关键字:Linux、Docker、Tomcat
    , s) `) g* X# G, @4 z' h* w& Y3 g  B+ u, `% ^7 v
    一、问题重现
    : X# f- z1 ~+ c; Q$ _( ^- h$ B% k$ a- a* G+ c$ p  @, u! M% I
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    ' c8 N6 N' T6 o% P; Y
    ) S& w# L3 m3 S9 ^* j: R[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印), l; ^+ d, Q8 g9 T) ?1 g
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时, I" O6 d% q8 m- A
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    4 ]/ Y& @; y4 b( Z: Z) s. G) b( c28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    $ k9 m  D! Y$ e28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]7 @: V  M- h8 k. ]6 `* Z9 P
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id5 d4 [. V: f  W
    Thu May 28 02:50:42 UTC 2020
    * u- r4 G3 n2 v( ^' N+ C1 v% H[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    1 G, U. P5 }* G6 s# qThu May 28 14:19:38 CST 2020! V7 R6 [- U$ J( d0 o0 @( V6 c
    [root@iZh4ntc7dmrvkzZ ~]# . {8 \0 B" J# l" b- ~! W* |
    1- l( X* b0 s* g4 s# B- V
    2# W, A  z+ L/ {) [0 x- K
    33 Y8 H+ S9 U1 h) s6 u# G
    4
    % y, s+ H8 o! g0 n0 k50 I9 o- X. y& |4 u7 ^5 r: w
    6+ ?! v& a$ t: T
    7; D6 T2 J1 d, [" @; ]( P
    80 N/ s  j$ [; \( ~0 e* g
    9$ R- M3 B/ G4 L/ c
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    6 h! S* K) `3 j
    # }  E, h! y) n( q; E, q3 ~二、分析问题
    , s; U; z5 C/ N1 c2 J2 N- s% z, A& E: b0 M* C. s' ~- [
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    7 b% z# q9 ~3 p7 P- e
    6 P( `' ^0 ]$ M4 q三、修改 docker 容器的时区
    * A: `0 x* R! K" Q! l/ E
    ' O/ }8 F, A* W5 e8 L1、进入需要修改时区的 docker 容器
    - d. P2 s- r1 ^1 }/ a: d' U
    ; e: p0 t0 B# E4 q9 f[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash% Y, g% g3 U# B' K: H
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹7 f7 }+ i* l; _& K
    1+ E& }( t$ g6 P- f# V
    2、复制上海(Shanghai)时区到 localtime
    " m' D1 ?. Q6 s7 Y+ _
    / r) _8 `. n" g& M9 Uroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制0 a& K" ]1 X% i5 ]6 u& O" R
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器: M, U4 G- h* d( ~& u/ \- o
    exit
    : x. S) U, U' q5 k[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器" o7 O, B+ g  r* {
    965abb1fb546
    1 Q- z' k( i( Z: d. Z[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了0 `, ~3 G: M( w/ j% u
    Thu May 28 11:12:12 CST 20204 N- b! W( ?8 l3 y
    1
    7 q7 f: v) R- f* S5 w! o; {# Q9 b29 U6 K& _* J" l) H3 L
    3
    % T! R* X3 O3 U9 T6 a. |: T4 M4/ x  X8 N2 l$ z- [8 L
    57 I' |0 R- Z* ^7 T
    6
    " k( o7 }0 z3 W3 G四、验证(重启容器并查看日志)
    + `" r+ v! {4 d6 w" |, M3 i; {8 k0 x" c  F
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    ! z) i; n0 E  D6 d  `& p28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    1 V, V0 {* |) b. L8 J! ~3 S28-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& j3 d5 }! @( t0 ~3 G  y
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd643 j; j6 |5 Z% X4 i) z6 C/ r
    1  k" ^- r1 z/ J; S
    21 a: L. @6 v7 [- C* Q* R
    3
    ' E* H9 x/ Z9 I1 N" I4 y4 y* f0 G7 B可以看到打印的日志已经和当前时间相同了。  v& Q* B/ O% l
    4 P: G4 C4 @/ ]# X7 O: y! X; B
    五、说明
    7 }9 _4 k* r' p  g$ z' Z+ H- @: e
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?2 q0 d: M- z6 _
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    9 E3 ^# N" _! h$ Y& d: d( }9 E: _% y, M- G9 d: y9 t0 Y) y2 ^
    六、参考
    ) k* S0 F% [2 b3 `1 q+ j3 Y) ~6 H6 u& N1 E2 t! d( p. y) W9 X
    参考文章
    + S! S3 U( E# i+ X" ?7 _) E- Q/ h+ L0 ~8 w: s
    总结
      C- O. q! a2 f: H1 a
    " @/ v9 L/ E2 A' v1 A( B时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。' d& N! l7 _/ U  v$ C, t
    ————————————————
    + A' }! q/ M* D* {! t1 A$ |版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ' ?) v$ ?$ B. O# z$ z' R: k原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093$ K+ K$ t" `, h- Q

    2 o0 K, }0 j+ i' X4 S! B
    $ ^( P  }* _& v, L# n
    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-21 16:03 , Processed in 0.436174 second(s), 56 queries .

    回顶部