数学建模社区-数学中国
标题:
Docker 中时区和宿主机相隔八个小时的解决方案之一
[打印本页]
作者:
杨利霞
时间:
2020-5-30 15:21
标题:
Docker 中时区和宿主机相隔八个小时的解决方案之一
Docker 中时区和宿主机相隔八个小时的解决方案之一
! `; w) |% I* A1 z6 m
前言
" p( ^8 a/ N# G8 V
( l) N# r! D9 Y+ E- x% T
项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
- Q& _# W1 J; U7 a' k
/ ]: ]& J0 I* T- y' L
关键字:Linux、Docker、Tomcat
m# M6 k# H# Q/ X
0 [( U' m6 V" h; L7 K
一、问题重现
# V) B+ }0 M2 P' h
/ i# @! q/ z' u' P+ c/ ~
项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
4 `! G+ M/ h5 \
" l3 ?/ w$ j2 P( Q- a
[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
$ X9 x; D/ p6 t! M! d
# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
" l- U' X' X3 G3 r. v2 F) M
28-May-2020 02:41:31.492 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
3 \6 U/ p4 m* M) f
28-May-2020 02:41:31.496 INFO [Thread-9] org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
% `1 s; c' |) g+ M' @
28-May-2020 02:41:31.498 INFO [Thread-9] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
6 G# P1 u. U8 M# L b$ K3 w
[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
8 X7 j! i$ d6 E% h @
Thu May 28 02:50:42 UTC 2020
; _ B# ~8 K, y0 I
[root@iZh4ntc7dmrvkzZ ~]# date # 查看 linux 的时间
: C) [4 ]! S& q; b. W7 k' a! ~
Thu May 28 14:19:38 CST 2020
( g% {4 r" R( m' j: R
[root@iZh4ntc7dmrvkzZ ~]#
7 E4 p/ | Y6 S {
1
R5 e5 `8 j! u$ y0 I
2
1 J# O, x8 d+ U) r2 |6 [0 y
3
( b# |+ i9 _' C1 G+ {4 G4 Y' V& y
4
0 e- r% F5 A: B `/ v
5
1 v4 m' o5 J: Q# {2 h
6
6 f0 c; y3 \* \ |% r
7
* B; M! r/ Z: B% m& R& |+ f' Y$ y% [9 c/ m
8
. {& s( A2 r2 Q( G
9
& P4 g: ~5 [% H, c6 B* z/ w
明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
7 D4 X) { w: a f' Y& |% k
1 W" q9 }* W( ^2 s' c" @' D
二、分析问题
1 ?- [+ k9 n; q4 B! q# A
8 g/ F; }- u, [4 a
刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
5 [6 `$ A9 M$ k" a, Q6 X$ `& z
& G6 W' i% k' }! n/ s& d
三、修改 docker 容器的时区
& X: |% s$ R7 X( w7 @) R9 v9 A
; u u5 _5 U4 q8 b* {
1、进入需要修改时区的 docker 容器
/ c' h8 A+ x9 ~2 G+ w% V) {( _
, m. v" M- F' [: d7 U, r
[root@iZh4ntc7dmrvkzZ zxw]# docker exec -it 965abb1fb546 /bin/bash
* I) R/ N% F" r" o0 Y
root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
* G& H+ t! t1 \( S4 T# V
1
0 U+ I4 H0 [- m: U1 X
2、复制上海(Shanghai)时区到 localtime
) k3 a3 d+ b- _" E: F" y: ^
- U7 Q4 M5 o- w; B3 A
root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
' x2 P$ X" H6 |# g Z4 Z! b+ Q( e
root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
$ x/ }5 }6 g6 J+ T7 o2 t
exit
1 |! Z& h+ e( R+ ^
[root@iZh4ntc7dmrvkzZ zxw]# docker restart 965abb1fb546 # 重启容器
( r/ _- s9 }6 j
965abb1fb546
* P0 l* |5 a$ U1 _% ^8 C; `& u
[root@iZh4ntc7dmrvkzZ zxw]# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
+ U6 ^2 f8 G" W6 U8 [' K
Thu May 28 11:12:12 CST 2020
, F" e# g5 R5 g5 n& H" s! N
1
& {0 M/ |: e5 z: `6 R5 @
2
% L, g4 T0 K8 e% ]
3
; m1 {$ w. d* \, B+ {$ w( n: i: A
4
6 P6 A6 {& S c, ^% s
5
0 p) ~+ ^4 ]5 Y3 e/ ~8 {& R
6
n' b9 {' p" i: C& g) p6 `
四、验证(重启容器并查看日志)
1 |' U! s7 M" z* J! A
" M' Y: b: s5 _
[root@iZh4ntc7dmrvkzZ zxw]# docker logs -f --tail 100 965abb1fb546
' E6 a4 A) @9 d& Y
28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name: Linux
1 K3 K# j, f; i; M* b$ W9 A
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
8 H$ E' V; i S
28-May-2020 11:16:56.191 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture: amd64
8 ]0 ]6 x7 q' Y& d) B
1
. s3 M! X$ W! Q$ o9 E! ?& J
2
8 A0 ^ i+ B3 w8 _
3
# S# @3 T4 W* v7 w8 }' m+ [
可以看到打印的日志已经和当前时间相同了。
- ]! }) J" G2 O! J2 }% q4 T# z& Y. N* E
# {+ l5 v5 ]# q( T7 z. d
五、说明
) e" ^7 `. |( g- b3 o4 {9 M
. U* C0 i a. t. _+ @
为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
2 ^/ [" x. N" O6 ~
是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
% G1 ~6 H" f7 `( U, ?" S
i* B, p$ `( d& e
六、参考
6 a+ }9 d$ O* R" |9 f
% J0 B! r" H' e' A2 \& E! E
参考文章
7 l( e& i# ]& E n# n
1 T* ]5 v# p! v% y( j
总结
( s( Z+ F! X% ^$ w2 O# h
% ?3 @7 \3 ]$ O# k% E7 |
时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
- T6 z, j* ]& n3 K
————————————————
' I' [& x8 u; U* o; n( I2 W
版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
2 R& V- e; h: m; x
原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
$ K. F, s8 X. m+ C3 v% h
3 B& A# m8 b! y
/ X3 W! f- }9 Z3 t) z5 Q) I* S2 C
作者:
手可摘星陈
时间:
2020-6-1 12:25
发表回复谢谢啦
' P. Q3 ]! t- q% Q
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5