QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4587|回复: 1
打印 上一主题 下一主题

Docker 中时区和宿主机相隔八个小时的解决方案之一

[复制链接]
字体大小: 正常 放大
杨利霞        

5250

主题

81

听众

16万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-5-30 15:21 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    Docker 中时区和宿主机相隔八个小时的解决方案之一- i+ r% U0 Q) @/ b' b
    前言- d0 @. @" J3 D: t; R
    0 D9 y3 _. |5 e: g0 `! X0 Y
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。+ [- ^5 O! g3 |) S+ L( v
    ) q+ H/ m# G. `6 k6 t7 Z( [
    关键字:Linux、Docker、Tomcat1 i. V1 D/ }6 p, u* \3 c
    4 d6 W0 U/ x4 `! W& o3 W
    一、问题重现
    $ g. L) y4 t1 |
    # ~# d0 ]8 ~$ ^+ D项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。* M" `, B2 o+ ]0 n/ v, B, }

    7 R  D0 s9 \5 X. q! Z3 E5 ?3 ~[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)# Y+ H2 x: o* w6 ]
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    9 P  ?9 n) K6 V/ O7 ~5 W28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    2 G: d# @4 e; i( |. G28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]) S6 e( c) y/ c( N* R1 Q7 S5 R* ?* |
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]5 R9 A3 T1 y( a: \
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id5 i. ?3 f8 T. L
    Thu May 28 02:50:42 UTC 2020+ d9 X! `6 \7 ^% f% Q
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间6 I3 ?6 f1 w! x7 V2 T7 M2 }
    Thu May 28 14:19:38 CST 2020
    4 o* d, J  d+ [, n8 {& c5 d3 _[root@iZh4ntc7dmrvkzZ ~]#   m: l' p" I7 Z2 t6 D. r1 g4 K: B
    1
    ) Q, B, a# U$ M& E5 k+ r2' y: ?$ b1 l+ ?+ C3 r  E  O) T
    3
    + n4 ~+ m" z; G. ~41 \( w5 R5 Q0 E( |; t. o9 R4 r" `
    5( g- P7 T. {0 [! m" ^& g
    6& @" d6 S) L; P9 r, @" z
    7
    . L' N* A) B2 Z2 U5 J8
    $ _$ C& T6 v; u- M' T5 T9: V' P2 h9 H* t$ B8 I2 u
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    : w1 ]( J: H% X# D1 Y) N- x
    % S0 D+ F8 t5 F( T# K二、分析问题5 V$ c5 N( c, R% g( N$ V, Y5 v

    ! {. a) U. s: C刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    5 ^' ^2 R7 o* p) y1 Y. ?3 N: t% z; }' w2 `) K( f* W2 P; A
    三、修改 docker 容器的时区
    $ `9 P. l& Y9 T0 T4 i0 _0 H. t9 c3 Y. k% G; l
    1、进入需要修改时区的 docker 容器
    8 N: i1 D7 q2 M6 K8 m' t7 Z
    ) ~4 h, }9 t8 C. _& N[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash1 [- t1 E( h9 j$ `
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹, Q% e" c  f+ W, I% d4 K
    1& H" ^# a  F% v6 Q5 i
    2、复制上海(Shanghai)时区到 localtime
    3 B0 h6 s1 ]) z! W, s3 j# s" y4 C8 Y' k
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    7 X7 p( ^% }$ M, {% C4 q- t9 Zroot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器) o7 x+ i3 n9 E7 W$ _/ q
    exit* z# e5 }4 c6 Y% b# v$ c) l
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    9 q) n  n2 K( B: s+ B" ~965abb1fb546/ t& P& ~( t, b; o1 ^9 n
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    6 V0 z# M8 D, o/ \) W/ B! yThu May 28 11:12:12 CST 20200 |3 O' {% |, N6 }7 ^  q4 @
    1
    . v& n1 ]* F1 M' I, }25 }$ h4 R, q1 C3 X1 l7 g) `1 L2 B& T
    3
    0 S* }9 x+ ?% j' c# g4
    # W( H* ~# O2 u. N$ O6 j51 ~* H9 L5 y4 n* S, P1 }  z3 R8 m
    66 f2 g- @+ k1 G* ]! G1 O
    四、验证(重启容器并查看日志)- I% m( p; d( x' K3 {

    & v, s1 L- y% o[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    1 g# F( R6 y- v: \4 L28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    - e$ H7 S/ i2 T) e& ]% u8 p28-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# }$ U" E8 Z9 f. v) o! J: j2 ]( [
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    7 }- Y! @. \, S- |; w/ Q. h1
    & A4 T7 E3 {6 X  f& b" b% o$ H2* s: T& v/ O" }5 c2 j. @& B8 p
    31 G8 _4 F" F. k! N& Y
    可以看到打印的日志已经和当前时间相同了。
    7 k' V  A+ V3 |& i5 y- U
    / L$ q6 y# S8 D8 d9 d+ D9 B五、说明
    % y7 f: Q( T, H
    5 @6 ~, U3 H% H# w/ F为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    8 N2 e" u  {/ F! F, q是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。2 b- J! d- e; |0 [3 z  p$ d* G

    : Z* H# v, b& F# [- \. n$ Y; M六、参考
    5 }) s! M# ?+ t/ \6 r$ |  a5 M3 L! d+ g0 q- S
    参考文章$ g& x; a$ e# c( A' N6 C6 W

    2 i$ d0 r5 H9 K总结3 a: ?' n0 Y- c/ z2 _
    7 K/ [5 ~9 E- i* ~4 |/ z1 j
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。# z9 G, E7 ~& j) L) A2 L
    ————————————————
    $ E. K4 c& L) p! f1 i& s版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    $ A. k% I  [9 l7 v$ x7 `& `原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093+ t# n4 L7 r& `+ p1 m4 m

      s9 d, P& f! L1 t! V7 _5 b& D8 X% M1 o, z& F9 c
    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, 2024-4-19 23:19 , Processed in 0.426201 second(s), 55 queries .

    回顶部