当前位置:Gxlcms > 数据库问题 > mysql日志管理笔记

mysql日志管理笔记

时间:2021-07-01 10:21:17 帮助过:3人阅读

       log_error  #错误日志

       log_warnings  #警告信息也要记录到错误日志中;0:表示不记录;1表示记录

log_error=/PATH/TO/ERROR_LOG_FILENAME

定义错误日志文件。作用范围为全局或会话级别,可用于配置文件,属非动态变量。

log_warnings=#

设定是否将警告信息记录进错误日志。默认设定为1,表示启用;可以将其设置为0以禁用;而其值为大于1的数值时表示将新发起连接时产生的“失败的连接”和“拒绝访问”类的错误信息也记录进错误日志。

#都记录那些日志?

       服务器启动和关闭过程中的信息

       服务器运行过程中的错误信息

       事件调度器运行一个事件时产生的信息

       在从服务器上启动从服务器进程时产生的信息(主从复制mysql-sever)

2.一般查询日志:

       general_log

       general_log_file

       log

       log_output

log_output={TABLE|FILE|NONE} 定义一般查询日志和慢查询日志的保存方式,可以是TABLE、FILE、NONE,也可以是TABLE及FILE的组合(用逗号隔开),默认为TABLE。如果组合中出现了NONE,那么其它设定都将失效,同时,无论是否启用日志功能,也不会记录任何相关的日志信息。作用范围为全局级别,可用于配置文件,属动态变量。

general_log={ON|OFF}

设定是否启用查询日志,默认值为取决于在启动mysqld时是否使用了--general_log选项。如若启用此项,其输出位置则由--log_output选项进行定义,如果log_output的值设定为NONE,即使用启用查询日志,其也不会记录任何日志信息。作用范围为全局,可用于配置文件,属动态变量。

general_log_file=FILE_NAME

查询日志的日志文件名称,默认为“hostname.log"。作用范围为全局,可用于配置文件,属动态变量。

log={YES|NO}

是否启用记录所有语句的日志信息于一般查询日志(general query log)中,默认通常为OFF。MySQL

3.慢查询日志:跟慢查询日志相关的指令

       long_query_time

       log_slow_queries={YES|NO}

       slow_query_log                      

       slow_query_log_file     

log_slow_queries={YES|NO}

是否记录慢查询日志。慢查询是指查询的执行时间超出long_query_time参数所设定时长的事件。MySQL 5.6将此参数修改为了slow_query_log。作用范围为全局级别,可用于配置文件,属动态变量。

long_query_time=#

设定区别慢查询与一般查询的语句执行时间长度。这里的语句执行时长为实际的执行时间,而非在CPU上的执行时长,因此,负载较重的服务器上更容易产生慢查询。其最小值为0,默认值为10,单位是秒钟。它也支持毫秒级的解析度。作用范围为全局或会话级别,可用于配置文件,属动态变量。

slow_query_log={ON|OFF}

设定是否启用慢查询日志。0或OFF表示禁用,1或ON表示启用。日志信息的输出位置取决于log_output变量的定义,如果其值为NONE,则即便slow_query_log为ON,也不会记录任何慢查询信息。作用范围为全局级别,可用于选项文件,属动态变量。

slow_query_log_file=/PATH/TO/SOMEFILE

设定慢查询日志文件的名称。默认为hostname-slow.log,但可以通过--slow_query_log_file选项修改。作用范围为全局级别,可用于选项文件,属动态变量。

