一、日志文件

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. bind 简单配置dns

    一. 安装apt-get install bind9 apt-get install bind9-host dnsutils apt-get install bind9-doc 二.修改本机配置我们要 ...

  2. QT5.3 杂记(转)

    原文转自 https://www.cnblogs.com/aoldman/p/3968280.html Qt5下,QWidget系列从QtGui中被剥离出去,成为单独的QtWidget模块.随着Qt ...

  3. Linux下Redis使用

    1. 简介 REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统. 2. 安装 安装方法如下: # yum i ...

  4. Uva 10158 War

    并查集的应用 直接阔成2倍.后N项为对应的敌人 #include <map> #include <set> #include <list> #include < ...

  5. jQuery的动画方法

    /* animate参数: 参数一:要改变的样式属性值,写成字典的形式 参数二:动画持续的时间,单位为毫秒,一般不写单位 参数三:动画曲线,默认为‘swing’,缓冲运动,还可以设置为‘linear’ ...

  6. Mongodb的学习整理(下)

    聚合 aggregate 聚合(aggregate)主要用于计算数据,类似sql中的sum().avg() 语法 db.集合名称.aggregate([{管道:{表达式}}]) 管道 管道在Unix和 ...

  7. CentOS6.5升级autoconf版本,解决”Autoconf version 2.64 or higher is required“错误

    CentOS6.5升级autoconf版本,解决”Autoconf version 2.64 or higher is required“错误 https://blog.csdn.net/pretty ...

  8. AC日记——开关灯 codevs 1690

    开关灯 思路: 线段树: bool懒标记维护: 更新区间时是区间总值减去当前值: 来,上代码: #include <cstdio> #include <cstring> #in ...

  9. CodeForces 450B Jzzhu and Sequences 【矩阵快速幂】

    Jzzhu has invented a kind of sequences, they meet the following property: You are given x and y, ple ...

  10. HDU 1203 【01背包/小数/概率DP】

    I NEED A OFFER! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...