修改Docker 的 MySQL 容器时区

栏目: IT技术 · 发布时间: 5年前

内容简介:阿航在开发Springboot项目时, 前端告诉验证码一直无效. 本地测试没有问题, 一看远程服务器的数据库时间, 哇塞–早了8小时. 很明显, 是MySQL的时区问题. 本篇文章就来记录下如何修改Docker 的 MySQL 容器时区.先来校验下数据库是否真的时区不对. 进入MySQL数据库, 运行语句:会返回类似这样的数据:

阿航在开发Springboot项目时, 前端告诉验证码一直无效. 本地测试没有问题, 一看远程服务器的数据库时间, 哇塞–早了8小时. 很明显, 是 MySQL 的时区问题. 本篇文章就来记录下如何修改 Docker 的 MySQL 容器时区.

解决方案

先来校验下数据库是否真的时区不对. 进入MySQL数据库, 运行语句:

SELECT NOW();

会返回类似这样的数据:

mysql> SELECT NOW();
+---------------------+
| NOW()               |
+---------------------+
| 2020-07-04 15:46:46 |
+---------------------+
1 row in set (0.09 sec)

再来查询下当前时区, 输入以下命令:

SHOW VARIABLES LIKE '%time_zone%';

会返回类似这样的数据:

mysql> SHOW VARIABLES LIKE '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | UTC    |
| time_zone        | +00:00 |
+------------------+--------+
2 rows in set (0.12 sec)

如果返回的时间和你的相差多个小时, 并且时区不对(非+08:00)的话, 那么证明你需要向下看了.

方法一: 临时修改

当我们的需求非常急的时候, 我们可以做此临时修改. 运行命令:

SET GLOBAL time_zone = '+8:00';

再次运行以下命令, 校验返回结果是否为当前时间:

SELECT NOW();

返回当前时间则证明修改成功.

之所以本方法称为”临时修改”, 是因为重启MySQL后该修改会失效.

方法二: 启动时加参数

此方法适用于条件允许我们重新创建一个MySQL容器,

创建容器时, 我们需要加上指定时区的命令(东八区是上海, 你可以按需修改为自己的时区):

-e TZ=Asia/Shanghai

所以, 我们的docker完整运行命令应该为(仅供参考, 你的运行命令可能略有差异):

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

要查看各个参数的用途, 请查看我的这篇文章:《Docker 安装 MySQL》.

方法三: 修改容器内配置

输入以下命令进入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'

如图:

修改Docker 的 MySQL 容器时区
添加配置文件

完成后, 点击 ESC , 输入 :wq 进行保存并退出.

再输入 exit 退出docker容器.

接下来我们要重启mysql容器, 输入命令:

docker restart 容器ID

至此, 已经成功修改了时区配置.

重启后, 输入以下命令验证是否成功:

SELECT NOW();

如果返回时间和当前时间一致, 则证明修改成功.

如果特别急, 推荐方法一. 不急则推荐方法二. 各位同学按需选择使用.


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

通灵芯片

通灵芯片

Daniel Hillis / 崔良沂 / 上海世纪出版集团 / 2009-1 / 19.80元

本书深入浅出地阐述了计算机科学中许多基本而重要的概念,包括布尔逻辑、有限自动机、编程语言、图灵机的普遍性、信息论、算法、并行计算、量子计算、神经网络、机器学习乃至自组织系统。 作者高屋建瓴式的概括,既不失深度,又妙趣横生,相信读者读后会有很多启发。 目录: 序言:石的奇迹 第一章 通用件 第二章 万能积木 第三章 程序设计 第四章 图灵机的普适性 第......一起来看看 《通灵芯片》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具