一、日志文件

1、错误日志:Error Log

  内容:MyQL Server 执行过程中全部较为严重的警告和错误信息,以及MySQL Server 每次启动和关闭的具体信息。

路径:默认存放位置在数据文件夹下

  名称:默认文件名称以hostname.err 命名

  改动:“--log-error[=file_name]”。改动其存放文件夹和文件名称

  扩展:FLUSH LOGS 命令来告诉MySQL 备份旧日志文件并生成新的日志文件。备份文件名称以“.old”结尾。

2、二进制日志:Binary Log & Binary Log Index

  内容:MySQL 会将全部改动数据库数据的query(query 语句、运行的时间、所消耗的资源,以及相关的事务信息) 以二进制形式记录到日志文件里。

路径:默认存放位置在数据文件夹下

  名称:mysql-bin.******(*代表0~9 之间的某一个数字。来表示该日志的序号)

  改动:“--log-bin[=file_name]”,改动其存放文件夹和文件名称

  扩展:“--max_binlog_size”设置binlog 的最大存储上限

        “--binlog-do-db=db_name”对某个(db_name)数据库记录binlog

        “--binlog-ignore-db=db_name”忽略某个(db_name)数据库的binlog 记录

注意:db_name 不是指query 语句更新的数据所在的数据库。而是当前连接所处的数据库

mysql-bin.index 文件(binary log index)的功能是记录全部Binary Log 的绝对路径,保证MySQL 各种线程可以顺利的依据它找到全部须要的Binary Log 文件。

3、更新日志:update log

  从版本号5.0 開始,MySQL 已经不再支持更新日志了。

4、查询日志:query log

  内容:记录MySQL 中全部的query(包含全部的select。体积比較大,开启后影响性能,慎用!)

  路径:默认存放位置在数据文件夹下

  名称:默认文件名称为hostname.log

  改动:“--log[=fina_name]”,改动其存放文件夹和文件名称

  扩展:一般仅仅用于跟踪某些特殊的sql 性能问题才会短暂打开该功能。

5、慢查询日志:slow query log

  内容:慢查询日志中记录的是运行时间较长的query

  路径:默认存放位置在数据文件夹下

  名称:默认文件名称为hostname-slow.log

  改动:“--log-slow-queries[=file_name]”。改动其存放文件夹和文件名称

  扩展:慢查询日志採用的是简单的文本格式,能够通过各种文本编辑器查看当中的内容。当中记录了语句运行的时刻,运行所消耗的时间,运行用户,连接主机等相关信息。

MySQL 还提供了专门用来分析满查询日志的工具程序mysqlslowdump。用来帮助数据库管理人员解决可能存在的性能问题。

6、Innodb 的在线redo 日志:innodb redo log

  内容:redo 日志中记录了Innodb 所做的全部物理变更和事务信息,通过redo 日志和undo 信息,Innodb 保证了在不论什么情况下的事务安全性

  路径:默认存放位置在数据文件夹下

  名称:ib_logfile******(*代表0~9 之间的某一个数字。来表示该日志的序号)

  改动:通过innodb_log_group_home_dir 来更改设置日志的存放位置,通过innodb_log_files_in_group 设置日志的数量。

  扩展:暂不提供



二、数据文件

1、“.frm”文件

  与表相关的元数据(meta)信息都存放在“.frm”文件里,包含表结构的定义信息等(与表一对一存在)。

2、“.MYD”文件

  “.MYD”文件是MyISAM 存储引擎专用。存放MyISAM 表的数据(与表一对一存在)。

3、“.MYI”文件

  “.MYI”文件也是专属于MyISAM 存储引擎的,主要存放MyISAM 表的索引相关信息(与表一对一存在)。

4、“.ibd”文件和ibdata 文件

  这两种文件都是存放Innodb 数据的文件,之所以有两种文件来存放Innodb 的数据(包含索引)。是由于Innodb 的数据存储方式可以通过配置来决定是使用共享表(ibdata文件)空间存放存储数据,还是独享表(.ibd文件,与表一对一存在)空间存放存储数据。



三、Replication相关文件

1、master.info 文件

  master.info 文件存在于Slave 端的数据文件夹下,里面存放了该Slave 的Master 端的相关信息,包含Master 的主机地址,连接用户,连接password,连接port。当前日志位置,已经读取到的日志位置等信息。

2、relay log 和relay log index

  mysql-relay-bin.xxxxxn 文件用于存放Slave 端的I/O 线程从Master 端所读取到的Binary Log 信息,然后由Slave 端的SQL 线程从该relay log 中读取并解析对应的日志信息,转化成Master 所运行的SQL 语句,然后在Slave 端应用。

mysql-relay-bin.index 文件的功能类似于mysql-bin.index ,相同是记录日志的存放位置的绝对路径。仅仅只是他所记录的不是Binary Log。而是Relay Log。

3、relay-log.info 文件

  类似于master.info,它存放通过Slave 的I/O 线程写入到本地的relay log 的相关信息。供Slave 端的SQL 线程以及某些管理操作随时可以获取当前复制的相关信息。



四、其它文件

1、system config file

  MySQL 的系统配置文件一般都是“my.cnf”,Unix/Linux 下默认存放在"/etc"文件夹下,Windows 环境一般存放在“c:/windows”文件夹以下。

