首页数据库mysql数据库操作日志 如何查看mysql数据库操作记录日志

mysql数据库操作日志 如何查看mysql数据库操作记录日志

编程之家2023-10-1998次浏览

大家好,关于mysql数据库操作日志很多朋友都还不太明白,今天小编就来为大家分享关于如何查看mysql数据库操作记录日志的知识,希望对各位有所帮助!

mysql数据库操作日志 如何查看mysql数据库操作记录日志

如何查看mysql数据库操作记录日志

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

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

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

实验

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

快速创建一些数据:

mysql数据库操作日志 如何查看mysql数据库操作记录日志

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

查看一下总的行数:

我们来释放一个大的 update:

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

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

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

mysql数据库操作日志 如何查看mysql数据库操作记录日志

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

💡小贴士

information_schema.tables中,提供了对表行数的估算,比起使用 select count(1)的成本低很多,几乎可以忽略不计。

那么是不是所有的 update,从引擎中获取的行数都会是表大小的两倍呢?这个还是要分情况讨论的,上面的 SQL更新了主键,如果只更新内容而不更新主键呢?我们来试验一下:

等待 update结束,查看 row_examined,发现其刚好是表大小:

那我们怎么准确的这个倍数呢?

一种方法是靠经验:update语句的 where中会扫描多少行,是否修改主键,是否修改唯一键,以这些条件来估算系数。

另一种方法就是在同样结构的较小的表上试验一下,获取倍数。

这样,我们就能准确估算一个大型 update的进度了。

请教:如何查看mysql数据定义操作的日志

一.错误日志

错误日志在Mysql数据库中很重要,它记录着mysqld启动和停止,以及服务器在运行过程中发生的任何错误的相关信息。

1.配置信息

--log-error=[file-name]用来指定错误日志存放的位置。

如果没有指定[file-name],默认hostname.err做为文件名,默认存放在DATADIR目录中。

也可以将log-error配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定--log-error.例如:

[mysql@test2]$ vi/etc/my.cnf

# The MySQL server

[mysqld]

....

log-error=/var/lib/mysql/test2_mysqld.err

.....

2.错误信息样板

080313 05:21:55 mysqld started

080313 5:21:55 InnoDB: Started; log sequence number 0 43655

080313 5:21:55 [Note]/usr/local/mysql/bin/mysqld: ready for connections.

Version:'5.0.26-standard-log' socket:'/var/lib/mysql/mysql.sock' port: 3306 MySQL Community Edition- Standard(GPL)

080313 5:24:13 [Note]/usr/local/mysql/bin/mysqld: Normal shutdown

080313 5:24:13 InnoDB: Starting shutdown...

080313 5:24:16 InnoDB: Shutdown completed; log sequence number 0 43655

080313 5:24:16 [Note]/usr/local/mysql/bin/mysqld: Shutdown complete

080313 05:24:16 mysqld ended

080313 05:24:47 mysqld started

080313 5:24:47 InnoDB: Started; log sequence number 0 43655

080313 5:24:47 [Note]/usr/local/mysql/bin/mysqld: ready for connections.

Version:'5.0.26-standard-log' socket:'/var/lib/mysql/mysql.sock' port: 3306 MySQL Community Edition- Standard(GPL)

080313 5:33:49 [Note]/usr/local/mysql/bin/mysqld: Normal shutdown

三.查询日志

查询日志记录了clinet的所有的语句。

Note:由于log日志记录了数据库所有操作,对于访问频繁的系统,此种日志会造成性能影响,建议关闭。

1.配置信息

--log=[file-name]用来指定错误日志存放的位置。

如果没有指定[file-name],默认为主机名(hostname)做为文件名,默认存放在DATADIR目录中。

也可以将log配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定--log.例如:

# The MySQL server

[mysqld]

......

#query-log

log=/var/lib/mysql/query_log.log

......

2.读取查询日志

查询日志是纯文本格可,可以使用OS文本读取工具直接打开查看。例如:

[mysql@test2]$ tail-n 15 query_log.log

080313 7:58:28 17 Query show tables

080313 8:07:45 17 Quit

080313 10:01:48 18 Connect root@localhost on

080313 10:02:38 18 Query SELECT DATABASE()

18 Init DB test

080313 10:02:42 18 Query show tables

080313 10:03:07 18 Query select* from pet

080313 10:06:26 18 Query insert into pet values('hunter','yxyup','cat','f','1996-04-29',null)

080313 10:06:39 18 Query select* from pet

080313 10:07:13 18 Query update pet set sex='m' where name='hunter'

080313 10:07:38 18 Query delete from pet where name='hunter'

080313 10:13:48 18 Query desc test8

080313 10:14:13 18 Query create table t1(id int,name char(10))

080313 10:14:41 18 Query alter table t1 add sex char(2)

[mysql@test2]$

四.慢查询日志

慢查询日志是记录了执行时间超过参数long_query_time(单位是秒)所设定值的SQL语句日志。

Note:慢查询日志对于我们发现性能有问题的SQL有很帮助,建议使用并经常分析

1.配置信息

