Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決
NO.1 產(chǎn)生問題
在我們學(xué)習(xí)中使用到sysdate這個函數(shù)時,發(fā)現(xiàn)查出來的日期時間與當前的正確時間不一致,相差8個小時左右,為什么會產(chǎn)生這個問題?又該如何解決?
– 在數(shù)據(jù)庫中使用sysdate()函數(shù)查詢系統(tǒng)時間
select sysdate();
結(jié)果顯示:
NO.2 原因分析
原因分析1:第一時間想到的是數(shù)據(jù)庫所在的云服務(wù)器時間可能與網(wǎng)絡(luò)時間不同步,因為數(shù)據(jù)庫是裝在云服務(wù)器上的,但是這種可能性應(yīng)該較小,因為購買的阿里云服務(wù)器應(yīng)該不會存在這種問題,一般會自動校對時間。于是先確定云服務(wù)器的時間,輸入date命令查看云服務(wù)器系統(tǒng)時間,結(jié)果云服務(wù)器顯示的時間是正確的,如下圖:
原因分析2:排除第一種可能后,又想到Mysql是部署在云服務(wù)器的docker容器上的,會不會是docker容器時間不對呢?因此進入容器,查看容器的系統(tǒng)時間。
# 進入容器 d71f18f09a4e:容器id,以自己的容器id為準 docker exec -it d71f18f09a4e /bin/bash # 查看系統(tǒng)時間 date
果然,容器的時間不對,跟正確的時間相差了8個小時,跟數(shù)據(jù)庫查詢的結(jié)果是一樣的問題。所以SQL查出來的時間是跟隨容器的系統(tǒng)時間一致的,因此存在同樣的問題。所以我們只要把容器時間修改正確了,那我們通過SQL查詢出來的時間不對的問題也就解決了。
NO.3 解決方法
1.通過sql語句,查看系統(tǒng)時區(qū),修改時區(qū)來校對時間
– 第一步:查看系統(tǒng)時區(qū)
show variables like ‘%time_zone%';
– 第二步:修改時區(qū),并生效
– 修改系統(tǒng)時區(qū)
set global time_zone = ‘+08:00';
– 修改當前會話時區(qū)
set time_zone = ‘+8:00';
– 立馬生效
flush privileges;
– 修改后再次查看
show variables like ‘%time_zone%';
– 第三步:修改后再查看系統(tǒng)時間顯示
select sysdate();
第一步:系統(tǒng)時區(qū)查詢:
時區(qū)知識普及: 整個地球分為二十四時區(qū),每個時區(qū)都有自己的本地時間。在國際無線電通信場合,為了統(tǒng)一起見,使用一個統(tǒng)一的時間,稱為通用協(xié)調(diào)時(UTC, Universal Time Coordinated)。UTC與格林尼治平均時(GMT, Greenwich Mean Time)一樣,都與英國倫敦的本地時相同。在本文中,UTC與GMT含義完全相同。北京時區(qū)是東八區(qū),領(lǐng)先UTC八個小時,所以我們的時區(qū)為UTC+8。
第二步:修改時區(qū),并生效:
第三步:修改后再查看系統(tǒng)時間:
2.在云服務(wù)器上,把云服務(wù)器的正確時間文件拷貝到容器的中去,校對容器的時間
# 將服務(wù)器上時間文件拷貝到容器 d71f18f09a4e:容器id,以自己的容器id為準 docker cp /usr/share/zoneinfo/Asia/Shanghai d71f18f09a4e:/etc/localtime # 重啟容器 docker restart d71f18f09a4e # 查看容器是否運行docker ps # 進入容器 d71f18f09a4e:容器id,以自己的容器id為準 docker exec -it d71f18f09a4e /bin/bash # 查看容器的時間 date
**第一步:**復(fù)制日志文件后,查看容器時間:
第二步:數(shù)據(jù)庫查詢時間:
注意:如果容器時間顯示正確,但是數(shù)據(jù)庫查詢結(jié)果還是不對,則需要關(guān)閉客戶端(navicat),重新打開后再次查詢,基本就不會有問題了。
總結(jié)
到此這篇關(guān)于Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決的文章就介紹到這了,更多相關(guān)Mysql時間與系統(tǒng)時間不一致內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL中NULLIF?、IFNULL、IF的用法和區(qū)別舉例詳解
這篇文章主要給大家介紹了關(guān)于MySQL中NULLIF?、IFNULL、IF的用法和區(qū)別的相關(guān)資料,nullif和ifnull都是MySQL中用于處理NULL值的函數(shù),但它們的用法和作用略有不同,下面給大家詳細介紹下,需要的朋友可以參考下2024-05-05MySQL 數(shù)據(jù)庫定時備份的幾種方式(全面)
在操作數(shù)據(jù)過程中,可能會導(dǎo)致數(shù)據(jù)錯誤,甚至數(shù)據(jù)庫奔潰,而有效的定時備份能很好地保護數(shù)據(jù)庫。本篇文章主要講述了幾種方法進行 MySQL 定時備份數(shù)據(jù)庫。2021-09-09如何使用分區(qū)處理MySQL的億級數(shù)據(jù)優(yōu)化
mysql在查詢上千萬級數(shù)據(jù)的時候,通過索引可以解決大部分查詢優(yōu)化問題。但是在處理上億數(shù)據(jù)的時候,應(yīng)該怎么解決,本文就是用分區(qū)來優(yōu)化一下,感興趣的一起來了解一下2021-06-06