【Mysql5.7数据目录和配置文件目录】

Win7下html

C:\ProgramData\MySQL\MySQL Server 5.7\mysql

如何查看mysql运行、访问记录等日志 sql

1.首先确认你日志是否启用了
mysql>show variables like 'log_bin';
2.若是启用了,即ON
那日志文件就在mysql的安装目录的data目录下
3.怎样知道当前的日志
mysql> show master status;                                                                                                                                               
4.看二进制日志文件用mysqlbinlog
shell>mysqlbinlog mail-bin.000001
或者shell>mysqlbinlog mail-bin.000001 | tail
Windows 下用相似的
 
 

MySQL配置文件mysql.ini参数详解shell

http://www.cnblogs.com/feichexia/archive/2012/11/27/mysqlconf.html数据库

 

   my.ini(Linux系统下是my.cnf),当mysql服务器启动时它会读取这个文件,设置相关的运行环境参数。windows

   my.ini分为两块:Client Section和Server Section。
   Client Section用来配置MySQL客户端参数。
   要查看配置参数能够用下面的命令:缓存

show variables like '%innodb%'; # 查看innodb相关配置参数安全

show status like '%innodb%'; # 查看innodb相关的运行时参数(好比当前正在打开的表的数量,当前已经打开的表的数量)服务器

show global status like 'open%tables'; # 查看全局的运行时参数,加上global是对当前mysql服务器中运行的全部数据库实例进行统计。不加global则只对当前数据库实例进行统计。
 session

一、Client Section
    [client]
    port = 3306 # 设置mysql客户端链接服务端时默认使用的端口
    [mysql]
    default-character-set=utf8 # 设置mysql客户端默认字符集

 

二、Server Section


[mysqld]
port=3306 # mysql服务端默认监听(listen on)的TCP/IP端口

basedir="C:/Program Files/MySQL/MySQL Server 5.5/" # 基准路径,其余路径都相对于这个路径

datadir="C:/Program Files/MySQL/MySQL Server 5.5/Data" # mysql数据库文件所在目录

character-set-server=latin1 # 服务端使用的字符集默认为8比特编码的latin1字符集

default-storage-engine=INNODB # 建立新表时将使用的默认存储引擎

sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" # SQL模式为strict模式

max_connections=100 # mysql服务器支持的最大并发链接数(用户数)。但总会预留其中的一个链接给管理员使用超级权限登陆,即便链接数目达到最大限制。若是设置得太小而用户比较多,会常常出现“Too many connections”错误。

query_cache_size=0 # 查询缓存大小,用于缓存SELECT查询结果。若是有许多返回相同查询结果的SELECT查询,而且不多改变表,能够设置query_cache_size大于0,能够极大改善查询效率。而若是表数据频繁变化,就不要使用这个,会拔苗助长

table_cache=256 # 这个参数在5.1.3以后的版本中叫作table_open_cache,用于设置table高速缓存的数量。因为每一个客户端链接都会至少访问一个表,所以此参数的值与 max_connections有关。当某一链接访问一个表时,MySQL会检查当前已缓存表的数量。若是该表已经在缓存中打开,则会直接访问缓存中的表已加快查询速度;若是该表未被缓存,则会将当前的表添加进缓存并进行查询。在执行缓存操做以前,table_cache用于限制缓存表的最大数目:若是当前已经缓存的表未达到table_cache,则会将新表添加进来;若已经达到此值,MySQL将根据缓存表的最后查询时间、查询率等规则释放以前的缓存。

tmp_table_size=34M # 内存中的每一个临时表容许的最大大小。若是临时表大小超过该值,临时表将自动转为基于磁盘的表(Disk Based Table)。

thread_cache_size=8 # 缓存的最大线程数。当客户端链接断开时,若是客户端总链接数小于该值,则处理客户端任务的线程放回缓存。在高并发状况下,若是该值设置得过小,就会有不少线程频繁建立,线程建立的开销会变大,查询效率也会降低。通常来讲若是在应用端有良好的多线程处理,这个参数对性能不会有太大的提升。


# MyISAM相关参数
myisam_max_sort_file_size=100G # mysql重建索引时容许使用的临时文件最大大小

myisam_sort_buffer_size=68M

key_buffer_size=54M # Key Buffer大小,用于缓存MyISAM表的索引块。决定数据库索引处理的速度(尤为是索引读)

read_buffer_size=64K # 用于对MyISAM表全表扫描时使用的缓冲区大小。针对每一个线程进行分配(前提是进行了全表扫描)。进行排序查询时,MySql会首先扫描一遍该缓冲,以免磁盘搜索,提升查询速度,若是须要排序大量数据,可适当调高该值。但MySql会为每一个客户链接发放该缓冲空间,因此应尽可能适当设置该值,以免内存开销过大。

