mysql日志查看开启与用法

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=  
上面只开启了错误日志,要开其他的日志就把前面的“#”去掉  
查看命令:  
①show variables like 'log_%';查看所有的log命令  
②show variables like 'log_bin';查看具体的log命令  
=================================  
linux MySQL 日志管理开启错误日志 (在[safe_mysqld]项下添加)  
# vi /etc/my.cnf[safe_mysqld]err-log=/var/log/mysqld/err.log  
开启常规日志和更新日志 (在[mysqld]项下添加)  # 
vi 
/etc/my.cnf[mysqld]log=/var/log/mysqld/log.loglog-update=/var/log/mysqld/update.
log创建日志文件并设置权限  
# mkdir /var/log/mysqld  
# touch /var/log/mysqld/err.log /var/log/mysqld/log.log /var/log/mysqld/update.log# chown -R mysql.mysql /var/log/mysqld  


零基础学MySQL数据库如何使用触发器如何创建联接表



# service mysqld restart说明:错误日志包含了服务器写入标准错误输出设备的所有消息,同时还包括了mysql服务的启动和关闭事件常规日志用来记录有关mysql服务器运行的常规信息.  
包括用户的连接、查询及其他各种时间更新日志用来记录修改数据库的查询信息,包括所有涉及数据库修改的SQl语句的查询记录建议调试结束后关闭日志  
 
=======================================================================  
mysql 日志文件的使用 收藏  
MYSQL有不同类型的日志文件(各自存储了不同类型的日志),从它们当中可以查询到MYSQL里都做了些什么,对于MYSQL的管理工作,这些日志文件是不可缺少的。 
1.错误日志(The error log):记录了数据库启动、运行以及停止过程中错误信息; 2.ISAM操作日志(The isam log):记录了所有对ISAM表的修改,该日志仅仅用于调试ISAM模式; 
3.SQL执行日志(The query log):记录了客户端的连接以及所执行的SQL语句; 
4.更新日志(The update log):记录了改变数据的语句,已经不建议使用,由二进制日志替代; 
5.二进制日志(The binary log):记录了所有对数据库数据的修改语句; 
6.超时日志(The slow log):记录所有执行时间超过最大SQL执行时间(long_query_time)或未使用索引的语句;  
如果你是在用mysql的复制、备份功能,那么从服务器还提供了一种叫做relay log的日志文件。 
 
默认情况下所有日志文件会记录在MYSQL的数据目录下,你可以通过强制mysql去关闭并重新打开一个文件进行日志记录,当然系统会自动加后缀 (如.00001, .00002),方式有在mysql环境下执行语句 mysql>flush logs; 或者通过mysqladmin管理程序执行 #mysqladmin flush-logs 或 #mysqladmin refresh 
 
这些日志的启动方式可以在mysqld_safe方式启动数据库的时候,后面跟选项参数,也可以在配置文件里配置,推荐采用第二种方式,配置方法很简单,我只配置了三种日志:  
[mysqld] 
log=/var/log/mysqld_common.log log-error=/var/log/mysqld_err.log log-bin=/var/log/mysqld_bin.bin  
 
日志的查看很简单,大部分都是文本,直接用vim、less、more之类的工具看就可以了,值得说明的是二进制文件的查看:  
1). 首先确定是否开启了二进制文件记录功能 






mysql>show variables like 'log_bin'; 
 
2). 如果你想知道现在记录二进制数据的文件具体信息,你可以通过下列语句看到现在正在记录哪个文件,以及记录的当前位置: mysql>show master status; 
 
3). 查看二进制数据需要借助程序mysqlbinlog,看看它支持哪些选项,根据自己需要来使用。 
mysql>mysqlbinlog /var/log/mysql/mysql-bin.000040; 
查询某个时间范围的可以执行下列语句,如果记录很多可以将结果定向到一个文件里自己慢慢看:-) : mysql>mysqlbinlog 
--start-datetime='2008-01-01 00:00:00' 
--stop-datetime='2008-08-08 00:00:00' 
 
/var/log/mysql/mysql-bin.000040 
> ./tmp.log   
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/tsuliuchao/archive/2009/12/14/500545有关MySQL的日志文件前面章节已简要讨论过了,主要有四种日志文件,分别是常规查询日志、慢查询日志、变更查询日志和二进制变更日志。这些日志文件的创建需在启动服务器时用选项指定。  
Table 4.3. 日志启动选项  
启动选项 激活日志  
--log[=file_name] 常规日志文件  
--log-bin[=file_name] 二进制变更日志文件  
--log-bin-index=file_name 二进制变更日志文件索引文件  --log-update[=file_name] 变更日志文件  
--log-slow-queries[=file_name] 慢查询日志文件  --log-isam[=file_name] ISAM/MyISAM日志文件  --log-long-format 设置慢查询日志和变更日志的格式   
BDB和InnoDB数据表的日志文件会自动创建不用指定选项。但可用以下选项指时日志文件的存放路径。 
 