4.二进制日志:任何引起或可能引起数据库变化的操作;(DML,DCL)

       二进制的作用:复制、即时点恢复;--->命令mysqlbinlog

       二进制日志,有时记录语句,有时记录数据;

              create  database mydb;  update tb set salaris=salaris+1000;

              INSER INTO  tb SET Birthdate=CURRENT_TIME();

       二进制日志的格式:

              基于语句: statement

              基于行: row

              混合方式: mixed

       二进制日志事件:

              产生的时间

              相对位置

       二进制日志文件:

              索引文件

              二进制日志文件

       查看当前正在使用的二进制日志文件

       mysql> SHOW MASTER STATUS;

       mysql> SHOW BINARY LOGS;

       mysql> SHOW BINLOG EVENTS IN ‘二进制日志文件名‘ [FROM pos];

       mysql> PURGE BINARY LOGS TO ‘某二进制日志文件‘

       mysqlbinlog

              --start-datetime

              --stop-datetime

              --start-position

              --stop-position

5.中继日志

6.事务日志:ACID,将随机IO转换为顺序IO;INNODB有事务日志

mysql>show global  variables like ‘%log%‘;#查看跟 log事务变量的日志有哪些

       binlog_*#是二进制日志

       innodb_* #innodb的事务日志

       log_bin  #二进制日志

       sql_log_bin#是否手动启动二进制日志

       sql_log_off #手动启动日志文件

知识回顾:

用户及权限管理:

       ‘username‘@‘host‘

       password()

       --skip-grant-tables --skip-networking

       UPDATE mysql.user

 

 权限:

              服务管理类:super

              库: CREATE

              表: DELETE、ALTER

              列: INSERT, SELECT, UPDATE

       GRANT 权限,... ON [对象类型] db.{table|routine} TO ‘username‘@‘host‘ [IDENTIFIED BY ‘password‘];

       REVOKE 权限,... ON [对象类型] db.{table|routine} FROM ‘username‘@‘host‘;

       SHOW GRANTS FOR ‘username‘@‘host‘;

       CREATE USER ‘username‘@‘host‘ [IDENTIFIED BY ‘password‘];

       DROP USER ‘username‘@‘host‘;

       RENAME USER old_name TO new_name;

权限的操作命令举例:




查看当前数据库的所有用户:

select user,host,password from mysql.user;


给用户赋予super权限(super和ALL PRIVILEGES都可以):

GRANT super ON *.* TO ‘mysql‘@‘localhost‘;

GRANT ALL PRIVILEGES ON *.* TO ‘mysql‘@‘localhost‘;


删除用户的super权限(super和ALL PRIVILEGES都可以):

REVOKE super ON *.* FROM ‘mysql‘@‘localhost‘;

REVOKE ALL PRIVILEGES ON *.* FROM ‘mysql‘@‘localhost‘;

#查看赋予用户的权限  

SHOW GRANTS FOR ‘username‘@‘host‘;

#show grants for ‘mysql‘@‘localhost‘;

#mysql的问题处理

1.mysql登录密码忘记时的恢复操作:

  启动mysql_safe时传递两个参数:

    --skip-grant-tables  跳过授权表

    --skip-networking   为了安全,防止网络登录

备份:

mysqldump  -uroot -p    -R --opt  --databases   db >databases.sql

登录方式一:

修改/etc/init.d/mysqld

            $bindir/mysqld_safe --skip-grant-tables --skip-networking --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null 2>&1 &

      wait_for_pid created "$!" "$mysqld_pid_file_path"; return_value=$?

登录方式二:

在my.cnf配置中配置;

[mysqld]

skip-grant-tables

skip-networking

而后修改密码:

通过更新授权表方式直接修改其密码,而后移除此两个选项重启服务器:

UPDATE user SET PASSWORD=PASSWORD("123456") where User="root"

#客户端链接mysql数据库速度慢的问题

直接在my.cnf配置,关闭DNS的反向解析参数

[mysqld]

skip-name-resolve

日志:

       错误日志:

       一般查询日志:

       慢查询日志:

              log_output {TABLE|FILE|NONE}

       二进制日志:

              复制、即时点恢复

              二进制日志事件:

                     基于语句:statement

                     基于行:row

                     混合方式:mixed

              mysql> SHOW BINARY LOGS;

              mysql> SHOW MASTER STATUS;  #查看当前使用的二进制文件是那个?

              mysql> SHOW BINLOG EVENTS IN ‘二进制日志文件‘ FROM ‘position‘;

              mysql> PURGE BINARY LOGS TO ‘日志文件‘;

              mysql> FLUSH LOGS;

       mysqlbinlog

              --start-position

              --stop-position

              --start-datetime ‘yyyy-mm-dd hh:mm:ss‘

              --stop-datetime ‘‘;

 

