MySQL5.7.18参数log_timestamps导致日志信息时间差8小时
环境:MySQL5.7.18+CentOS6.8
背景:
排查问题查看mysql日志的时候发现mysql错误日志和慢查询日志中的时间戳信息比正常时间少了8小时.
官方资料显示:
log_timestamps 自5.7.2版本被引入,此参数控制了general log、error log、slow query log日志中
时间戳的显示,默认使用的UTC。但是此参数不影响mysql.general_log, mysql.slow_log中写入信息的
时间戳。在查询记录的时候,可以使用 CONVERT_TZ() 函数,或者设置会话级别的系统变量 time_zone
来转换成所需要的时区。实则不然,我这是5.7.18版本也遇到同样的问题.
此参数有UTC(默认值)和system的2个可选项,此参数是可以动态修改的。
#进入mysql查询一下,然后动态修改.
mysql> show variables like 'log_timestamps';
+----------------+-------+
| Variable_name | Value |
+----------------+-------+
| log_timestamps | UTC |
+----------------+-------+
1 row in set (0.00 sec)
mysql> set global log_timestamps=system;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'log_timestamps';
+----------------+--------+
| Variable_name | Value |
+----------------+--------+
| log_timestamps | SYSTEM |
+----------------+--------+
1 row in set (0.00 sec)
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2020-08-06 09:58:48 |
+---------------------+
1 row in set (0.00 sec)
#修改完成后,可以看到已经变成SYSTEM.那在配置文件my.cnf里再添加:
[mysqld]
log_timestamps=system
#建议写入配置文件,这样以防重启失效.
小补充:
MySQL 8.0支持参数log_timestamps持久化设置
设置为持久化参数:
mysql> set persist log_timestamps=system;