--log-slow-queries=[file-name]用来指定错误日志存放的位置。

如果没有指定[file-name],默认为hostname-slow.log做为文件名,默认存放在DATADIR目录中。

也可以将log-slow-queries配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定--log-slow-queries.例如:

# The MySQL server

[mysqld]

......

#slow-query-log

log-slow-queries=/var/lib/mysql/slow_query_log.log

......

2.读取慢查询日志

[mysql@test2]$ cat slow_query_log.log

/usr/local/mysql/bin/mysqld, Version: 5.0.26-standard-log. started with:

Tcp port: 3306 Unix socket:/var/lib/mysql/mysql.sock

Time Id Command Argument

# Time: 080313 5:41:46

# User@Host: root[root]@ localhost []

# Query_time: 108 Lock_time: 0 Rows_sent: 0 Rows_examined: 8738

use test;

select count(1) from t1 a, t1 b,t1 c where a.id=b.id and b.name=c.name;

# Time: 080313 5:52:04

# User@Host: root[root]@ localhost []

# Query_time: 583 Lock_time: 0 Rows_sent: 0 Rows_examined: 508521177

select count(1) from t1 a, t1 b where a.id=b.id;

/usr/local/mysql/bin/mysqld, Version: 5.0.26-standard-log. started with:

Tcp port: 3306 Unix socket:/var/lib/mysql/mysql.sock

Time Id Command Argument

# Time: 080313 10:39:59

# User@Host: root[root]@ localhost []

# Query_time: 11 Lock_time: 0 Rows_sent: 4537467 Rows_examined: 4537467

use test;

select id from tail;

如果慢查询日志记录很多可以使用mysqldumpslow进行分类汇总

[mysql@test2]$ mysqldumpslow slow_query_log.log

Reading mysql slow query log from slow_query_log.log

Count: 1 Time=583.00s(583s) Lock=0.00s(0s) Rows=0.0(0), root[root]@localhost

select count(N) from t1 a, t1 b where a.id=b.id

Count: 1 Time=108.00s(108s) Lock=0.00s(0s) Rows=0.0(0), root[root]@localhost

select count(N) from t1 a, t1 b,t1 c where a.id=b.id and b.name=c.name

Count: 1 Time=11.00s(11s) Lock=0.00s(0s) Rows=4537467.0(4537467), root[root]@localhost

select id from tail;

mysql有以下几种日志:

错误日志:-log-err

查询日志:-log

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

更新日志:-log-update

二进制日志:-log-bin

在mysql的安装目录下,打开my.ini,在后面加上上面的参数,保存后重启mysql服务就行了。

例如:

#Enter a name for the binary log. Otherwise a default name will be used.

#log-bin=

#Enter a name for the query log file. Otherwise a default name will be used.

#log=

#Enter a name for the error log file. Otherwise a default name will be used.

log-error=

#Enter a name for the update log file. Otherwise a default name will be used.

#log-update=

查看日至:

1.首先确认你日志是否启用了

mysql>show variables like'log_bin';

如果启用了,即ON

那日志文件就在mysql的安装目录的data目录下

cat/tail日志文件名

2.怎样知道当前的日志

mysql> show master status;

3.查看从某一段时间到某一段时间的日志

mysqlbinlog--start-datetime='2008-01-19 00:00:00'

--stop-datetime='2008-01-30 00:00:00'/var/log/mysql/mysql-bin.000006

> mysqllog1.log

如何用phpmyadmin记录sql用户操作日志

1.启用查询日志,把这个在/etc/my.cnf在[mysqld]部分log=/path/to/query.log

这个日志文件会变得非常大的一个繁忙的服务器上更新:因为MySQL 5.1.12的你general_log=1

与MySQL 5.1.29,该log选项已被否决。来指定general_log_file=/path/to/query.log

代替。看

2.就拿这个回答另一个相关的问题一起来看看。它显示了如何启用,禁用和看直播服务器日志而不需要重新启动。登录mysql的所有查询这里是一个总结:如果你不想或者无法重新启动MySQL服务器,你可以继续这样你运行的服务器上:创建你的日志表(见答案)启用查询日志记录的数据库上(请注意,字符串'表'应该从字面上,而不是取代放任何表感谢尼古拉pg林)SET global general_log= 1;

SET global log_output='table';

查看日志select* from mysql.general_log

禁止对数据库的查询记录SET global general_log= 0;

3.您可以禁用或启用的一般查询日志(记录所有查询)与SET GLOBAL general_log= 1#(or 0 to disable)

4. MyAdmin 4.0 CodeGo.net,你去>监视器。在那里,您可以启用慢查询日志和一般日志,看现场监控,选择图表的一部分,请参阅相关的查询和分析。

5.你可以分析象PT-查询顾问的日志开源工具和有工具,以及像MONyog,MEM,JetProfiler等。你可以参考在查询分析器工具。

mysql数据库操作日志的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于如何查看mysql数据库操作记录日志、mysql数据库操作日志的信息别忘了在本站进行查找哦。

数据库保护?数据库的数据保护包括:()和()数据库时间格式转换 数据库时间格式的转换