read_rnd_buffer_size=256K

sort_buffer_size=256K # connection级参数(为每一个线程配置),500个线程将消耗500*256K的sort_buffer_size。


# InnoDB相关参数
innodb_additional_mem_pool_size=3M # InnoDB用于存储元数据信息的内存池大小,通常不需修改

innodb_flush_log_at_trx_commit =1 # 事务相关参数,若是值为1,则InnoDB在每次commit都会将事务日志写入磁盘(磁盘IO消耗较大),这样保证了彻底的ACID特性。而若是设置为0,则表示事务日志写入内存log和内存log写入磁盘的频率都为1次/秒。若是设为2则表示事务日志在每次commit都写入内存log,但内存log写入磁盘的频率为1次/秒。

innodb_log_buffer_size=2M # InnoDB日志数据缓冲大小,若是缓冲满了,就会将缓冲中的日志数据写入磁盘(flush)。因为通常至少都1秒钟会写一次磁盘,因此不必设置过大,即便是长事务。

innodb_buffer_pool_size=105M # InnoDB使用缓冲池来缓存索引和行数据。该值设置的越大,则磁盘IO越少。通常将该值设为物理内存的80%。

innodb_log_file_size=53M # 每个InnoDB事务日志的大小。通常设为innodb_buffer_pool_size的25%到100%


innodb_thread_concurrency=9 # InnoDB内核最大并发线程数

 

 

 
 
