QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4597|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    6 z/ p! g7 Y+ v5 a7 j% A前言% g3 ~+ `. H7 m8 @8 y
      I, u( S# |$ O" \& q
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    2 H& `( W( I% k5 H. a& [
    ) D; N1 E4 n* ]( P7 [( o  d关键字:Linux、Docker、Tomcat3 E3 y6 J% Y1 b
      O7 ?& d- N0 n+ p: |
    一、问题重现8 A: F$ w& z+ y$ R  V4 ~. J
    + r: h# A" L: o6 a5 U5 _/ P: _
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    % _+ f6 |2 \0 \0 u# H! {# B. p
    1 S3 j- Z' R# ][root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    ) E- z# V3 c+ u% a# 打的日志上面的信息会比当前的时间(北京时间)少8个小时0 @' W# C8 H- O. M6 n% A) t6 Q( s
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    / w/ W8 ^! S1 h28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    , O' G2 n9 E6 j$ J2 h; _28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]7 ]2 L/ P! R# s7 \2 \/ s
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id4 r6 K* F5 ?* |5 U% ~4 I2 Q
    Thu May 28 02:50:42 UTC 2020
    ! y. A' o6 ]5 ~4 ^[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    4 P8 N. v4 R. H0 K1 S9 hThu May 28 14:19:38 CST 2020* M- f5 k. n- I/ [1 ~" L) u9 v# Z. ^
    [root@iZh4ntc7dmrvkzZ ~]# 2 D" m7 x6 Q  S* m) T8 u
    1
    # E9 T! U( n* X1 D. e  z! s) _27 |$ W( u5 {4 C+ }1 ^
    3
    7 `5 N9 J0 G5 k  p6 W4% c" ~( f3 \: Q
    5
    ; ]3 W6 z& z" s& r0 a8 j9 Y6
    ! m. l# ^2 I$ a9 r6 y# L( H7* B3 m% i! Y6 \2 {( a- g
    8. v3 T1 B4 r5 F7 p* h
    9
    3 C9 U* N, |' U明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。/ ~1 L5 t7 F" K3 ], x. A# v

    / U  f/ s; [6 X二、分析问题% D% n4 e+ W. w" ]
    " N& h' r; O# |8 O& p3 J1 _
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。& M, B7 X5 d/ I* @' O5 S
    . `5 x% H- f0 C$ m% U4 P' D( Z
    三、修改 docker 容器的时区; q% g8 h  s% D7 u

    1 s$ \+ S9 J. l% _6 s, _1、进入需要修改时区的 docker 容器* ~1 e; A) V4 O; w6 }: m( @
    ( s  W' P" E  Z! j# R5 a: X+ M
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash& [, l5 p! A9 O/ E, h2 h' O( Y; q
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    7 B* h2 f8 f2 L6 i( z- L" a' l18 Z" \' P, T9 j4 G7 m
    2、复制上海(Shanghai)时区到 localtime
    ! K4 _+ E! o; o; f3 m% _. M
    7 M  d3 {+ ^, P3 ?root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制4 E3 \+ z5 I) K  P' U' [
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    6 }) B5 Y" \- c/ H& @" ?exit2 G# R: Q/ x: k
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    . h. i6 o' q/ A' K965abb1fb546  n9 I+ W$ T7 G8 n8 a0 t) `: p; C
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了! x. r" F. Y# H( Y. @. h
    Thu May 28 11:12:12 CST 2020
    6 n; u' }3 E! s5 f: ?5 t* L$ p1
    ; h4 b. B0 u) o2
      E0 N; |5 ~2 ]' Q3, S' H% d. N8 b$ e4 O8 o1 u
    4  g1 ]: k/ J, |  M* V6 ]8 k
    5
    / r  ?" Q7 Q4 {2 \3 J3 v6
    * U) K! R  y  \& t四、验证(重启容器并查看日志)5 g3 z# b2 f3 A

    ( s9 t7 Q9 o7 b' D6 G[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    ! X+ g( ]7 `' h# b0 ^% t% h$ A' t28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    6 I" E3 T" P9 ^9 E1 R9 T5 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
    4 S/ }- u- G- g( d" H28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    ( Q" ~  F) x$ B$ }  ]8 k. K18 h* z; y% B! K
    2* B# I  j" w, a* F; V
    3
    ; T! `2 q; U0 I+ D可以看到打印的日志已经和当前时间相同了。( [% q2 F9 m- @6 z; x8 V

    ) Q. p4 b! y4 z& ?% X7 W, k( W7 _五、说明# u, z0 v6 ~; t5 D; f

    " P4 E; r9 k% x" a( }, I1 _3 p为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    ; Y$ x, L9 O; l- v' g( x; w是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    ( Z5 [, J2 b- f' G$ ^$ o/ ?: \- X  o4 G0 ?# N5 _, q
    六、参考
    . y: N0 T$ G* ^
    ! E2 l% @# a+ T- M/ N+ r- Q参考文章
    5 n; c& h+ f( V
    1 K# y7 h$ C- N7 C+ T总结7 S% {7 E" ~4 g% Z1 V3 Q. s$ I( o

    2 b4 B! z  ?( [8 j时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。3 r. }. H, E5 Q% f# j& B# l
    ————————————————
    1 Y( p/ |% o+ m版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。, j0 O) Y. K# }' v' Q! f: H, H- Y
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    ! C3 R# [( D8 [8 @, H& q
    + N1 P- K& \  a: L# H) H8 N/ o$ j* P7 l3 j* n+ E! I4 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, 2024-4-26 19:21 , Processed in 0.430363 second(s), 55 queries .

    回顶部