是否有任何查询/方法显示在所有服务器上执行的最后查询?
当前回答
读完保罗的回答后,我继续在https://dev.mysql.com/doc/refman/5.7/en/query-log.html上挖掘更多信息
我发现了一个非常有用的代码。这里是上下文的摘要。
(注:以下代码不是我的)
这个脚本是一个保持表整洁的示例,这将帮助您减少表的大小。一天之后,将会有大约180k的日志查询。(在一个文件中,每天是30MB)
你需要添加一个额外的列(event_unix),然后你可以使用这个脚本来保持日志干净…它会将时间戳更新为unix时间戳,删除超过1天的日志,然后将event_time从event_unix更新为timestamp…听起来有点混乱,但效果很好。
新列的命令:
SET GLOBAL general_log = 'OFF';
RENAME TABLE general_log TO general_log_temp;
ALTER TABLE `general_log_temp`
ADD COLUMN `event_unix` int(10) NOT NULL AFTER `event_time`;
RENAME TABLE general_log_temp TO general_log;
SET GLOBAL general_log = 'ON';
清理脚本:
SET GLOBAL general_log = 'OFF';
RENAME TABLE general_log TO general_log_temp;
UPDATE general_log_temp SET event_unix = UNIX_TIMESTAMP(event_time);
DELETE FROM `general_log_temp` WHERE `event_unix` < UNIX_TIMESTAMP(NOW()) - 86400;
UPDATE general_log_temp SET event_time = FROM_UNIXTIME(event_unix);
RENAME TABLE general_log_temp TO general_log;
SET GLOBAL general_log = 'ON';
这要归功于Sebastian Kaiser(代码的原始作者)。
希望有人会像我一样觉得它有用。
其他回答
读完保罗的回答后,我继续在https://dev.mysql.com/doc/refman/5.7/en/query-log.html上挖掘更多信息
我发现了一个非常有用的代码。这里是上下文的摘要。
(注:以下代码不是我的)
这个脚本是一个保持表整洁的示例,这将帮助您减少表的大小。一天之后,将会有大约180k的日志查询。(在一个文件中,每天是30MB)
你需要添加一个额外的列(event_unix),然后你可以使用这个脚本来保持日志干净…它会将时间戳更新为unix时间戳,删除超过1天的日志,然后将event_time从event_unix更新为timestamp…听起来有点混乱,但效果很好。
新列的命令:
SET GLOBAL general_log = 'OFF';
RENAME TABLE general_log TO general_log_temp;
ALTER TABLE `general_log_temp`
ADD COLUMN `event_unix` int(10) NOT NULL AFTER `event_time`;
RENAME TABLE general_log_temp TO general_log;
SET GLOBAL general_log = 'ON';
清理脚本:
SET GLOBAL general_log = 'OFF';
RENAME TABLE general_log TO general_log_temp;
UPDATE general_log_temp SET event_unix = UNIX_TIMESTAMP(event_time);
DELETE FROM `general_log_temp` WHERE `event_unix` < UNIX_TIMESTAMP(NOW()) - 86400;
UPDATE general_log_temp SET event_time = FROM_UNIXTIME(event_unix);
RENAME TABLE general_log_temp TO general_log;
SET GLOBAL general_log = 'ON';
这要归功于Sebastian Kaiser(代码的原始作者)。
希望有人会像我一样觉得它有用。
你可以做流动的事情来监视mysql查询日志。
打开mysql配置文件my.cnf
sudo nano /etc/mysql/my.cnf
搜索[mysqld]标题下的以下行,并取消这些行注释以启用日志
general_log_file = /var/log/mysql/mysql.log
general_log = 1
重新启动mysql服务器以反映更改
sudo service mysql start
在终端中使用以下命令监视mysql服务器日志
tail -f /var/log/mysql/mysql.log
如果你不想改变你的MySQL配置,你可以使用SQL分析器,如“Neor Profile SQL”http://www.profilesql.com。
也许您可以通过查看查询日志来找到这一点。
您可以为这种诊断启用一般查询日志。但是,通常不会在生产服务器上记录所有SELECT查询,这是性能杀手。
编辑你的MySQL配置,例如/etc/mysql/my.cnf -查找或添加如下一行
[mysqld]
log = /var/log/mysql/mysql.log
重新启动mysql以获取该更改,现在就可以了
tail -f /var/log/mysql/mysql.log
嘿,马上,你就可以看到输入的查询了。
推荐文章
- 在MySQL中检测值是否为number
- MySQL中两个日期之间的差异
- 为什么在MySQL中文本列不能有一个默认值?
- 使用SQL查询查找最近的纬度/经度
- 有nginx access_log和error_log日志的STDOUT和STDERR的主进程
- 如何停止mysqld
- 检查MySQL表是否存在而不使用“select from”语法?
- 从NOW() -1天选择记录
- 从表中选择1是什么意思?
- 在Python Django中运行单元测试时,如何禁用日志记录?
- 数据库性能调优有哪些资源?
- 如何更改表的默认排序规则?
- MySQL foreign_key_checks是否影响整个数据库?
- 哪里是logging.config.dictConfig的完整示例?
- 设置NOW()为datetime数据类型的默认值?