Mysql my.ini 配置文件详解
#BEGIN CONFIG INFO
#DESCR: 4GB RAM, 只使用InnoDB, ACID, 少许的链接, 队列负载大
#TYPE: SYSTEM
#END CONFIG INFO
#
# 此mysql配置文件例子针对4G内存
# 主要使用INNODB
#处理复杂队列而且链接数量较少的mysql服务器
#
# 将此文件复制到/etc/my.cnf 做为全局设置,
# mysql-data-dir/my.cnf 做为服务器指定设置
# (@localstatedir@ for this installation) 或者放入
# ~/.my.cnf 做为用户设置.
#
# 在此配置文件中, 你可使用全部程序支持的长选项.
# 若是想获悉程序支持的全部选项
# 请在程序后加上"--help"参数运行程序.
#
# 关于独立选项更多的细节信息能够在手册内找到
#
#
# 如下选项会被MySQL客户端应用读取.
# 注意只有MySQL附带的客户端应用程序保证能够读取这段内容.
# 若是你想你本身的MySQL应用程序获取这些值
# 须要在MySQL客户端库初始化的时候指定这些选项
#
[client]
#password = [your_password]
port = @MYSQL_TCP_PORT@
socket = @MYSQL_UNIX_ADDR@
# *** 应用定制选项 ***
#
# MySQL 服务端
#
[mysqld]
# 通常配置选项
port = @MYSQL_TCP_PORT@
socket = @MYSQL_UNIX_ADDR@
# back_log 是操做系统在监听队列中所能保持的链接数,
# 队列保存了在MySQL链接管理器线程处理以前的链接.
# 若是你有很是高的链接率而且出现"connection refused" 报错,
# 你就应该增长此处的值.
# 检查你的操做系统文档来获取这个变量的最大值.
# 若是将back_log设定到比你操做系统限制更高的值,将会没有效果
back_log = 50
# 不在TCP/IP端口上进行监听.
# 若是全部的进程都是在同一台服务器链接到本地的mysqld,
# 这样设置将是加强安全的方法
# 全部mysqld的链接都是经过Unix sockets 或者命名管道进行的.
# 注意在windows下若是没有打开命名管道选项而只是用此项
# (经过 "enable-named-pipe" 选项) 将会致使mysql服务没有任何做用!
#skip-networking
# MySQL 服务所容许的同时会话数的上限
# 其中一个链接将被SUPER权限保留做为管理员登陆.
# 即使已经达到了链接数的上限.
max_connections = 100
# 每一个客户端链接最大的错误容许数量,若是达到了此限制.
# 这个客户端将会被MySQL服务阻止直到执行了"FLUSH HOSTS" 或者服务重启
# 非法的密码以及其余在连接时的错误会增长此值.
# 查看 "Aborted_connects" 状态来获取全局计数器.
max_connect_errors = 10
# 全部线程所打开表的数量.
# 增长此值就增长了mysqld所须要的文件描述符的数量
# 这样你须要确认在[mysqld_safe]中 "open-files-limit" 变量设置打开文件数量容许至少4096
table_cache = 2048
# 容许外部文件级别的锁. 打开文件锁会对性能形成负面影响
# 因此只有在你在一样的文件上运行多个数据库实例时才使用此选项(注意仍会有其余约束!)
# 或者你在文件层面上使用了其余一些软件依赖来锁定MyISAM表
#external-locking
# 服务所能处理的请求包的最大大小以及服务所能处理的最大的请求大小(当与大的BLOB字段一块儿工做时至关必要)
# 每一个链接独立的大小.大小动态增长
max_allowed_packet = 16M
# 在一个事务中binlog为了记录SQL状态所持有的cache大小
# 若是你常用大的,多声明的事务,你能够增长此值来获取更大的性能.
# 全部从事务来的状态都将被缓冲在binlog缓冲中而后在提交后一次性写入到binlog中
# 若是事务比此值大, 会使用磁盘上的临时文件来替代.
# 此缓冲在每一个链接的事务第一次更新状态时被建立
binlog_cache_size = 1M
# 独立的内存表所容许的最大容量.
# 此选项为了防止意外建立一个超大的内存表致使永尽全部的内存资源.
max_heap_table_size = 64M
# 排序缓冲被用来处理相似ORDER BY以及GROUP BY队列所引发的排序
# 若是排序后的数据没法放入排序缓冲,
# 一个用来替代的基于磁盘的合并分类会被使用
# 查看 "Sort_merge_passes" 状态变量.
# 在排序发生时由每一个线程分配
sort_buffer_size = 8M
# 此缓冲被使用来优化全联合(full JOINs 不带索引的联合).
# 相似的联合在极大多数状况下有很是糟糕的性能表现,
# 可是将此值设大可以减轻性能影响.
# 经过 "Select_full_join" 状态变量查看全联合的数量
# 当全联合发生时,在每一个线程中分配
join_buffer_size = 8M
# 咱们在cache中保留多少线程用于重用
# 当一个客户端断开链接后,若是cache中的线程还少于thread_cache_size,
# 则客户端线程被放入cache中.
# 这能够在你须要大量新链接的时候极大的减小线程建立的开销
# (通常来讲若是你有好的线程模型的话,这不会有明显的性能提高.)
thread_cache_size = 8
# 此容许应用程序给予线程系统一个提示在同一时间给予渴望被运行的线程的数量.
# 此值只对于支持 thread_concurrency() 函数的系统有意义( 例如Sun Solaris).
# 你可能够尝试使用 [CPU数量]*(2..4) 来做为thread_concurrency的值
thread_concurrency = 8
# 查询缓冲常被用来缓冲 SELECT 的结果而且在下一次一样查询的时候再也不执行直接返回结果.
# 打开查询缓冲能够极大的提升服务器速度, 若是你有大量的相同的查询而且不多修改表.
# 查看 "Qcache_lowmem_prunes" 状态变量来检查是否当前值对于你的负载来讲是否足够高.
# 注意: 在你表常常变化的状况下或者若是你的查询原文每次都不一样,
# 查询缓冲也许引发性能降低而不是性能提高.
query_cache_size = 64M
# 只有小于此设定值的结果才会被缓冲
# 此设置用来保护查询缓冲,防止一个极大的结果集将其余全部的查询结果都覆盖.
query_cache_limit = 2M
# 被全文检索索引的最小的字长.
# 你也许但愿减小它,若是你须要搜索更短字的时候.
# 注意在你修改此值以后,
# 你须要重建你的 FULLTEXT 索引
ft_min_word_len = 4
# 若是你的系统支持 memlock() 函数,你也许但愿打开此选项用以让运行中的mysql在在内存高度紧张的时候,数据在内存中保持锁定而且防止可能被swapping out
# 此选项对于性能有益
#memlock
# 当建立新表时做为默认使用的表类型,
# 若是在建立表示没有特别执行表类型,将会使用此值
default_table_type = MYISAM
# 线程使用的堆大小. 此容量的内存在每次链接时被预留.
# MySQL 自己常不会须要超过64K的内存
# 若是你使用你本身的须要大量堆的UDF函数
# 或者你的操做系统对于某些操做须要更多的堆,
# 你也许须要将其设置的更高一点.
thread_stack = 192K
# 设定默认的事务隔离级别.可用的级别以下:
# READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
transaction_isolation = REPEATABLE-READ
# 内部(内存中)临时表的最大大小
# 若是一个表增加到比此值更大,将会自动转换为基于磁盘的表.
# 此限制是针对单个表的,而不是总和.
tmp_table_size = 64M
# 打开二进制日志功能.
# 在复制(replication)配置中,做为MASTER主服务器必须打开此项
# 若是你须要从你最后的备份中作基于时间点的恢复,你也一样须要二进制日志.
log-bin=mysql-bin
# 若是你在使用链式从服务器结构的复制模式 (A->B->C),
# 你须要在服务器B上打开此项.
# 此选项打开在从线程上重作过的更新的日志,
# 并将其写入从服务器的二进制日志.
#log_slave_updates
# 打开全查询日志. 全部的由服务器接收到的查询 (甚至对于一个错误语法的查询)
# 都会被记录下来. 这对于调试很是有用, 在生产环境中经常关闭此项.
#log
# 将警告打印输出到错误log文件. 若是你对于MySQL有任何问题
# 你应该打开警告log而且仔细审查错误日志,查出可能的缘由.
#log_warnings
# 记录慢速查询. 慢速查询是指消耗了比 "long_query_time" 定义的更多时间的查询.
# 若是 log_long_format 被打开,那些没有使用索引的查询也会被记录.
# 若是你常常增长新查询到已有的系统内的话. 通常来讲这是一个好主意,
log_slow_queries
# 全部的使用了比这个时间(以秒为单位)更多的查询会被认为是慢速查询.
# 不要在这里使用"1", 不然会致使全部的查询,甚至很是快的查询页被记录下来(因为MySQL 目前时间的精确度只能达到秒的级别).
long_query_time = 2
# 在慢速日志中记录更多的信息.
# 通常此项最好打开.
# 打开此项会记录使得那些没有使用索引的查询也被做为到慢速查询附加到慢速日志里
log_long_format
# 此目录被MySQL用来保存临时文件.例如,
# 它被用来处理基于磁盘的大型排序,和内部排序同样.
# 以及简单的临时表.
# 若是你不建立很是大的临时文件,将其放置到 swapfs/tmpfs 文件系统上也许比较好
# 另外一种选择是你也能够将其放置在独立的磁盘上.
# 你可使用";"来放置多个路径
# 他们会按照roud-robin方法被轮询使用.
#tmpdir = /tmp

