QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5722|回复: 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 中时区和宿主机相隔八个小时的解决方案之一3 U6 b3 E/ @* X1 I/ j, p7 s6 T
    前言5 G0 M  }4 g' w/ R1 u2 _8 r
    * I  B% j# A) d
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。) N% o& \+ f( [$ H! c5 y. Z  R
    ) Q8 G, C. s( p. q" D9 z$ ~3 ?& i
    关键字:Linux、Docker、Tomcat6 W/ c6 Z: t/ \" l6 ?
    6 [2 `# T+ g& ?* q5 u" y( e
    一、问题重现9 ~- I5 u$ G( p$ g- d

    - n7 h5 R" d! m, q项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。- n! ~' f: w2 U4 \& y6 ~  l# _/ K

    4 K3 W) R1 S6 j3 u0 T8 G[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    / f1 X8 `' P0 f3 H( s' O# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    . j3 H, m& h: h7 z1 f% q" _28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    2 O' N) u" T% h  h8 Z' V28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"], K7 T- H% [& F
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    + U: |' e( ^  Q- I2 u2 S9 X1 I[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    . C7 b/ k9 N& h* v& \Thu May 28 02:50:42 UTC 2020
    & _8 N5 A0 h$ j2 B- L( t$ D[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
    / J) X" d0 H' Q( wThu May 28 14:19:38 CST 2020: a, d# f6 n% l" C
    [root@iZh4ntc7dmrvkzZ ~]# " t) [4 B2 |! A+ J$ j1 |+ ^% ^
    1
    / d6 p6 Z' P+ S7 ~; Z2
    $ f. D6 p% W6 e; _* T% f3
    0 d( _* m4 U7 C, {5 v47 r! D( z# p7 L6 u9 n$ r
    5! J& X! \, F% n# x7 h
    6+ f" Z6 k+ T% Q1 b5 B. A
    7
    4 k/ P7 X4 c5 a83 S& ^9 r# y' s
    9
    3 `9 m% W/ q- d2 U明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。" X) u3 `6 O& Z& }: ~( r
    ! W" V, w( n. {+ m1 i  e- @) K4 E0 X
    二、分析问题% M$ y$ K; E( K9 w9 W/ Y

    1 `( Q* ?* _* P! N% l刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    + v5 z: F# Q7 M% x+ ~9 `  I/ W2 A& X4 D  P' t3 `% r. N
    三、修改 docker 容器的时区0 O8 ~0 q/ }* F4 Y
    6 p3 s; z! G( I- k% T4 s( `
    1、进入需要修改时区的 docker 容器- d8 {) K3 b) ~+ e: Q3 Y
    + u) e- q8 Y* a/ `: Z
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash6 ]. q! f' H7 T6 j% D
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
    / s+ l: ?1 R' i4 P% x% A: E1 y, p8 N: S19 {- T: L8 g. b" C
    2、复制上海(Shanghai)时区到 localtime( D- ]4 @7 J' @  F* e

    % B5 ^. l  S. Q  N- vroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制4 R7 G8 q8 f  i$ Z. M
    root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    : @( c! h. G2 uexit
    6 R0 P2 |, Z- `3 x% z# n[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器; h$ V8 W0 N. u3 }
    965abb1fb5469 E  p8 Z  E2 F$ ~2 Y
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    8 {' V3 R! [$ o- e, w: f/ F- AThu May 28 11:12:12 CST 2020" ]* d7 C/ f, x  a: K
    1: ?0 k5 [, s; K9 X
    2
    ' z9 G: e: G1 Y. v* K9 T3* k. C2 k- u8 e* [3 @
    48 [& E) j9 F- P# Y$ o) A! `+ l9 N
    5) b8 M6 l1 C, Q7 P9 f) }
    6" p$ O  ~5 D* ^- I
    四、验证(重启容器并查看日志)& m3 L; s7 G& z( e: E/ c' Z7 ?

    2 X9 ~9 g1 Y% F" W3 `[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    7 r+ I7 n9 N* D8 c% h28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux' G) [6 d, B0 p8 l8 E2 v+ |
    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_640 s' }. @3 b% j+ A8 x+ _: Y
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd647 ~6 \$ o, L/ r1 \# z: Y; o
    1
    , l7 P9 m& A. m4 F# Y2
    7 X; M& l2 _6 R, ~3+ ~- y% F: a7 n
    可以看到打印的日志已经和当前时间相同了。+ G: Y5 x9 h( d% t: H
    : L, z( R* T$ Z
    五、说明
    $ o5 W3 c" V9 }! z% W% d8 t) ]8 I& n
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?5 `2 q* ~/ l! D# e$ b( H9 {
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。/ Q( Y' n) H/ E! s+ n0 `, g

    2 w+ R, V% h" F1 w- e六、参考
    7 I6 o2 \4 ~7 O7 z( U4 Y  r: h  y* e$ F
    参考文章
    . R* Q$ c4 C  h: j+ [# D4 f5 T- U
    4 b. R* |3 a8 o! Y. ?总结
    : D$ U9 G7 t8 t, f8 S
    * U6 |5 `7 J9 e- c3 n时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。) R; S7 a; n, }) r3 I. j
    ————————————————
    . |: c9 q( b2 r版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。4 K- H2 s# R0 T, X2 r+ ]0 p. i
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/1064030938 s) x0 c1 L( A7 f2 ?7 U/ x5 w

    " U  t( \# ]3 b6 p1 Q  O
    # A0 `2 H! F$ d" B* R' l% {
    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-9-30 23:37 , Processed in 0.451699 second(s), 55 queries .

    回顶部