mysql日志时区不对_【mysql案例】mysql 5.7日志文件里面时间的时区不对的问题

问题:

新安装的MySQL 5.7.27,发现error log、general log日志里面日志时间的时区不对。

error log

2019-09-11T12:53:23.988658Z 0 [Warning] CA certificate ca.pem is self signed.

2019-09-11T12:53:24.007777Z 0 [Note] Server hostname (bind-address): '*'; port: 3306

2019-09-11T12:53:24.008117Z 0 [Note] IPv6 is available.

2019-09-11T12:53:24.008148Z 0 [Note] - '::' resolves to '::';

2019-09-11T12:53:24.008226Z 0 [Note] Server socket created on IP: '::'.

2019-09-11T12:53:24.088216Z 0 [Note] /usr/local/mysql/libexec/mysqld: ready for connections.

Version: '5.7.27-debug-log' socket: '/usr/local/mysql/tmp/mysql.sock' port: 3306 Source distribution

general log

2019-09-11T12:56:32.547294Z 2 Queryshow global variables like 'log_timestamps'

2019-09-11T13:01:04.907420Z 2 Queryselect DATABASE(), USER() limit 1

2019-09-11T13:01:04.908582Z 2 Queryselect @@character_set_client, @@character_set_connection, @@character_set_server, @@character_set_database limit 1

2019-09-11T13:01:04.908974Z 2 Statistics

原因:

mysql 5.7.2新增了参数 log_timestamps,用于控制error log、general log、slow log日志记录使用的时区,只影响写入文件的时区,不影响写入表中记录的时区。默认值是UTC,支持设置为SYSTEM使用系统的时区。

• log_timestamps

Introduced

5.7.2

Command-Line Format

--log_timestamps=#

System Variable

Name

log_timestamps

Variable Scope

Global

DynamicYes Variable

Permitted Values

Type

enumeration

Default

UTC

Valid Values

UTC

SYSTEM

This variable controls the timestamp time zone of error log messages, and of general query log and slow query log messages written to files. It does not affect the time zone of general query log and slow query log messages written to tables (mysql.general_log, mysql.slow_log). Rows retrieved from those tables can be converted from the local system time zone to any desired time zone with CONVERT_TZ() or by setting the session time_zone system variable.

Permitted log_timestamps values are UTC (the default) and SYSTEM (local system time zone). Timestamps are written using ISO 8601 / RFC 3339 format: YYYY-MM-DDThh:mm:ss.uuuuuu plus a tail value of Z signifying Zulu time (UTC) or ±hh:mm (an offset from UTC).

This variable was added in MySQL 5.7.2. Before 5.7.2, timestamps in log messages were written using the local system time zone by default, not UTC. If you want the previous log message time zone default, set log_timestamps=SYSTEM.

修复:

1)执行 set global log_timestamps=SYSTEM

执行之后,新的日志的时区就会变成系统默认的时区。

2)在my.cnf中添加 log_timestamps=SYSTEM

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值