# *** 复制有关的设置

# 惟一的服务辨识号,数值位于 1 到 2^32-1之间.
# 此值在master和slave上都须要设置.
# 若是 "master-host" 没有被设置,则默认为1, 可是若是忽略此选项,MySQL不会做为master生效.
server-id = 1
# 复制的Slave (去掉master段的注释来使其生效)
#
# 为了配置此主机做为复制的slave服务器,你能够选择两种方法:
#
# 1) 使用 CHANGE MASTER TO 命令 (在咱们的手册中有完整描述) -
# 语法以下:
#
# CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>,
# MASTER_USER=<user>, MASTER_PASSWORD=<password> ;
#
# 你须要替换掉 <host>, <user>, <password> 等被尖括号包围的字段以及使用master的端口号替换<port> (默认3306).
#
# 例子:
#
# CHANGE MASTER TO MASTER_HOST='125.564.12.1', MASTER_PORT=3306,
# MASTER_USER='joe', MASTER_PASSWORD='secret';
#
# 或者
#
# 2) 设置如下的变量. 不论如何, 在你选择这种方法的状况下, 而后第一次启动复制(甚至不成功的状况下,
# 例如若是你输入错密码在master-password字段而且slave没法链接),
# slave会建立一个 master.info 文件,而且以后任何对于包含在此文件内的参数的变化都会被忽略
# 而且由 master.info 文件内的内容覆盖, 除非你关闭slave服务, 删除 master.info 而且重启slave 服务.
# 因为这个缘由,你也许不想碰一下的配置(注释掉的) 而且使用 CHANGE MASTER TO (查看上面) 来代替
#
# 所须要的惟一id号位于 2 和 2^32 - 1之间
# (而且和master不一样)
# 若是master-host被设置了.则默认值是2
# 可是若是省略,则不会生效
#server-id = 2
#
# 复制结构中的master - 必须
#master-host = <hostname>
#
# 当链接到master上时slave所用来认证的用户名 - 必须
#master-user = <username>
#
# 当链接到master上时slave所用来认证的密码 - 必须
#master-password = <password>
#
# master监听的端口.
# 可选 - 默认是3306
#master-port = <port>
# 使得slave只读.只有用户拥有SUPER权限和在上面的slave线程可以修改数据.
# 你可使用此项去保证没有应用程序会意外的修改slave而不是master上的数据
#read_only

#*** MyISAM 相关选项