中继日志:

              从主服务器的二进制日志文件中复制而来的事件,并保存为的日志文件;

事务日志:

       事务性存储引擎用于保证原子性、一致性、隔离性和持久性;

       innodb_flush_log_at_trx_commit:

              0: 每秒同步,并执行磁盘flush操作;

              1:每事务同步,并执行磁盘flush操作;

              2: 每事务同步,但不执行磁盘flush操作;

expire_logs_days={0..99}

设定二进制日志的过期天数,超出此天数的二进制日志文件将被自动删除。默认为0,表示不启用过期自动删除功能。如果启用此功能,自动删除工作通常发生在MySQL启动时或FLUSH日志时。作用范围为全局,可用于配置文件,属动态变量。

 

binlog-format={ROW|STATEMENT|MIXED}

指定二进制日志的类型,默认为STATEMENT。如果设定了二进制日志的格式,却没有启用二进制日志,则MySQL启动时会产生警告日志信息并记录于错误日志中。作用范围为全局或会话,可用于配置文件,且属于动态变量。

log-bin={YES|NO}

是否启用二进制日志,如果为mysqld设定了--log-bin选项,则其值为ON,否则则为OFF。其仅用于显示是否启用了二进制日志,并不反应log-bin的设定值。作用范围为全局级别,属非动态变量。

log_bin_trust_function_creators={TRUE|FALSE}

此参数仅在启用二进制日志时有效,用于控制创建存储函数时如果会导致不安全的事件记录二进制日志条件下是否禁止创建存储函数。默认值为0,表示除非用户除了CREATE ROUTING或ALTER ROUTINE权限外还有SUPER权限,否则将禁止创建或修改存储函数,同时,还要求在创建函数时必需为之使用DETERMINISTIC属性,再不然就是附带READS SQL DATA或NO SQL属性。设置其值为1时则不启用这些限制。作用范围为全局级别,可用于配置文件,属动态变量。

log_query_not_using_indexes={ON|OFF}

设定是否将没有使用索引的查询操作记录到慢查询日志。作用范围为全局级别,可用于配置文件,属动态变量。

log_slave_updates

用于设定复制场景中的从服务器是否将从主服务器收到的更新操作记录进本机的二进制日志中。本参数设定的生效需要在从服务器上启用二进制日志功能。

max_binlog_cache_size{4096 .. 18446744073709547520}

二进定日志缓存空间大小,5.5.9及以后的版本仅应用于事务缓存,其上限由max_binlog_stmt_cache_size决定。作用范围为全局级别,可用于配置文件,属动态变量。

max_binlog_size={4096 .. 1073741824}

设定二进制日志文件上限,单位为字节,最小值为4K,最大值为1G,默认为1G。某事务所产生的日志信息只能写入一个二进制日志文件,因此,实际上的二进制日志文件可能大于这个指定的上限。作用范围为全局级别,可用于配置文件,属动态变量。

max_relay_log_size={4096..1073741824}

设定从服务器上中继日志的体积上限,到达此限度时其会自动进行中继日志滚动。此参数值为0时,mysqld将使用max_binlog_size参数同时为二进制日志和中继日志设定日志文件体积上限。作用范围为全局级别,可用于配置文件,属动态变量。

innodb_log_buffer_size={262144 .. 4294967295}

设定InnoDB用于辅助完成日志文件写操作的日志缓冲区大小,单位是字节,默认为8MB。较大的事务可以借助于更大的日志缓冲区来避免在事务完成之前将日志缓冲区的数据写入日志文件,以减少I/O操作进而提升系统性能。因此,在有着较大事务的应用场景中,建议为此变量设定一个更大的值。作用范围为全局级别,可用于选项文件,属非动态变量。

