是否有任何查询/方法显示在所有服务器上执行的最后查询?
当前回答
你可以做流动的事情来监视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 binlog,可以通过执行命令查看用户执行的命令 以下命令在Linux控制台通过浏览到mysql binlog目录
mysqlbinlog binlog.000001 > /tmp/statements.sql
启用
[mysqld]
log = /var/log/mysql/mysql.log
或者一般的日志会对mysql的性能有影响
您可以为这种诊断启用一般查询日志。但是,通常不会在生产服务器上记录所有SELECT查询,这是性能杀手。
编辑你的MySQL配置,例如/etc/mysql/my.cnf -查找或添加如下一行
[mysqld]
log = /var/log/mysql/mysql.log
重新启动mysql以获取该更改,现在就可以了
tail -f /var/log/mysql/mysql.log
嘿,马上,你就可以看到输入的查询了。
对于那些拥有MySQL >= 5.1.12的人,你可以在运行时全局控制这个选项:
执行SET GLOBAL log_output = 'TABLE'; 执行SET GLOBAL general_log = 'ON'; 看一下mysql.general_log表
如果你喜欢输出到一个文件而不是一个表:
SET GLOBAL log_output = "FILE";默认值。 SET GLOBAL general_log_file = "/path/to/your/logfile.log"; SET GLOBAL general_log = 'ON';
与编辑.cnf文件相比,我更喜欢这种方法,因为:
您没有编辑my.cnf文件,也没有可能永久地打开日志记录 您不必在文件系统中寻找查询日志——或者更糟的是,不必因为需要完美的目的地而分心。/var/log /var/data/log /opt /home/ mysql_救世主/var 您不必重新启动服务器并中断到它的任何当前连接。 重新启动服务器会让您回到开始时的位置(默认情况下日志仍然关闭)
有关更多信息,请参见 MySQL 5.1参考手册-服务器系统变量- general_log . zip
您可以在linux中查看以下内容
cd /root
ls -al
vi .mysql_history可能有帮助
你可以做流动的事情来监视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中检测值是否为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数据类型的默认值?