# 关键词缓冲的大小, 通常用来缓冲MyISAM表的索引块.
# 不要将其设置大于你可用内存的30%,
# 由于一部份内存一样被OS用来缓冲行数据
# 甚至在你并不使用MyISAM 表的状况下, 你也须要仍旧设置起 8-64M 内存因为它一样会被内部临时磁盘表使用.
key_buffer_size = 32M
# 用来作MyISAM表全表扫描的缓冲大小.
# 当全表扫描须要时,在对应线程中分配.
read_buffer_size = 2M
# 当在排序以后,从一个已经排序好的序列中读取行时,行数据将从这个缓冲中读取来防止磁盘寻道.
# 若是你增高此值,能够提升不少ORDER BY的性能.
# 当须要时由每一个线程分配
read_rnd_buffer_size = 16M
# MyISAM 使用特殊的相似树的cache来使得突发插入
# (这些插入是,INSERT ... SELECT, INSERT ... VALUES (...), (...), ..., 以及 LOAD DATA
# INFILE) 更快. 此变量限制每一个进程中缓冲树的字节数.
# 设置为 0 会关闭此优化.
# 为了最优化不要将此值设置大于 "key_buffer_size".
# 当突发插入被检测到时此缓冲将被分配.
bulk_insert_buffer_size = 64M
# 此缓冲当MySQL须要在 REPAIR, OPTIMIZE, ALTER 以及 LOAD DATA INFILE 到一个空表中引发重建索引时被分配.
# 这在每一个线程中被分配.因此在设置大值时须要当心.
myisam_sort_buffer_size = 128M
# MySQL重建索引时所容许的最大临时文件的大小 (当 REPAIR, ALTER TABLE 或者 LOAD DATA INFILE).
# 若是文件大小比此值更大,索引会经过键值缓冲建立(更慢)
myisam_max_sort_file_size = 10G
# 若是被用来更快的索引建立索引所使用临时文件大于制定的值,那就使用键值缓冲方法.
# 这主要用来强制在大表中长字串键去使用慢速的键值缓冲方法来建立索引.
myisam_max_extra_sort_file_size = 10G
# 若是一个表拥有超过一个索引, MyISAM 能够经过并行排序使用超过一个线程去修复他们.
# 这对于拥有多个CPU以及大量内存状况的用户,是一个很好的选择.
myisam_repair_threads = 1
# 自动检查和修复没有适当关闭的 MyISAM 表.
myisam_recover

# 默认关闭 Federated
skip-federated
# *** BDB 相关选项 ***
# 若是你运行的MySQL服务有BDB支持可是你不许备使用的时候使用此选项. 这会节省内存而且可能加速一些事.
skip-bdb