Table 4.4. BDB和InnoDB数据表日志选项  
启动选项 用途  
--bdb-logdir=dir_name 存放BDB日志文件的位置  
--innodb-log_arch_dir=dir_name 存放InnoDB日志文件的归档目录  --innodb_log_group_home_dir=dir_name 存放InnoDB日志文件的位置  
 
MySQL日志文件选项可在mysqld和mysqld_safe脚本中使用,也可在选项文件my.cnf的[mysqld]中使用。推荐在选项文件中使用,因为每次启动服务器的日志选项基本上都是一致






的。 
 
日志的刷新可用mysqladmin flush-logs命令或flush logs语句实现。另外,对MySQL服务器发送一条SIGHUP信号也会刷新日志。错误日志和DBD/InnoDB日志不能用以上方法刷新。  
错误日志记录MySQL数据库系统的论断和出错信息,由mysqld_safe脚本创建,文件名默认为hostname.err,也可通过--err-log或选项文件的err-log语句指定另外的名字。如果直接用mysqld程序启动服务器,错误信息会直接输出到输出设备,也就是屏幕。但我们可用重定向方法把错误信息输出到其它地方,如把错误信息输出到/var/log/mysql.err文件中,可以执行以下语句:  
% mysqld > /var/log/mysql.err 2>&1 & 
 
在windows平台下,MySQL服务器默认把诊断信息写到数据目录的mysql.err文件中,并且不允许另外指定错误日志文件名。如在启动MySQL服务器时给出了--console选项,则MySQL会把诊断信息输出到控制台窗口而不创建错误日志。但如MySQL是作为一个服务运行,则--console选项不起作用。  
4.5.1. 日志失效处理 
在服务器正常运行中,会产生大量的日志文件。我们要对这些日志文件进行失效管理,以节省磁盘空间和方便查询。进行日志失效处理的方式主要有以下几种: 
 
日志轮转。该方法适用于常规查询日志和慢查询日志这些文件名固定的日志文件,在日志轮转时,应进行日志刷新操作(mysqladmin flush-logs命令或flush logs语句),以确保缓存在内存中的日志信息写入磁盘; 
 
日志轮转的操作过程是这样的:第一次轮转时,把log更名为log.1,然后服务器再创建一个新的log文件,在第二轮转时,再把log.1更名为log.2,把log更名为log.1,然后服务器再创建一个新的log文件。如此循环,创建一系列的日志文件。当到达日志轮转失效位置时,下次轮转就不再对它进行更名,直接把最后一个日志文件覆盖掉。例如:如果每天进行一次日志轮转并想保留最后7天的日志文件,就需要保留log.1--log.7共七个日志文件,等下次轮转时,用log.6覆盖原来的log.7成新的log.7,原来的log.7就自然失效。下面是一个失效处理的shell脚本,以供参考:  
#!/bin/sh 
# shell script ---  rotate_log.sh  
if [ $# -ne 1 ]; then 
   echo "Usage: $0 logname" 1>&2    exit 1 if 
 
logfile=$1  






mv $logfile.6 $logfile.7 mv $logfile.5 $logfile.6 mv $logfile.4 $logfile.5 mv $logfile.3 $logfile.4 mv $logfile.2 $logfile.3 mv $logfile.1 $logfile.2 mv $logfile $logfile.1 
mysqladmin -u flush -pflushpass flush-logs     #执行mysqladmin flush-logs会打开一个日志文件----重新生成一个新的日志文件  
该脚本以日志文件名为参数,执行方法如下:  
% rotate_log.sh /usr/local/mysql/data/log  
注意,脚本中的mysqladmin命令是带有-u和-p参数的,因为我们进行日志刷新时需连接服务器。为确保安全,我们建立一个flush用户,密码为flushpass。该用户只有日志刷新的权限(reload权限)。创建该用户的语句如下:  
GRANT RELOAD ON *.* TO 'flush'@'localhost' IDENTIFIED BY 'fulshpass'; 
 
设置好后,我们就可利用系统的自动处理机制定期运行该脚本以生成轮转日志。在Linux系统上的MySQL发行版中带有一个用来安装mysql-log-rotate日志轮转脚本的logrotate工具,如用RPM安装,则在/usr/share/mysql目录,如用二进制方式安装,则在MySQL安装目录的support-files目录,如用源码安装,则在安装目录的share/mysql目录中。  
在windows平台下,不能在线更名,需停掉服务器,再进行。下面是一个进行日志更名的批处理文件: 
 
@echo off 
REM script name : rotate_log.bat  
if not "%1" == "" goto ROTATE  
   @echo Usage: rotate_log logname    goto DONE  :ROTATE 
set logfile=%1 erase %logfile%.7 
rename %logfile%.6 %logfile%.7 rename %logfile%.5 %logfile%.6 rename %logfile%.4 %logfile%.5 rename %logfile%.3 %logfile%.4 rename %logfile%.2 %logfile%.3 






你可能感兴趣的:(mysql)