QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5598|回复: 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 中时区和宿主机相隔八个小时的解决方案之一1 J+ U/ {+ l0 E4 q- q
    前言
    8 T1 d3 S  [! z" _' V3 s8 @& j7 d% |$ v  ]: H% t4 M; I. O
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。1 _5 ^" n8 ^5 h5 s" e% a( i& _2 l
    0 J$ X& O: V  N/ U2 ?5 x
    关键字:Linux、Docker、Tomcat+ s. L6 ?7 h! z5 i/ ~; X

    3 z; W' _; Z8 [5 M% D3 C一、问题重现
    - W$ |) b! m9 P, `$ K: @$ k2 f) }2 t8 c! a! @
    项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。6 U! W5 u2 ^; A6 q- ~" ~6 o

    * q5 \' x; R% e5 b! a1 h[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    + g: A: A& H5 `  o9 ?# 打的日志上面的信息会比当前的时间(北京时间)少8个小时; T0 O* t6 R. }1 L
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    % A) j" g3 G+ _/ n7 c7 P4 x+ R28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
    ) I( T# \# v, f. Z/ H4 A  D28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    ! B$ G+ `( V1 n[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    . h3 k: v( _# W0 P' D$ b+ JThu May 28 02:50:42 UTC 2020
    1 A. w5 h2 O) W% s, L  H2 Z[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    5 _8 ?) A/ C2 K1 W: y1 @Thu May 28 14:19:38 CST 20201 y$ G' f, W% u( b
    [root@iZh4ntc7dmrvkzZ ~]#
    # a, ]$ g8 O2 |2 h: |) Y1
    2 D5 I- i# n3 M1 a; k+ r2! y2 z/ x% P$ v+ }7 i6 k/ Y
    3
    0 Q( F9 O9 G$ r- h9 h  i) E4+ _) d9 W, h/ l/ T* e
    5
    3 C6 F. ]# {* K3 @  k. u6  w$ e# }7 ~6 H$ ~( W, s/ t5 D
    79 ~9 |) }& D+ u% J' r
    8
    9 |3 |7 }8 e) w! `9
    2 b3 Y' v* K$ t8 }明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    4 a9 C, I  m5 k# q% e) {+ {$ i
    - X. o& S0 L2 Z二、分析问题2 C* k# L( \4 Q3 D- k
    1 {1 s1 W$ H4 C$ z9 C
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。0 e6 c% x9 b) n

    9 v3 F% K& W2 ~1 P三、修改 docker 容器的时区# s" E0 G3 Y: U5 S7 v7 r7 ]8 v# ?
    ' j' {7 D) i$ T" e  q( g) h
    1、进入需要修改时区的 docker 容器. N' W. M" J& `
      C, f' a; ^, P" x" k7 {
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash: O4 |3 `0 |2 U1 u
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    4 i8 w" z! Q6 L: B1 d# Q1
    5 x6 b& D- |, u  q2、复制上海(Shanghai)时区到 localtime; \) `( z0 q1 |+ i' l

    * [: M, ]0 W( O5 n4 droot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制/ y- ^6 U  v( j2 e
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    ' j$ Z$ n! t- g# T& o: z  ]exit0 k- }* u1 M+ Z1 h
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器9 \4 i/ I2 H' U% A+ O3 U
    965abb1fb546
    2 L, m4 h4 y: s0 e[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了& ^, K' Z1 g2 a$ D! d% \4 \& `$ H  a
    Thu May 28 11:12:12 CST 2020
    . H( h! X% M3 a6 n# j# N1
    0 q5 d4 L3 \; M5 ~2
    , \: l/ W. W$ W4 t9 L5 S3+ ^$ i" w- h2 Q9 b  c
    4
    0 ^; T3 [  Y) H' e6 C& d5
    . @8 F' o( r9 p, B2 V  q6
    ! O0 J8 E1 u: ^4 ^7 l四、验证(重启容器并查看日志)
    ( _! _- g0 |0 w$ N
    ; X0 {, G' r/ H* `% Z6 A9 U1 K[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    # n( V/ g" Q/ x( u28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux+ P8 l' ]$ c4 [, w8 H9 K
    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
    9 @9 U$ i- L+ [0 n28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64! ]. U9 ]9 m) V: R8 c& s/ z
    1
      X7 n; `, m( h3 D9 K2
    : }9 J# \* H$ ?0 P5 |3
    * q5 N; e+ \: l. V* ~可以看到打印的日志已经和当前时间相同了。* r8 N' T# y  ^7 @5 _% P, ?
    & J( L/ U( f0 x: j- N2 k6 ]
    五、说明
    4 ]3 m% p1 v' A- j! E2 g% V
    # X4 E( n5 W$ h+ G. V; w5 K( q  L为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    8 }" |1 x  m3 v, b/ ]8 k  E1 l是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。- M% m" m1 |( ]6 t
    , K* O9 C8 h, K
    六、参考9 H( U  y% e8 \3 M6 S. a' ^

    9 x9 _2 c) w3 }& X  W参考文章
      O  E9 M; z2 e8 A& Q/ I4 D( T! a( P1 t% H' [. M) x0 A
    总结/ @, L- s4 o, m0 ~& q+ [+ E8 R

    ' s( U9 w5 l+ }" z$ j时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。* E; _/ H. V' H5 Q5 j. n$ d4 e
    ————————————————3 j8 A, f' \! t9 X, F- T$ `
    版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ! n+ ~: O, A* h: h7 [) l8 \/ V$ l原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    : t3 L* u0 f7 L( {( S0 w* x( }6 e8 ^2 u1 I

    & G- h/ ]4 `+ L2 F$ F& H9 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, 2025-7-20 02:52 , Processed in 0.294778 second(s), 55 queries .

    回顶部