# *** INNODB 相关选项 ***
# 若是你的MySQL服务包含InnoDB支持可是并不打算使用的话,
# 使用此选项会节省内存以及磁盘空间,而且加速某些部分
#skip-innodb
# 附加的内存池被InnoDB用来保存 metadata 信息
# 若是InnoDB为此目的须要更多的内存,它会开始从OS这里申请内存.
# 因为这个操做在大多数现代操做系统上已经足够快, 你通常不须要修改此值.
# SHOW INNODB STATUS 命令会显示当先使用的数量.
innodb_additional_mem_pool_size = 16M
# InnoDB使用一个缓冲池来保存索引和原始数据, 不像 MyISAM.
# 这里你设置越大,你在存取表里面数据时所须要的磁盘I/O越少.
# 在一个独立使用的数据库服务器上,你能够设置这个变量到服务器物理内存大小的80%
# 不要设置过大,不然,因为物理内存的竞争可能致使操做系统的换页颠簸.
# 注意在32位系统上你每一个进程可能被限制在 2-3.5G 用户层面内存限制,
# 因此不要设置的过高.
innodb_buffer_pool_size = 2G
# InnoDB 将数据保存在一个或者多个数据文件中成为表空间.
# 若是你只有单个逻辑驱动保存你的数据,一个单个的自增文件就足够好了.
# 其余状况下.每一个设备一个文件通常都是个好的选择.
# 你也能够配置InnoDB来使用裸盘分区 - 请参考手册来获取更多相关内容
innodb_data_file_path = ibdata1:10M:autoextend
# 设置此选项若是你但愿InnoDB表空间文件被保存在其余分区.
# 默认保存在MySQL的datadir中.
#innodb_data_home_dir = <directory>
# 用来同步IO操做的IO线程的数量. This value is
# 此值在Unix下被硬编码为4,可是在Windows磁盘I/O可能在一个大数值下表现的更好.
innodb_file_io_threads = 4
# 若是你发现InnoDB表空间损坏, 设置此值为一个非零值可能帮助你导出你的表.
# 从1开始而且增长此值知道你可以成功的导出表.
#innodb_force_recovery=1
# 在InnoDb核心内的容许线程数量.
# 最优值依赖于应用程序,硬件以及操做系统的调度方式.
# 太高的值可能致使线程的互斥颠簸.
innodb_thread_concurrency = 16
# 若是设置为1 ,InnoDB会在每次提交后刷新(fsync)事务日志到磁盘上,
# 这提供了完整的ACID行为.
# 若是你愿意对事务安全折衷, 而且你正在运行一个小的食物, 你能够设置此值到0或者2来减小由事务日志引发的磁盘I/O
# 0表明日志只大约每秒写入日志文件而且日志文件刷新到磁盘.
# 2表明日志写入日志文件在每次提交后,可是日志文件只有大约每秒才会刷新到磁盘上.
innodb_flush_log_at_trx_commit = 1
# 加速InnoDB的关闭. 这会阻止InnoDB在关闭时作全清除以及插入缓冲合并.
# 这可能极大增长关机时间, 可是取而代之的是InnoDB可能在下次启动时作这些操做.
#innodb_fast_shutdown
# 用来缓冲日志数据的缓冲区的大小.
# 当此值快满时, InnoDB将必须刷新数据到磁盘上.
# 因为基本上每秒都会刷新一次,因此没有必要将此值设置的太大(甚至对于长事务而言)
innodb_log_buffer_size = 8M
# 在日志组中每一个日志文件的大小.
# 你应该设置日志文件总合大小到你缓冲池大小的25%~100%
# 来避免在日志文件覆写上没必要要的缓冲池刷新行为.
# 不论如何, 请注意一个大的日志文件大小会增长恢复进程所须要的时间.
innodb_log_file_size = 256M
# 在日志组中的文件总数.
# 一般来讲2~3是比较好的.
innodb_log_files_in_group = 3
# InnoDB的日志文件所在位置. 默认是MySQL的datadir.
# 你能够将其指定到一个独立的硬盘上或者一个RAID1卷上来提升其性能
#innodb_log_group_home_dir
# 在InnoDB缓冲池中最大容许的脏页面的比例.
# 若是达到限额, InnoDB会开始刷新他们防止他们妨碍到干净数据页面.
# 这是一个软限制,不被保证绝对执行.
innodb_max_dirty_pages_pct = 90
# InnoDB用来刷新日志的方法.
# 表空间老是使用双重写入刷新方法
# 默认值是 "fdatasync", 另外一个是 "O_DSYNC".
#innodb_flush_method=O_DSYNC
# 在被回滚前,一个InnoDB的事务应该等待一个锁被批准多久.
# InnoDB在其拥有的锁表中自动检测事务死锁而且回滚事务.
# 若是你使用 LOCK TABLES 指令, 或者在一样事务中使用除了InnoDB之外的其余事务安全的存储引擎
# 那么一个死锁可能发生而InnoDB没法注意到.
# 这种状况下这个timeout值对于解决这种问题就很是有帮助.
innodb_lock_wait_timeout = 120

[mysqldump]
# 不要在将内存中的整个结果写入磁盘以前缓存. 在导出很是巨大的表时须要此项
quick
max_allowed_packet = 16M
[mysql]
no-auto-rehash
# 仅仅容许使用键值的 UPDATEs 和 DELETEs .
#safe-updates
[isamchk]
key_buffer = 512M
sort_buffer_size = 512M
read_buffer = 8M
write_buffer = 8M
[myisamchk]
key_buffer = 512M
sort_buffer_size = 512M
read_buffer = 8M
write_buffer = 8M
[mysqlhotcopy]
interactive-timeout
[mysqld_safe]
# 增长每一个进程的可打开文件数量.
# 警告: 确认你已经将全系统限制设定的足够高!
# 打开大量表须要将此值设高
open-files-limit = 8192 
 

日志文件类型概述:   
1.
错误日志   记录启动、运行或中止mysqld时出现的问题。
My.ini配置信息:
#Enter a name for the error log file.   Otherwise a default name will be used.
#log-error=d:/mysql_log_err.txt
2.
查询日志    记录创建的客户端链接和执行的语句。
My.ini配置信息:
#Enter a name for the query log file. Otherwise a default name will be used.
#log=d:/mysql_log.txt
3.
更新日志   记录更改数据的语句。不同意使用该日志。
My.ini配置信息:
#Enter a name for the update log file. Otherwise a default name will be used.
#log-update=d:/mysql_log_update.txt
4.
二进制日志    记录全部更改数据的语句。还用于复制。
My.ini配置信息:
#Enter a name for the binary log. Otherwise a default name will be used.
#log-bin=d:/mysql_log_bin
5.
慢日志    记录全部执行时间超过long_query_time秒的全部查询或不使用索引的查询。
My.ini配置信息:
#Enter a name for the slow query log file. Otherwise a default name will be used.
#long_query_time =1
#log-slow-queries= d:/mysql_log_slow.txt
Mysql日志的关闭与开启:
使用如下命令查看是否启用了日志
mysql>show variables like 'log_%’; 
 

 
    
