QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5667|回复: 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 中时区和宿主机相隔八个小时的解决方案之一. T$ W6 E: D% e$ ^
    前言$ i. r# Q) e) ]; ?: G& o
    & ~3 }) @( k7 Q) @: B
    项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
    ' w, q3 n& s& k, n) n
    ( [) f+ \- U  a# N关键字:Linux、Docker、Tomcat
    ' H& W' T+ k3 o8 G3 }2 N( ?# S, |! X' U/ ^: |) d" b) d
    一、问题重现
    5 e1 w& i  i3 n
    2 {% o8 Q% e. e0 m2 F+ `( b项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
    : R+ |0 G4 y) L6 t! l! x* E( q8 V, c0 H% D
    [root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
    / ~8 p: ^6 O6 M! r# 打的日志上面的信息会比当前的时间(北京时间)少8个小时1 ?  `9 \0 y7 v( J3 [" Z
    28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
    0 S1 @. r/ I  B* j8 L* }$ @; G28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]! z- v2 ~1 u) f  D2 c8 A8 r) H
    28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
    7 {0 E9 T' A: Z8 l[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
    / Q$ j7 H$ s! x; V# GThu May 28 02:50:42 UTC 2020
    2 i! c# c' v4 c- h( r9 ^[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间* f1 u. `/ Q& C% H# u
    Thu May 28 14:19:38 CST 20208 ?1 M' B, ^7 S& c- x* W
    [root@iZh4ntc7dmrvkzZ ~]#
    3 @( U2 }. H6 ]11 W0 {4 y4 M, X9 \1 L& ?8 ~
    2& y1 I3 ]5 x0 b0 Q. J/ l! x
    3
    ! L) K: l; S( [8 M4
    , `' D  A+ }0 q! x% z* K6 D54 G& S/ f# G, M6 O3 Q
    6
    ' I. p, m. {( g# s" q71 t3 V: C3 ?" E. G: z
    8
    5 y) t2 R5 s. l0 c% z1 f+ O9# P! }: }& ^5 N) {
    明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
    + u; A$ X, O/ E1 N5 A, f  n
    1 Y9 A9 Z9 W$ g1 v, ~二、分析问题1 k) Z+ U, K7 G. S  u
    ! H4 n& f9 [+ Z1 D. y
    刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
    1 L5 d0 l6 p% a  p9 N9 H7 k! \
    : Z. ]2 ~0 ^1 l+ p三、修改 docker 容器的时区8 J9 j. F5 y7 w$ h- V& E( X- ?4 [9 c

    2 N! p" r$ r' q8 _0 f1 K3 t$ a, p! Q1、进入需要修改时区的 docker 容器
    . N2 ^; b9 n1 p( V3 G' C) J( u, m  J7 o% D) }0 L* U+ Y: _# `4 Q4 m
    [root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash/ J  j) V3 U& m- G$ n" i+ [
    root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹8 G6 C; G4 N" o" ~1 h$ T4 N
    1. n) {2 A' S3 U2 o! y
    2、复制上海(Shanghai)时区到 localtime: y' _: h  z4 ^( v1 h) e* N; O5 U
    ! B: V, s0 R/ s( f
    root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
    , t$ a3 a- [0 R/ V# k$ y' kroot@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
    ( H5 Y* l- A3 Nexit" |6 c7 ]% d4 T8 e
    [root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
    7 p. p: @3 B, J- [3 _: U965abb1fb546
    - i5 C  i$ H: a[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了! m* @2 y; d7 E! X6 {8 }! t. J
    Thu May 28 11:12:12 CST 2020
    + `9 N/ e2 H( `4 c% l12 a1 n1 L% V6 N1 x
    2
    % q% q$ `/ ^' Z$ D7 Q9 H' J, l# `3
    & b$ [% }6 H# _8 W1 H( t4( W0 _/ k6 r, k) f7 W, @
    5
    6 E: R( a0 `2 v. y0 \8 J6& {2 K; o' Z; F8 s& S) [4 k1 S8 \' r
    四、验证(重启容器并查看日志)
    $ w; s, u- w8 g, b  \
    ) U2 m: L# t) x& t/ y$ i[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
    $ a& b. ?& z4 l$ n) a# D; H, E0 z28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
    : I, M+ o( j( }9 y28-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+ \6 ]3 t9 T! r- V! F, Y
    28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
    ! w; P( @! x% z% h2 G' x8 @) y, @1
    ) H+ Z- I% Q" w, i. t% B5 P21 U3 B, B4 T( j6 N) Z! y
    35 i: h7 ?6 ^6 W+ {* ^: s5 H
    可以看到打印的日志已经和当前时间相同了。
    : V+ q8 r6 e. Z9 z- B1 {4 f% j  A4 [0 N; `; N
    五、说明& ^/ E+ |' u) M( \. s; W$ M! t

    4 U, a# z' ?2 W为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?  D, S0 h& T1 g0 G
    是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。. e  F; K( q$ }$ U; j& b+ f3 t
    : u2 @* |  T1 V$ b0 l
    六、参考
    $ J( N  R8 k4 y1 C  {; j; ^3 z2 @9 K
    参考文章
    . [+ S. ^0 J2 C0 P4 a! i  U5 z0 I5 ]. K5 C$ A. J
    总结
    5 ?4 I& m  n& `. t* T: H/ \! \2 a8 ]6 h
    时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
    ( h8 n; L+ l0 S————————————————
    3 x7 y& @2 b; d- F版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。2 p. s" e0 O$ E0 N
    原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093, ^) F+ n9 [7 t/ }, l! \4 v3 Y) I

    # G9 q" y* M* \$ V' G; V( [4 F
    , C& Z& ^3 o1 `5 E' y
    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-8-28 09:21 , Processed in 0.494009 second(s), 55 queries .

    回顶部