QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5848|回复: 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 中时区和宿主机相隔八个小时的解决方案之一
    ! D7 K& r/ u1 k$ S! r前言
    1 U/ n" U) ?5 L) `7 X% \  n* {% c, t5 V" C: o, T7 L  E" h* ?6 o
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。7 O2 I- ]  _" ]( w! _

    ; i# ?8 y( E2 A" ^6 J9 S关键字:Linux、Docker、Tomcat
    & \6 D" D$ C2 _9 f; H7 I0 z8 P0 j; j" I2 J% u
    一、问题重现
    7 t* G. B- ?3 P
    - M) q4 M) f' S- D* z* D项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。* ^9 O1 Y' Q# t* ^+ z
    9 V, _! Q$ C5 C6 `0 B: ]
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    / x4 m# \8 ~% U& Z  e6 I4 J; Q* y# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    , H/ b+ b' G4 M7 U5 k28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]# W( ~& s8 M. a: E; z8 `0 l8 D8 L
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]% O, u# @+ p4 u+ g# b# ]& ^
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]$ d8 C. g  B  ]! c6 k5 `
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    + {  N1 @2 }6 @7 R  B) OThu May 28 02:50:42 UTC 2020$ Q4 y" z% J! R9 c5 J
    [root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    % V7 g' P9 C- B2 _3 wThu May 28 14:19:38 CST 2020
    . ?& r" S: g$ x& k+ d: D[root@iZh4ntc7dmrvkzZ ~]#
    8 q" X- t8 v: {1
    ( r# @1 @. M* C* H! c6 R2/ M+ M( l- x, b4 i
    3
    % {* o' ~! }' O; k# B) x4
    ; ~6 c2 Y2 S9 e5
    . x" c. H( ~# H( e; F! Q1 p$ y" ?6
    & _  d! E/ {7 |% b7  p" o; u! P3 R' D% e) l9 `
    8, _+ E4 ]$ a% {5 ~' ^# x9 W
    9
    3 @5 j1 b5 D5 d% \' ]3 u明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。' \- ~* E# o2 j0 n/ W' Y0 \9 I$ F' j
    8 ^* d: F" @7 j% J/ z  O
    二、分析问题6 H5 ?) d" O& ]8 m: c% G( |

    % U. b8 k. n* n& y& a5 h6 w刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    # P% r1 A; K9 A2 b% e" `
    6 z  g% t5 Q9 {6 t三、修改 docker 容器的时区: H& S# p$ G# O6 C: m: x6 r/ I" H& N
    8 l( N, n/ x4 J
    1、进入需要修改时区的 docker 容器5 N( v5 f% e9 E3 T2 _3 }
    " f/ J+ p! ^& t2 r
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash; z6 }8 w, X) ^: [6 L
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    ' i% I3 r" r  ?* p1. g; d; m5 q) C! P, K% ^) x
    2、复制上海(Shanghai)时区到 localtime7 J9 Z# u+ @* y( A) U* D) I8 C
    ( ?: e7 J" D3 B% n' N
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    % L+ k2 e3 _8 M4 V7 E6 d0 e( c3 K  |root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    ! R: X1 a, t" L- L; ?0 t6 n4 H! Yexit9 v. K* Q! ]! s
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器  u: p+ v/ h9 ]1 r3 j
    965abb1fb546
    ( x) @) u2 l! H[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    1 [+ d$ n6 y! [( k  W* R, `7 ]Thu May 28 11:12:12 CST 20204 d" M8 z" X6 u& |% e- a9 ]# I8 h
    1
      [6 |0 m, _# `2 i- }( E2
    9 T1 x7 m; k" s  F4 J3, W  S- h& X" ^* v
    4
    2 L6 q! C9 G1 B! [6 D1 T; A, I) A2 Z5
    7 _4 Q! U7 U3 `6& ]7 y- x. }6 Q/ [9 ]0 e
    四、验证(重启容器并查看日志)8 [; T5 S5 @4 f/ D; ~1 {& [

    ! O. _. q3 ~9 k7 f[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb5466 E* C2 y2 H, R6 ?' a% V" I2 s; K
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    2 H3 m6 C% {3 p1 \9 z$ f' ~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: Y+ @7 R/ C0 S5 y% x6 k
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64% u! \, T' p% g( s& z' `
    1
    * ?0 {. [+ e8 L& i5 q5 t" m2% O, s. C3 r! r1 a8 {/ i  P' v+ I: {
    3
    - P7 U# _2 |/ a$ L可以看到打印的日志已经和当前时间相同了。+ L4 i5 ^2 |/ _( p- S! \

      Q* k2 [# }! F- g- ]五、说明7 G  W/ u  ^; u; }1 D4 ]

    , A0 v/ ]2 j, ?. D# k6 l为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    9 J$ j2 |% P4 y4 P$ e! L是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    . q8 r" x/ W+ k! U( X9 D) Z: c: @3 N& ^  Z
    六、参考, M5 y9 [  v- k& o$ t& @9 s
    3 }7 q$ _) O4 T( q
    参考文章$ J, i% a, z9 R( h( @: @
    5 G) K# r" m- I) s  g: I* b: Z
    总结% u& F: m" ~$ P( L" j1 |
    7 u2 t0 A8 P. W8 K+ H
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。6 ~' v+ b( U* t  ?# Z
    ————————————————
    2 ]# @% g2 O* {% `5 r) ?8 z6 l版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。3 }5 ]0 A9 j& \+ L1 i- V
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093: r: b5 J& F2 a5 {* o  r2 d, ]1 a4 H( ?

    2 N- P! M3 i1 ^" D& m8 y$ t/ H
    - x, B) U" ]/ H$ p% ]& B1 _
    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-19 12:55 , Processed in 0.457232 second(s), 55 queries .

    回顶部