2、pid file

  pid file 是mysqld 应用程序在Unix/Linux 环境下的一个进程文件。和更多Unix/Linux 服务端程序一样,存放着自己的进程id。

3、socket file

  socket 文件也是在Unix/Linux 环境下才有的,用户在Unix/Linux 环境下client连接能够不通过TCP/IP 网络而直接使用Unix Socket 来连接MySQL。

MySQL架构组成之物理文件组成的更多相关文章

  1. MySQL 物理文件体系结构的简单整理说明

    本文出处:http://www.cnblogs.com/wy123/p/7102128.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...

  2. MySQL架构原理之存储引擎InnoDB数据文件

    MySQL架构原理之体系架构 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中简单介绍了MySQL的系统文件层,其中包含了数据文件.那么InnoDB的数据文件是如何分类并存储的呢? 一. ...

  3. 误删mysql表物理文件的解决方法(不涉及恢复数据)

    该方法只介绍了如何救回这个表名(数据不恢复) 如果想要恢复原来数据 直接用extundelete把文件恢复后放回去即可 并且是适用于平时没有全备的情况下  如果有全备 直接那全备的frm和idb文件放 ...

  4. MySQL innodb表使用表空间物理文件复制或迁移表

    MySQL InnoDB引擎的表通过拷贝物理文件来进行单表或指定表的复制,可以想到多种方式,今天测试其中2种: 将innodb引擎的表修改为Myisam引擎,然后拷贝物理文件 直接拷贝innodb的表 ...

  5. 一次修改数据库物理文件造成Mysql宕机的恢复记录

    事件起始 某夜,我正在床上冥想准备入睡,忽然同事向我求救:消息内容如下: Oh My Gold 改了些配置,啥都没了!都没了!没了!了! 我仔细询问,原来是她因为某些原因将某库的物理文件夹改名后,发现 ...

  6. 数据库周刊28│开发者最喜爱的数据库是什么?阿里云脱口秀聊程序员转型;MySQL update误操作;PG流复制踩坑;PG异机归档;MySQL架构选型;Oracle技能表;Oracle文件损坏处理……

    热门资讯 1.Stackoverflow 2020年度报告出炉!开发者最喜爱的数据库是什么?[摘要]2020年2月,近6.5万名开发者参与了 Stackoverflow 的 2020 年度调查,这份报 ...

  7. MySQL体系结构之物理文件

    一.MySQL日志文件 mysql日志文件及功能: 日志文件 功能 错误日志 记录启动.停止.运行过程中mysqld时出现的问题 通用日志 记录建立客户端连接和执行的语句 二进制日志 记录更改数据的所 ...

  8. mysql引擎与物理文件

    SELECT VERSION();show GLOBAL VARIABLES like '%PARTITION%';-- 查看分区情况 show GLOBAL VARIABLES like '%dat ...

  9. ch2 MySQL 架构组成

    第 2 章 MySQL 架构组成 前言 麻雀虽小,五脏俱全.MySQL    虽然以简单著称,但其内部结构并不简单.本章从 MySQL 物理组成.逻辑组成,以及相关工具几个角度来介绍    MySQL ...

随机推荐

  1. bzoj 1314: River过河 树套树+单调队列

    Description ZY带N个小Kid过河,小KID分成两种:高一年级,高二年级,由于存在代沟问题,如果同一条船上高一年级生和高二年级生数量之差超过K,就会发生不和谐的事件.当然如果一条船上全是同 ...

  2. Selenium2 鼠标悬停效果实现

    对一些js控件,鼠标悬停的时候出发下拉层的实现 1.使用Action public void moveToElement(WebDriver driver, By locator) { Actions ...

  3. Codeforces Round #395 Div.2 题解

    感受 第一次参加CF的rating比赛,感觉还是非常exciting,前18分钟把AB切掉之后一直在考虑C题,结果最后还是没有想出来Orz 传送门 A 比较水的模拟,就是计算:\(\frac{z}{l ...

  4. malloc,calloc,realloc区别

    malloc:memory allocation calloc:The 'c' indicates 'cleared' realloc:The realloc() function changes t ...

  5. [置顶] Linux Malloc分析-从用户空间到内核空间【转】

    转自:http://blog.csdn.net/ordeder/article/details/41654509 版权声明:本文为博主(http://blog.csdn.net/ordeder)原创文 ...

  6. django返回响应对象

    Django的视图必须要返回一个HttpResponse对象(或者其子类对象),不能像flask一样直接返回字符串. Django: return HttpResponse("Hello&q ...

  7. HDU 6235.Permutation (2017中国大学生程序设计竞赛-哈尔滨站-重现赛)

    Permutation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Tot ...

  8. Maximum Product of Word Lengths -- LeetCode

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  9. rest ---hateoas

    推荐一篇博客. https://www.ibm.com/developerworks/cn/java/j-lo-SpringHATEOAS/

  10. Linux下进行Web服务器压力(并发)测试工具http_load、webbench、ab、Siege、autobench简单使用教程(转)

    一.http_load 程序非常小,解压后也不到100K http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载.但是它不同于大多数压力测试工 具,它可以以一个单一的进程运行,一般 ...