QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5847|回复: 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 中时区和宿主机相隔八个小时的解决方案之一  S  u1 ~: V8 s5 R6 Y' m
    前言
    9 f5 ?* @! }: H6 L7 v5 U/ ~+ @  G$ H% w
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    * B7 }# x* W; Y# X/ `1 J
    - r( e: E9 d: g) u! U) M! L5 R关键字:Linux、Docker、Tomcat
    . w0 z3 A+ Z8 z6 X, K7 L) k& y, ^: h7 g, d
    一、问题重现+ T) l3 T' M7 \* _/ y' l) I) ]9 I

    ) _2 w4 `/ ?; B8 h项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。% ~% C" n) F4 W# j0 B! a
    1 @# V5 a, n" J- V  k1 v, h
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印). L3 }9 J! u: K+ T
    # 打的日志上面的信息会比当前的时间(北京时间)少8个小时
    : ^) o/ e4 C) ^& T' l2 Z28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]- c( N# _  J" E$ p% v
    28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]. S9 |; c  R7 N( b: Q% I
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]; G2 h* t4 l+ Z: k* T
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id" J2 C- i9 h- h- Z8 A- f3 v
    Thu May 28 02:50:42 UTC 2020
    : W3 s0 l% \3 R[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间/ L1 m  a$ W  w5 w
    Thu May 28 14:19:38 CST 2020
    8 m: Q8 s9 w% b) b; D3 x[root@iZh4ntc7dmrvkzZ ~]# 2 {& e+ \+ M' h+ |
    14 @5 F% O: B3 }4 g
    28 [4 F1 f& d: s0 Q6 K9 P* z2 P
    3, }% }/ P) P/ Z) d: _$ Z
    4  u# ^4 a# y6 i1 R/ T0 O
    5
    6 a% M5 Y! ?. O# k6: m0 ?: H; A0 M3 E0 x- y7 Q
    7
    / x0 r. v- g% S3 z8! K0 A8 \% ?& G% s* {; G  {
    94 c; F: S& |& m. q
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。( X8 U( Q! D, O
    / _2 z3 D  r7 o2 X: z
    二、分析问题& I* a" b, j! o
    ! g2 P8 ^- |6 T, V2 A
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    2 u9 t* x) H: }( s4 z( ^6 T' h8 D2 J8 L" [; j
    三、修改 docker 容器的时区. d& u" w8 D- b8 B$ [: ^$ ~' u5 @# C

      ^1 l& x6 X( S/ S8 O2 Y3 u, [1、进入需要修改时区的 docker 容器
    + j# g$ F7 w8 P' Y9 }# V6 T0 H' N$ J- b; S
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
    7 C8 Q0 y* W& I- v6 O7 z2 p* ?root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹  {9 K6 h4 M6 a4 G$ O, }
    1+ M% C0 w9 ^1 k& L3 u) x
    2、复制上海(Shanghai)时区到 localtime$ ^3 x. v7 n, u* Z6 M

    ( R0 ^. D, Z3 h, Q/ W( ^: a& eroot@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    * a. \' T0 k- I/ X, p) Kroot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    ) `9 U5 B5 S" J5 }6 o! s5 yexit
    - t. l2 r0 R* o! Q[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    & e5 q( N; G/ j( c' {( b" G& k965abb1fb546* y' M, T. t7 k4 {8 c7 T$ d
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
    8 {6 K4 R! n5 t" d7 O' k0 cThu May 28 11:12:12 CST 2020& d3 y, v" X$ f* v9 v
    1
    ! m4 ?1 v; @: O3 H% [+ I0 F: {2* X) U8 B3 v5 q/ Z4 J
    30 c9 u( @* C. F4 }
    4
    2 F$ ?% g% j) a% y, }5
    0 [2 o( L5 W1 m  m/ {6
      ?; C, h& A/ B. V, \4 J: x8 N四、验证(重启容器并查看日志)$ F, l. w& y& p* O. ?

    3 B7 T. Y4 h2 v  G2 n% c- A[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb5464 b4 r; p7 n% k' R
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux( _  j: B# ?0 M: V: D( U$ j
    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$ l* Q* [) r  C* R- M  S
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    : g0 \+ i0 h% f" Y* m/ E- s( o1
    % V7 T6 w7 M' I9 j2( g, G0 f3 Y- n5 @
    3
    . N' T% O% s( [5 W( X可以看到打印的日志已经和当前时间相同了。. s2 Y( t, x, a  a6 O. b( y* I+ ~- ~

    ( {: L4 T2 [' |1 E( V  [! |; h五、说明
    # \8 R0 V4 @7 G$ u% F# l) e" Z9 c2 P$ t+ E' @
    为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
    1 D) X' N/ y9 _5 I是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
    7 i! K9 T. G7 f/ u2 B- P) D  o
    * X  X: K* h9 |5 x: R六、参考; G# `5 ~1 x$ a/ J4 P
      c3 g0 f4 D5 X9 w% @$ N% I
    参考文章( v$ c, N) A' d3 B0 d3 g( |8 s

    1 K/ R' v% |& R$ M/ L* {7 K总结
    , ~1 R4 Y" j& q; \4 C* L
    9 W* w9 l8 N( }  a: n时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    6 D$ y7 y7 N) j6 o: [————————————————
    % v6 I# Y9 T  J5 |版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ; m6 `% l: t, o; c原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
    2 q. A$ Z! f7 ^
    ! t, W& M* k2 E( J* }1 ^
    ) X/ s) }) ~: [8 y' ]8 Y9 }, P( v
    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 07:27 , Processed in 0.411849 second(s), 56 queries .

    回顶部