解決MySQL時區(qū)日期時差8個小時的問題
場景:
我們在mysql客戶端查詢 now() 系統(tǒng)當(dāng)前日期時間,會發(fā)現(xiàn)得到的結(jié)果比系統(tǒng)實際日期時間慢8個小時左右,這是由于不同的時區(qū)導(dǎo)致的
解決:
1、在 mysql 的服務(wù)端的 my.conf 文件中 [mysqld] 節(jié)點下設(shè)置時區(qū)參數(shù)
default-time-zone=Asia/Shanghai
2、如果 mysql 的版本是 5.7 配置如下參數(shù)
default-time-zone = '+8:00'
3、如果 mysql 服務(wù)是由 docker 創(chuàng)建的容器,需要查看 mysql 容器的系統(tǒng)日期是否正確,如果不正確,需要調(diào)整 mysql 容器內(nèi)的系統(tǒng)日期時間
方式一:
//1、把當(dāng)前宿主機(jī)的時區(qū)信息復(fù)制到mysql容器的時區(qū)中 docker cp /usr/share/zoneinfo/Asia/Shanghai 容器名稱或Id:etc/localtime //2、重啟mysql服務(wù)即可 docker restart 容器名稱或Id
方式二:
共享主機(jī)的 localtime,創(chuàng)建容器的時候指定啟動參數(shù),掛載 localtime 文件到容器內(nèi)
docker run --name 容器名稱 -v /etc/localtime:/etc/localtime
如此,時區(qū)不一致的問題就解決了
mysql查出時間相差14小時
問題重現(xiàn)
服務(wù)器使用mysql 5.7數(shù)據(jù)庫,線上運行程序時,保存時間相差14小時
問題排查
首先以為是線上linux系統(tǒng)數(shù)據(jù)庫時區(qū)問題,特地查看了線上linux數(shù)據(jù)庫時區(qū)
Last login: Wed Nov 27 14:39:13 2019 from 192.168.2.147 [root@localhost ~]# date -R Thu, 28 Nov 2019 08:44:39 +0800 [root@localhost ~]# hwclock 2019年11月28日 星期四 08時44分52秒 -0.938419 秒 [root@localhost ~]#
檢查時區(qū)后發(fā)現(xiàn)時區(qū)設(shè)置是正確的,懷疑是線上數(shù)據(jù)庫時區(qū)設(shè)置問題,檢查線上數(shù)據(jù)庫時區(qū)設(shè)置
mysql> show variables like '%time_zone%'; +------------------+--------+ | Variable_name | Value | +------------------+--------+ | system_time_zone | CST | | time_zone | SYSTEM | +------------------+--------+ 2 rows in set (0.03 sec)
發(fā)現(xiàn)線上數(shù)據(jù)庫時區(qū)設(shè)置也是一致,于是在本地重新運行程序,添加斷點,監(jiān)聽時間傳參變化,斷點逐步進(jìn)行,在保存至數(shù)據(jù)庫前,斷點中檢查的時間都是正確的,可以確定是數(shù)據(jù)庫時間保存時出現(xiàn)的問題。
在這個地方我自己遇到的問題更尷尬,排查問題時是在同事電腦上進(jìn)行排查,檢查了pom文件中依賴的mysql-connector-java 版本號是 5.1.46 ,運行時無報錯信息,但實際打包項目時使用的是我電腦進(jìn)行打包,但我電腦中pom文件里mysql-connector-java 版本號寫的是runtime,也就是跟著springboot版本選擇,我使用的springboot版本號是2.1.5,所以對應(yīng)的mysql版本jar包文件是8.0的jar包,就是這個問題導(dǎo)致是時間相差了14小時,更改mysql版本號,重新運行,問題解決。
自己在排查問題過程中也發(fā)現(xiàn)了類似相關(guān)的數(shù)據(jù)庫時間保存相差N小時問題主要出于幾種情況:
- 數(shù)據(jù)庫版本不一致
- marven依賴jar包版本與數(shù)據(jù)庫版本不一致
- mysql時區(qū)設(shè)置錯誤
- 系統(tǒng)時區(qū)錯誤
到此這篇關(guān)于解決MySQL時區(qū)日期時差8個小時的問題的文章就介紹到這了,更多相關(guān)MySQL差8個小時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深度解析MySQL啟動時報“The server quit without up
這篇文章主要介紹了MySQL啟動時報“The server quit without updating PID file”錯誤的原因,需要的朋友可以參考下2017-05-05MySQL中的RIGHT?JOIN和CROSS?JOIN操作示例
本文詳細(xì)介紹了MySQL中的RIGHT?JOIN和CROSS?JOIN操作,RIGHT?JOIN返回右表中的所有記錄及與左表中的記錄相匹配的記錄,而CROSS?JOIN返回兩個表中所有可能的組合,通過實際示例和輸出結(jié)果,我們展示了如何使用RIGHT?JOIN和CROSS?JOIN進(jìn)行數(shù)據(jù)庫查詢,一起看看吧2023-07-07MySQL遞歸sql語句WITH表達(dá)式實現(xiàn)方法代碼
SQL遞歸查詢語句是指通過遞歸方式對數(shù)據(jù)進(jìn)行查詢的語句,下面這篇文章主要給大家介紹了關(guān)于MySQL遞歸sql語句WITH表達(dá)式實現(xiàn)的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01mysql8報錯:ERROR?1410?(42000):?You?are?not?allowed?to?
電腦新裝的mysql,版本為8.0以上,分配權(quán)限時直接帶密碼和賬號會報錯,這篇文章主要給大家介紹了關(guān)于mysql8報錯:ERROR?1410?(42000):?You?are?not?allowed?to?create?a?user?with?GRANT的解決辦法,需要的朋友可以參考下2022-06-06MySQL通過存儲過程來添加和刪除分區(qū)的過程(List分區(qū))
這篇文章主要介紹了MySQL-通過存儲過程來添加和刪除分區(qū)(List分區(qū)),本文通過創(chuàng)建存儲過程來添加和刪除分區(qū),可以避免在分區(qū)存在時添加分區(qū)報錯,或者分區(qū)不存在時刪除分區(qū)報錯的問題,需要的朋友可以參考下2023-09-09windows下mysql?8.0.27?安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了windows下mysql?8.0.27?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04mySQL count多個表的數(shù)據(jù)實例詳解
這篇文章通過實例給大家介紹了mySQL中count多個表的數(shù)據(jù),也就是多個表如何聯(lián)合查詢,文中通過項目中遇到的一個問題進(jìn)行分析和實現(xiàn),給出了詳細(xì)的示例代碼,相信對大家的理解和學(xué)習(xí)很有幫助,有需要的朋友們下面來一起看看吧。2016-11-11MySQL利用索引優(yōu)化ORDER BY排序語句的方法
這篇文章主要介紹了MySQL利用索引優(yōu)化ORDER BY排序語句的方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2020-10-10