凡Value值为OFF的表示未开启服务,若要开启只须要将上的my.ini配置信息写入(my.ini为mysql安装目录下),而后去掉前面的“#”
号,再重启mysql服务。OK,如今会看到指定的日志文件已建立。相反地,若要中止mysql日志服务,只须要将my.ini中对应的配置信息去掉即
可。
二进制日志:
   
从概述中我能够看到my.ini配置信息的log-bin没有指定文件扩展名,这是由于即便你指定上扩展名它也不使用。当mysql建立二进制日志文件
时,首先建立一个以“mysql_log_bin”为名称,以“.index”为后缀的文件;再建立一个以“mysql_log_bin”为名称,以
“.000001”为后缀的文件。当mysql服务从新启动一次以“.000001”为后缀的文件会增长一个,而且后缀名加1递增;若是日志长度超过了
max_binlog_size的上限(默认是1G)也会建立一个新的日志文件;使用flush
logs(mysql命令符)或者执行mysqladmin –u –p flush-logs(windows命令提示符)也会建立一个新的日志文件。
既然写入的都是二进制数据,用记事本打开文件是看不到正常数据的,那怎么查看呢?
使用BIN目录下mysqlbinlog命令,如:
Bin>mysqlbinlog d:/mysql_log/mysql_bin.000001
Bin>mysqlbinlog d:/mysql_log/mysql_bin.000002
Bin>mysqlbinlog d:/mysql_log/mysql_bin.000003
Bin>mysqlbinlog d:/mysql_log/mysql_bin.000004
Bin>mysqlbinlog d:/mysql_log/mysql_bin.000005
使用SQL语句也可查看mysql建立的二进制的文件目录:
 
Mysql> show master logs; 
 
查看当前二进制文件状态:
 
mysql> show master status;  
 
至于准确的看懂日志文件,还须要读者仔细阅读,深深体会,这里就再也不奥述了!

 

 

 

任何一种数据库中,都有各类各样的日志。MySQL也不例外,在Mysql中有4种不一样的日志、分别错误日志、二进制日志、查询日志和慢查询日志。这些日志记录着Mysql数据库不一样方面的踪影。下文将介绍这4种不一样的日志做用和用途。

  一.错误日志

  错误日志在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


附录:

