mysql.log日志放在哪

mysql.log日志放在哪,第1张

MySQL日志在哪

MySQL日志一般保存在/var/log/目录下,但还需要看具体的配置文件才能确定,具体方法如下:

1、首先登陆 mysql:>mysql -u root -p

2、然后查看是否启用了日志mysql>show variables like 'log_%'

3、查看当前的日志mysql>show master status

4、你需要知道的mysql的日志类型:错误日志: -log-err

查询日志: -log

慢查询日志: -log-slow-queries

更新日志: -log-update

二进制日志: -log-bin

5、修改配置/etc/my.cnf(以下为日志文件保存位置)[mysqld]

log=/var/log/mysqld_common.log

log-error=/var/log/mysqld_err.log

log-bin=/var/log/mysqld_bin.bin

可通过以下语句查看日志存放路径:

show variables like 'general_log_file'结果:

其中,如图所示红框部分即为mysql日志文件的存放路径及文件名。

有时候我们会不小心对一个大表进行了 update,比如说写错了 where 条件......

此时,如果 kill 掉 update 线程,那回滚 undo log 需要不少时间。如果放置不管,也不知道 update 会持续多久。

那我们能知道 update 的进度么?

实验

我们先创建一个测试数据库:

快速创建一些数据:

连续执行同样的 SQL 数次,就可以快速构造千万级别的数据:

查看一下总的行数

我们来释放一个大的 update:

然后另起一个 session,观察 performance_schema 中的信息:

可以看到,performance_schema 会列出当前 SQL 从引擎获取的行数。

等 SQL 结束后,我们看一下 update 从引擎总共获取了多少行:

可以看到该 update 从引擎总共获取的行数是表大小的两倍,那我们可以估算:update 的进度 = (rows_examined) / (2 * 表行数)

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6786654.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存