Docker的MySQL容器時區(qū)問題修改
前言
阿航在開發(fā)Springboot項目時, 前端告訴驗證碼一直無效. 本地測試沒有問題, 一看遠程服務(wù)器的數(shù)據(jù)庫時間, 哇塞–早了8小時. 很明顯, 是MySQL的時區(qū)問題. 本篇文章就來記錄下如何修改Docker 的 MySQL 容器時區(qū).
解決方案
先來校驗下數(shù)據(jù)庫是否真的時區(qū)不對. 進入MySQL數(shù)據(jù)庫, 運行語句:
SELECT NOW();
會返回類似這樣的數(shù)據(jù):
mysql> SELECT NOW(); +---------------------+ | NOW() | +---------------------+ | 2020-07-04 15:46:46 | +---------------------+ 1 row in set (0.09 sec)
再來查詢下當(dāng)前時區(qū), 輸入以下命令:
SHOW VARIABLES LIKE '%time_zone%';
會返回類似這樣的數(shù)據(jù):
mysql> SHOW VARIABLES LIKE '%time_zone%'; +------------------+--------+ | Variable_name | Value | +------------------+--------+ | system_time_zone | UTC | | time_zone | +00:00 | +------------------+--------+ 2 rows in set (0.12 sec)
如果返回的時間和你的相差多個小時, 并且時區(qū)不對(非+08:00)的話, 那么證明你需要向下看了.
方法一: 臨時修改
當(dāng)我們的需求非常急的時候, 我們可以做此臨時修改. 運行命令:
SET GLOBAL time_zone = '+8:00';
再次運行以下命令, 校驗返回結(jié)果是否為當(dāng)前時間:
SELECT NOW();
返回當(dāng)前時間則證明修改成功.
之所以本方法稱為”臨時修改”, 是因為重啟MySQL后該修改會失效.
方法二: 啟動時加參數(shù)
此方法適用于條件允許我們重新創(chuàng)建一個MySQL容器,
創(chuàng)建容器時, 我們需要加上指定時區(qū)的命令(東八區(qū)是上海, 你可以按需修改為自己的時區(qū)):
-e TZ=Asia/Shanghai
所以, 我們的docker完整運行命令應(yīng)該為(僅供參考, 你的運行命令可能略有差異):
docker run -p 3306:3306 --name mymysql -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -e TZ=Asia/Shanghai -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0
要查看各個參數(shù)的用途, 請查看我的這篇文章: 《Docker 安裝 MySQL》.
方法三: 修改容器內(nèi)配置
輸入以下命令進入mysql容器:
docker exec -it 容器ID bash
修改MySQL配置文件(兩種情況):
vim /etc/mysql/mysql.conf.d
或者
vim /etc/mysql/my.cnf
如果以上命令返回bash: vim: command not found, 請先閱讀Docker容器沒有vim命令的解決方案
進入配置文件后, 點擊i進入編輯模式, 添加一行配置文件:
default-time-zone = '+08:00'
如圖:
添加配置文件
完成后, 點擊ESC, 輸入:wq進行保存并退出.
再輸入exit退出docker容器.
接下來我們要重啟mysql容器, 輸入命令:
docker restart 容器ID
至此, 已經(jīng)成功修改了時區(qū)配置.
重啟后, 輸入以下命令驗證是否成功:
SELECT NOW();
如果返回時間和當(dāng)前時間一致, 則證明修改成功.
結(jié)語
如果特別急, 推薦方法一. 不急則推薦方法二. 各位同學(xué)按需選擇使用.
到此這篇關(guān)于Docker的MySQL容器時區(qū)問題修改的文章就介紹到這了,更多相關(guān)Docker MySQL容器時區(qū)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker鏡像的遷移與備份及Dockerflie 使用方法詳解
遷移和備份主要有三個操作命令將容器保存為鏡像、備份鏡像(將鏡像導(dǎo)出為一個文件)、鏡像的遷移與恢復(fù),這篇文章主要介紹了Docker鏡像的遷移與備份、Dockerflie 使用方法,需要的朋友可以參考下2022-07-07在Docker中使用mongodb數(shù)據(jù)庫的實現(xiàn)代碼
這篇文章主要介紹了在Docker中使用mongodb數(shù)據(jù)庫的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10Docker部署springboot項目到騰訊云的實現(xiàn)步驟
本文主要介紹了Docker部署springboot項目到騰訊云的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04如何通過Dockerfile 創(chuàng)建 kali-novnc
這篇文章主要介紹了如何通過Dockerfile 創(chuàng)建 kali-novnc,在Dockerfile所在目錄運行相關(guān)命令操作即可完成,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-04-04docker安裝Adminer并支持mysql和mongodb的詳細步驟
這篇文章主要介紹了docker安裝Adminer并支持mysql和mongodb,通過查找并拉取Adminer鏡像,啟動docker,支持mysq,本文分步驟給大家詳細講解,需要的朋友可以參考下2022-10-10