【MySQL常见疑难杂症】常见文件及其所存储的信息

1、MySQL配置文件的读取顺序

(非Win)/etc/my.cnf、/etc/mysql/my.cnf、/usr/local/mysql/etc/my.cnf、~/.my.cnf

可以通过命令查看MySQL读取配置文件的顺序

bash 复制代码
[root@hadoop01 ~]# mysql --help |grep '/etc/my.cnf'
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf 
[root@hadoop01 ~]# 

2、数据文件,以及文件作用

数据文件:.frm、.MYI、.MYD、.ibd、.ibdata*、.ib_logfile*、undo*、ibtmp1、auto.cnf、db.opt、.CSM、.CSV、.TRN、.TRG。

🦎.frm:表结构定义文件。

🦎.MYI:MyISAM存储引擎索引文件。

🦎.MYD:MyISAM存储引擎数据文件。

🦎.ibd:InnoDB存储引擎独立表空间文件。

🦎.ibdata*:InnoDB存储引擎共享表空间文件。

🦎.ib_logfile*:InnoDB存储引擎redo log文件。

🦎undo*:InnoDB存储引擎独立undo文件。

🦎ibtmp1:InnoDB存储引擎临时表空间文件。

🦎auto.cnf:用于存放MySQL实例的全局唯一的server-uuid的文件。

🦎db.opt:用于存放MySQL实例的schema级别的默认字符集和默认校对规则的文件。

🦎.CSM:用于存放CSV存储引擎的元数据等相关信息的文件。

🦎.CSV:用于存放CSV存储引擎的数据文件,每行数据的列值之间使用逗号分隔。

🦎.TRN:用于存放与触发器相关的元数据。

🦎.TRG:用于存放触发器定义语句以及与定义相关的信息。

日志文件:error.log(error log)​、localhost.log(generallog)​、mysql-bin.(binlog)​、mysql-relay-bin.(relay log)​、slow-query.log(slow log)​。

🦎error.log(error log)​:错误日志,记录着MySQL启动之后mysqld打印的相关信息。错误日志文件在MySQL Server启动之后必须存在;否则,在使用mysqld_safe启动数据库时会因为找不到错误日志文件而报错,终止启动过程(如果直接使用mysqld程序来启动数据库,则不会有这个问题,因为mysqld进程发现错误日志不存在时会重新创建)​。

🦎localhost.log(general log)​:一般查询日志,启用该日志之后,在MySQL Server中执行的所有SQL语句都会被记录。查询日志可以在MySQL Server启动之后动态开关、自动创建。

🦎mysql-bin.(binlog)​:二进制日志,用于复制架构中的数据同步(从库I/O线程从主库读取)​,MySQL Server中涉及数据变更的SQL语句都会被记录,可以指定单个文件的大小,写满指定大小的文件之后自动切换到一个新文件。
🦎mysql-relay-bin.
(relay log)​:中继日志,用于复制架构中的数据同步(从库I/O线程从主库读取binlog之后写入自身的中继日志中)​。

🦎slow-query.log(slow log)​:慢查询日志,SQL语句的执行时间超过指定时间,被认为执行缓慢,会被记录到该文件中。

其他文件:mysql.pid(pid)​、mysql.sock(socket)​、mysql.sock.lock(socket lock)​。

🦎 mysql.pid(pid):MySQL Server启动之后存放进程号的文件。

🦎 mysql.sock(socket):MySQL Server启动之后用于本地UNIXDomain通信的sock文件。

🦎 mysql.sock.lock(socket lock):MySQL Server启动之后用于锁定本地socket文件的锁标记文件。这是MySQL 5.7.x版本中新增的,如果MySQL Server非正常关闭,该文件可能残留而导致MySQL重新启动失败,删除该文件重新启动即可。

在MySQL 8.0中,数据字典库performance_schema、mysql、sys中的所有MyISAM存储引擎都改为使用InnoDB存储引擎,且所有的.frm文件也不见了,表结构文件和视图等定义信息都被放到了InnoDB存储引擎的数据字典表中,performance_schema数据字典表和mysql下的general_log、 slow_log表特殊,因为不支持事务,所以使用了新的.sdi后缀的文件来代替,该文件中记录的是JSON格式的表结构描述信息

bash 复制代码
tree /home/mysql/data/mysqldata1/* | grep -Eiv '.frm|.myi|.myd|.ibd'
相关推荐
君不见,青丝成雪18 分钟前
Hadoop技术栈(四)HIVE常用函数汇总
大数据·数据库·数据仓库·hive·sql
会飞的灰大狼3 小时前
MyCAT完整实验报告
mysql·centos7
不羁。。5 小时前
【撸靶笔记】第七关:GET - Dump into outfile - String
数据库·笔记·oracle
yangchanghua1117 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance7 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai7 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白7 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务7 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
冒泡的肥皂11 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.12 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构