innodb_log_file_size={108576 .. 4294967295}

设定日志组中每个日志文件的大小,单位是字节,默认值是5MB。较为明智的取值范围是从1MB到缓存池体积的1/n,其中n表示日志组中日志文件的个数。日志文件越大,在缓存池中需要执行的检查点刷写操作就越少,这意味着所需的I/O操作也就越少,然而这也会导致较慢的故障恢复速度。作用范围为全局级别,可用于选项文件,属非动态变量。

innodb_log_files_in_group={2 .. 100}

设定日志组中日志文件的个数。InnoDB以循环的方式使用这些日志文件。默认值为2。作用范围为全局级别,可用于选项文件,属非动态变量。

innodb_log_group_home_dir=/PATH/TO/DIR

设定InnoDB重做日志文件的存储目录。在缺省使用InnoDB日志相关的所有变量时,其默认会在数据目录中创建两个大小为5MB的名为ib_logfile0和ib_logfile1的日志文件。作用范围为全局级别,可用于选项文件,属非动态变量。

relay_log=file_name

设定中继日志的文件名称,默认为host_name-relay-bin。也可以使用绝对路径,以指定非数据目录来存储中继日志。作用范围为全局级别,可用于选项文件,属非动态变量。

relay_log_index=file_name

设定中继日志的索引文件名,默认为为数据目录中的host_name-relay-bin.index。作用范围为全局级别,可用于选项文件,属非动态变量。

relay-log-info-file=file_name

设定中继服务用于记录中继信息的文件,默认为数据目录中的relay-log.info。作用范围为全局级别,可用于选项文件,属非动态变量。

relay_log_purge={ON|OFF}

设定对不再需要的中继日志是否自动进行清理。默认值为ON。作用范围为全局级别,可用于选项文件,属动态变量。

relay_log_space_limit=#

设定用于存储所有中继日志文件的可用空间大小。默认为0,表示不限定。最大值取决于系统平台位数。作用范围为全局级别,可用于选项文件,属非动态变量。

sql_log_bin={ON|OFF}

用于控制二进制日志信息是否记录进日志文件。默认为ON,表示启用记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。

sql_log_off={ON|OFF}

用于控制是否禁止将一般查询日志类信息记录进查询日志文件。默认为OFF,表示不禁止记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。

sync_binlog=#

设定多久同步一次二进制日志至磁盘文件中,0表示不同步,任何正数值都表示对二进制每多少次写操作之后同步一次。当autocommit的值为1时,每条语句的执行都会引起二进制日志同步,否则,每个事务的提交会引起二进制日志同步。1.错误日志:

       log_error  #错误日志

       log_warnings  #警告信息也要记录到错误日志中;0:表示不记录;1表示记录

log_error=/PATH/TO/ERROR_LOG_FILENAME

定义错误日志文件。作用范围为全局或会话级别,可用于配置文件,属非动态变量。

log_warnings=#

设定是否将警告信息记录进错误日志。默认设定为1,表示启用;可以将其设置为0以禁用;而其值为大于1的数值时表示将新发起连接时产生的“失败的连接”和“拒绝访问”类的错误信息也记录进错误日志。

#都记录那些日志?

       服务器启动和关闭过程中的信息

       服务器运行过程中的错误信息

       事件调度器运行一个事件时产生的信息

       在从服务器上启动从服务器进程时产生的信息(主从复制mysql-sever)

2.一般查询日志:

       general_log

       general_log_file

       log

       log_output

log_output={TABLE|FILE|NONE} 定义一般查询日志和慢查询日志的保存方式,可以是TABLE、FILE、NONE,也可以是TABLE及FILE的组合(用逗号隔开),默认为TABLE。如果组合中出现了NONE,那么其它设定都将失效,同时,无论是否启用日志功能,也不会记录任何相关的日志信息。作用范围为全局级别,可用于配置文件,属动态变量。