//显示全部本机上的二进制日志
mysql> SHOW MASTER LOGS;
//删除全部本机上的二进制日志
mysql> RESET MASTER;
//删除全部建立时间在binary-log.xxx以前的二进制日志
mysql> PURGE MASTER LOGS TO 'binary-log.xxx';
//只保留最近6天的日志,以前的都删掉
find /var/intra -type f -mtime +6 -name "*.log" -exec rm -f {} ;
//用键盘左上角(也就是Esc下面)那个键包围起来,说明是命令。-1d是昨天,以此类推-1m是上个月等等
day=`/bin/date -v -1d +%Y%m%d`;
//给文件更名
mv xxx.log xxx-${day}.log;
//这里还要加上数据库的用户名密码,做用是更新日志(包括二进制日志和查询日志等等)
mysqladmin flush-logs

 


  二进制日志也一般被称为binlog,它记当着全部的DDL和DML,但不包括数据查询语句。

  1.配置信息

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

  若是没有指定[file-name],默认为主机名后面跟-bin作为文件名,默认存放在DATADIR目录中。

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

  # The MySQL server

  [mysqld]

  ......

  log-bin = /var/lib/mysql/log-bin

  ......

  2.查看blnlog

  因为binlog以是binary方式存取,不能直接查看,须要用mysql提供的mysqlbinlog工具查看。

  3.删除binlog

  (1).用reset master命令删除全部日志,新日志从新从000001开始编号

  (2).用purge master logs to 'mysq-bin.******' 命令能够删除指定编号前的全部日志

  (3).用purge master logs to before 'YYYY-MM-DD HH24:MI:SS'命令能够删除'YYYY-MM-DD HH24:MI:SS'以前的产生的全部日志

  (4).能够在my.cnf中指定--expire_logs_days=#,此参数设置了binlog日志的过时天数

  4.测试案例

  [mysql@test2]$ mysql -uroot -p

  Enter password:

  Welcome to the MySQL monitor. Commands end with ; or g.

  Your MySQL connection id is 18 to server version: 5.0.26-standard-log

  Type 'help;' or 'h' for help. Type 'c' to clear the buffer.

  mysql> use test;

  Database changed

  mysql> select * from pet;

  +----------+--------+---------+------+------------+------------+

  | name | owner | species | sex | birth | death |

  +----------+--------+---------+------+------------+------------+

  | Fluffy | Harold | cat | f | 1993-02-04 | NULL |

  | Claws | Gwen | cat | m | 1994-03-17 | NULL |

  | Buffy | Harold | dog | f | 1989-05-13 | NULL |

  | Fang | Benny | dog | m | 1990-08-27 | NULL |

  | Bowser | Diane | dog | m | 1979-08-31 | 1995-07-29 |

  | Chirpy | Gwen | bird | f | 1998-09-11 | NULL |

  | Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |

  | Slim | Benny | snake | m | 1996-04-29 | NULL |

  +----------+--------+---------+------+------------+------------+

  8 rows in set (0.06 sec)

  mysql> insert into pet values('hunter','yxyup','cat','f','1996-04-29',null);

  Query OK, 1 row affected (0.03 sec)

  mysql> select * from pet;

  +----------+--------+---------+------+------------+------------+

  | name | owner | species | sex | birth | death |

  +----------+--------+---------+------+------------+------------+

  | Fluffy | Harold | cat | f | 1993-02-04 | NULL |

  | Claws | Gwen | cat | m | 1994-03-17 | NULL |

  | Buffy | Harold | dog | f | 1989-05-13 | NULL |

  | Fang | Benny | dog | m | 1990-08-27 | NULL |

  | Bowser | Diane | dog | m | 1979-08-31 | 1995-07-29 |

  | Chirpy | Gwen | bird | f | 1998-09-11 | NULL |

  | Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |

  | Slim | Benny | snake | m | 1996-04-29 | NULL |

  | hunter | yxyup | cat | f | 1996-04-29 | NULL |

  +----------+--------+---------+------+------------+------------+

  9 rows in set (0.00 sec)

mysql> update pet set sex='m' where name='hunter';

  Query OK, 1 row affected (0.00 sec)

  Rows matched: 1 Changed: 1 Warnings: 0

  mysql> delete from pet where name='hunter';

  Query OK, 1 row affected (0.00 sec)

  [mysql@test2]$ mysqlbinlog log-bin.000002

  /*!40019 SET @@session.max_insert_delayed_threads=0*/;

  /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;

  # at 4

  #080313 7:52:47 server id 1 end_log_pos 98 Start: binlog v 4, server v 5.0.26-standard-log created 080313 7:52:47

  # Warning: this binlog was not closed properly. Most probably mysqld crashed writing it.

  # at 98

  #080313 10:06:26 server id 1 end_log_pos 229 Query thread_id=18 exec_time=0 error_code=0

  use test;

  SET TIMESTAMP=1205373986;

  SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=1, @@session.unique_checks=1;

  SET @@session.sql_mode=0;

  /*!C latin1 */;

  SET @@session.character_set_client=8,@@session.collation_connection=8,@@session.collation_server=8;

  insert into pet values('hunter','yxyup','cat','f','1996-04-29',null);

  # at 229

  #080313 10:07:13 server id 1 end_log_pos 334 Query thread_id=18 exec_time=0 error_code=0

  SET TIMESTAMP=1205374033;

  update pet set sex='m' where name='hunter';

  # at 334

  #080313 10:07:38 server id 1 end_log_pos 432 Query thread_id=18 exec_time=0 error_code=0

  SET TIMESTAMP=1205374058;

  delete from pet where name='hunter';

  # at 432

  #080313 10:14:13 server id 1 end_log_pos 532 Query thread_id=18 exec_time=0 error_code=0

  SET TIMESTAMP=1205374453;

  create table t1(id int,name char(10));

  # at 532

  #080313 10:14:41 server id 1 end_log_pos 625 Query thread_id=18 exec_time=0 error_code=0

  SET TIMESTAMP=1205374481;

  alter table t1 add sex char(2);

  # End of log file

  ROLLBACK /* added by mysqlbinlog */;

  /*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;

  [mysql@test2]$

  能够看出,三条DML操做和两条DDL都记录到了binlog中了,而select并无记录。

相关文章
相关标签/搜索