如何让 MySQL 5.5 将警告记录到日志文件之一?

Wod*_*din 5 mysql logging

我发现有很多事情说你可以将警告记录到 MySQL 错误日志中,但我还没有真正做到这一点。

我确实有错误日志在工作,并且 MySQL 在启动和关闭时以及偶尔在其他时间向它打印内容,但是如果我例如SELECT CAST('123' AS DATE);然后SHOW WARNINGS;我可以看到警告,但它没有出现在任何日志中。

我也试过启用一般日志和慢查询日志,但这些也没有显示警告。

我试过log_warnings = 1and log_warnings = 2,但仍然没有记录警告。

我究竟做错了什么?

mysql> show variables like '%error%';
+--------------------+--------------------------+
| Variable_name      | Value                    |
+--------------------+--------------------------+
| error_count        | 0                        |
| log_error          | /var/log/mysql/mysql.err |
| max_connect_errors | 10                       |
| max_error_count    | 1024                     |
| slave_skip_errors  | OFF                      |
+--------------------+--------------------------+

mysql> show variables like '%warn%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_warnings  | 1     |
| sql_warnings  | OFF   |
| warning_count | 0     |
+---------------+-------+
3 rows in set (0.06 sec)

mysql> show variables like '%log%';
+-----------------------------------------+-------------------------------+
| Variable_name                           | Value                         |
+-----------------------------------------+-------------------------------+
...
| general_log                             | ON                            |
| general_log_file                        | /var/log/mysql/general.log    |
...
| log                                     | ON                            |
...
| log_error                               | /var/log/mysql/mysql.err      |
| log_output                              | FILE                          |
| log_queries_not_using_indexes           | ON                            |
...
| log_warnings                            | 1                             |
...
| slow_query_log                          | ON                            |
| slow_query_log_file                     | /var/log/mysql/mysql-slow.log |
...
+-----------------------------------------+-------------------------------+
Run Code Online (Sandbox Code Playgroud)

编辑:

mysql> show global status like 'Aborted%';
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| Aborted_clients  | 24    |
| Aborted_connects | 15    |
+------------------+-------+
2 rows in set (0.08 sec)
Run Code Online (Sandbox Code Playgroud)

编辑:

澄清:我确实得到[Warning] Aborted connection 1 to db...[Warning] Access denied for user...记录了消息,但不是在SHOW WARNINGS插入某些内容或运行后您可以看到的警告,LOAD DATA INFILE...这正是我正在寻找的。

小智 4

来自:http://ushatry.blogspot.in/2011/02/mysql-bulk-import-and-logging-warnings.html

\n\n
/path/to/mysql --show-warnings \xe2\x80\x93uUserName \xe2\x80\x93pPassword DBNAME < /path/to/dump_file.sql >> /path/to/load_warnings.log 2>&1\n
Run Code Online (Sandbox Code Playgroud)\n