general_log={ON|OFF}

设定是否启用查询日志,默认值为取决于在启动mysqld时是否使用了--general_log选项。如若启用此项,其输出位置则由--log_output选项进行定义,如果log_output的值设定为NONE,即使用启用查询日志,其也不会记录任何日志信息。作用范围为全局,可用于配置文件,属动态变量。

general_log_file=FILE_NAME

查询日志的日志文件名称,默认为“hostname.log"。作用范围为全局,可用于配置文件,属动态变量。

log={YES|NO}

是否启用记录所有语句的日志信息于一般查询日志(general query log)中,默认通常为OFF。MySQL

3.慢查询日志:跟慢查询日志相关的指令

       long_query_time

       log_slow_queries={YES|NO}

       slow_query_log                      

       slow_query_log_file     

log_slow_queries={YES|NO}

是否记录慢查询日志。慢查询是指查询的执行时间超出long_query_time参数所设定时长的事件。MySQL 5.6将此参数修改为了slow_query_log。作用范围为全局级别,可用于配置文件,属动态变量。

long_query_time=#

设定区别慢查询与一般查询的语句执行时间长度。这里的语句执行时长为实际的执行时间,而非在CPU上的执行时长,因此,负载较重的服务器上更容易产生慢查询。其最小值为0,默认值为10,单位是秒钟。它也支持毫秒级的解析度。作用范围为全局或会话级别,可用于配置文件,属动态变量。

slow_query_log={ON|OFF}

设定是否启用慢查询日志。0或OFF表示禁用,1或ON表示启用。日志信息的输出位置取决于log_output变量的定义,如果其值为NONE,则即便slow_query_log为ON,也不会记录任何慢查询信息。作用范围为全局级别,可用于选项文件,属动态变量。

slow_query_log_file=/PATH/TO/SOMEFILE

设定慢查询日志文件的名称。默认为hostname-slow.log,但可以通过--slow_query_log_file选项修改。作用范围为全局级别,可用于选项文件,属动态变量。

4.二进制日志:任何引起或可能引起数据库变化的操作;(DML,DCL)

       二进制的作用:复制、即时点恢复;--->命令mysqlbinlog

       二进制日志,有时记录语句,有时记录数据;

              create  database mydb;  update tb set salaris=salaris+1000;

              INSER INTO  tb SET Birthdate=CURRENT_TIME();

       二进制日志的格式:

              基于语句: statement

              基于行: row

              混合方式: mixed

       二进制日志事件:

              产生的时间

              相对位置

       二进制日志文件:

              索引文件

              二进制日志文件

       查看当前正在使用的二进制日志文件

       mysql> SHOW BINARY LOGS;#查看当前仍拥有的二进制日志文件

              mysql> SHOW MASTER STATUS;  #查看当前使用的二进制文件是那个?

              mysql> SHOW BINLOG EVENTS IN ‘二进制日志文件‘ FROM ‘position‘;

              mysql> PURGE BINARY LOGS TO ‘日志文件‘;

              mysql> FLUSH LOGS; 实现日志滚动

       mysqlbinlog

              --start-datetime

              --stop-datetime

              --start-position

              --stop-position

5.中继日志

6.事务日志:ACID,将随机IO转换为顺序IO;INNODB有事务日志

mysql>show global  variables like ‘%log%‘;#查看跟 log事务变量的日志有哪些

       binlog_*#是二进制日志

       innodb_* #innodb的事务日志

       log_bin  #二进制日志

       sql_log_bin#是否手动启动二进制日志

       sql_log_off #手动启动日志文件

知识回顾:

