博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(1.2)学习笔记之mysql体系结构(数据库文件)
阅读量:5112 次
发布时间:2019-06-13

本文共 1856 字,大约阅读时间需要 6 分钟。

InnoDB存储引擎体系结构图

   

 

 

1.InnoDB数据库的结构

  (1)redo log:这里的redo log不是数据的redo log,InnoDB本也是一个数据库,身具有的redo log,所以这里的redo log只是InnoDB存储引擎的,这里是循环写入的(如下图这种模式)。但经过mysql server层的封装的话,日志是放在iblog下的。

    

  iblog对所有的存储引擎做了一层封装,把所有存储引擎的日志都封装成iblog了。

 

  (2)user tablespace:用户表空间

    包含:

    【1】insert buffer bitmap page:插入数据的位图索引页  【2】leaf page segment:聚集索引的叶子节点(也就是数据表数据)  【3】no leaf page segment:非叶子节点的页(其实也就是索引存放)

    从这里我们可以查出,其实聚集索引是逻辑上连续,而物理上并不是放在一起的。

  (3)sys tablespace:系统表空间

    主要是存放了undo,数据字典等信息;

 

 

2、数据库文件

  

 

(1)数据库配置文件/参数文件

  一般默认会按照顺序从以下几个目录去找;

  【1】/etc/my.cnf  【2】/etc/mysql/my.cnf  【3】/usr/local/mysql/my.cnf  【4】./my.cnf

  

#以下命令可以指定配置文件/参数文件的路径mysqld_safe --default-file=/u01/my3306/my.cnf #如果要运行还得再该命令后面加个&
mysqld_safe --default-file=/u01/my3306/my.cnf &

 

(2)表结构定义文件

 

--进入查看表结构定义文件目录  cd /u01/my3306/data/mysql

以下这样的结构是MYISAM引擎的():

【1】.frm:放表定义  【2】.MYD:放表数据  【3】.MYI:放表索引

下面这些才是用户的:

直接cat user.frm 是看不了的,会是乱码,需要mysql工具来看。

要去官网下载 MySQL Utilities

#然后装好后运行下面语句即可查看表结构定义

mysqlfrm --diagnostic time_zone_transition.frm

 

(3)数据文件

就是图中的MYD文件,不过这是Myisam的,如果是innodb应该会把索引文件和数据文件放在一起

 

(4)错误文件

这里因为my.cnf里面没有指定,所以查出来错误文件默认放在mysql数据根目录下的bogon.err

注意,是因为我的my.cnf文件是这样,所以结果才出现上图的情况

 

(5)慢查询日志

  一般慢查询日志默认是没有开启的,我们来看看如何开启。

  show variables like '%slow%';

  

  slow_query_log 这里要设置为ON,这样慢查询日志才会启用,并且才会把数据写到如上图日志文件里面去。

  

#开启慢查询日志 set global slow_query_log='ON';
  
#查看当前超过多少秒认定为慢查询,这里显示的是10S,如下图
  
#设置查询时间超过多久为慢查询并记录在慢查询日志中去
set global long_query_time=1; 注意,这些修改都只是临时的,重启一次mysql之后就没用了。要永久有效需要在my.cnf文件里配置。

  

#编辑配置文件/etc/my.cnf加入如下内容[mysqld]slow_query_log = ONslow_query_log_file = /var/lib/mysql/test-10-226-slow.loglong_query_time = 1#修改配置后重启mysqlsystemctl restart mysqldmysql -uroot -p#使用下面命令验证show variables like 'slow_query%';mysql永久开启了漫查询日志功能

 

 

 

(6)通用日志

  默认不开,一般用作数据库审计。开了之后会把数据库所有的操作记下来。

  show variables like '%gen%'

   

 

 

 

 

 

  

 

转载于:https://www.cnblogs.com/gered/p/9614557.html

你可能感兴趣的文章
一次失败的项目经理招聘经验
查看>>
怎么保存退出vi编辑
查看>>
Java泛型的基本使用
查看>>
智力逻辑题
查看>>
SpringBoot前后端分离Instant时间戳自定义解析
查看>>
开发一个简单的 Vue 弹窗组件
查看>>
1076 Wifi密码 (15 分)
查看>>
rsync
查看>>
java中的IO操作总结
查看>>
noip模拟赛 党
查看>>
bzoj2038 [2009国家集训队]小Z的袜子(hose)
查看>>
Java反射机制及其Class类浅析
查看>>
Postman-----如何导入和导出
查看>>
面试题17:合并两个排序的链表
查看>>
Jmeter HTTPS接口测试的证书导入
查看>>
[OC] UITableView 与 UItableViewCell 的使用
查看>>
挂载设备时出现错误:mount: unknown filesystem type 'ntfs'
查看>>
结对编程第一次作业
查看>>
gulp入门学习
查看>>
JDK源码那些事儿之红黑树基础下篇
查看>>