mysql logtimestamps_MySQL5.7.18参数log_timestamps导致日志信息时间差8小时

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值