用户及权限管理:

       ‘username‘@‘host‘

       password()

       --skip-grant-tables --skip-networking

       UPDATE mysql.user

       权限:

              服务管理类:super

              库: CREATE

              表: DELETE、ALTER

              列: INSERT, SELECT, UPDATE

       GRANT 权限,... ON [对象类型] db.{table|routine} TO ‘username‘@‘host‘ [IDENTIFIED BY ‘password‘];

       REVOKE 权限,... ON [对象类型] db.{table|routine} FROM ‘username‘@‘host‘;

       SHOW GRANTS FOR ‘username‘@‘host‘;

       CREATE USER ‘username‘@‘host‘ [IDENTIFIED BY ‘password‘];

       DROP USER ‘username‘@‘host‘;

       RENAME USER old_name TO new_name;

日志:

       错误日志:

       一般查询日志:

       慢查询日志:

              log_output {TABLE|FILE|NONE}

       二进制日志:

              复制、即时点恢复

              二进制日志事件:

                     基于语句:statement

                     基于行:row

                     混合方式:mixed

                  (二进制日志文件) 对数据安全性和可读性,建议分开放

       mysql> SHOW BINARY LOGS;#查看当前仍拥有的二进制日志文件

              mysql> SHOW MASTER STATUS;  #查看当前使用的二进制文件是那个?

              mysql> SHOW BINLOG EVENTS IN ‘二进制日志文件‘ FROM ‘position‘;

              mysql> PURGE BINARY LOGS TO ‘日志文件‘; #清除日志文件

              mysql> FLUSH LOGS; 实现日志滚动

       mysql>INSERT INTO tutors (Tname,Gender,Age) VAVLUE (‘stu100’,’M’,30);

       mysql>show binlog events in ‘mysql-bin.00001’;

1.指定开始\结束位置,从上面的查看产生的binary log我们可以知道某个log的开始到结束的位置,我们可以在恢复的过程中指定回复从A位置到B位置的log.需要用下面两个参数来指定:

       mysqlbinlog

              --start-position = ‘‘ // 指定从某位置开始

              --stop-position =‘‘  //指定到某位置结束

              --start-datetime ‘yyyy-mm-dd hh:mm:ss‘

              --stop-datetime ‘‘;

2.查看最后一个bin日志文件是那个,现在的位置

show master status;

3.启用新的日志文件,一般备份玩数据库后执行。

flush logs;

4.清空现有的所有bin-log

reset master;

#查看mysql服务器是否开启二进制文件

show variables like  ‘%bin%‘     #查看bin-log

二进制日志文件,不能用cat来查看,要用mysqlbinlog命令来查看

       实例:[root@www data]# mysqlbinlog  mysql-bin.000010

       [root@www data]# mysqlbinlog  --start-position=107 --stop-position=339 mysql-bin.000010

       [root@www data]# mysqlbinlog  --start-datetime=‘2015-01-08 17:09:21‘  mysql-bin.000010;

1.最长用的就是恢复指定数据端的数据了,可以直接恢复到数据库中:

        [root@www data]# mysqlbinlog  --start-datetime=‘2015-01-08 17:09:21‘  --stop-date=‘2016-01-08 17:09:21‘  mysql-bin.000010 >/root/a.sql

中继日志:

              从主服务器的二进制日志文件中复制而来的事件,并保存为的日志文件;

事务日志:

       事务性存储引擎用于保证原子性、一致性、隔离性和持久性;

       innodb_flush_log_at_trx_commit:#(二进制日志文件)

              0: 每秒钟同步,(事务提交并没有操作,)并执行磁盘flush操作;

              1:每事务同步,并执行磁盘flush操作;

              2: 每事务同步,但不执行磁盘flush操作;

  MyISAM:   (特点)

          不支持事务

           表锁

            不支持外键

            B树索引 、FULLTEXT索引、空间索引

            支持表压缩

  .frm

  .MYD

  .MYI

InnoDB:

 事务w

 行级锁

 B树索引、聚簇索引、自适应hash索引

 表空间,raw磁盘设备;

  .frm

  .ibd

MRG_MYISAM:(工作在MyISAM之上(特殊的引擎))

    能够将两个MyISAM的表,当作一个表来使用;

expire_logs_days={0..99}

人气教程排行