(1.2)学习笔记之mysql体系结构(数据库文件)
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 = ON slow_query_log_file = /var/lib/mysql/test---slow.log long_query_time = #修改配置后重启mysql systemctl restart mysqld mysql -uroot -p #使用下面命令验证 show variables like 'slow_query%'; mysql永久开启了漫查询日志功能
(6)通用日志
默认不开,一般用作数据库审计。开了之后会把数据库所有的操作记下来。
show variables like '%gen%'
(1.2)学习笔记之mysql体系结构(数据库文件)的更多相关文章
- (1.3)学习笔记之mysql体系结构(C/S整体架构、内存结构、物理存储结构、逻辑结构)
目录 1.学习笔记之mysql体系结构(C/S架构) 2.mysql整体架构 3.存储引擎 4.sql语句处理--SQL层(内存层) 5.服务器内存结构 6.mysql如何使用磁盘空间 7.mysql ...
- (1.1)学习笔记之mysql体系结构(内存、进程、线程)
关键词:mysql体系结构 参考:https://www.cnblogs.com/zhoubaojian/articles/7866292.html 一.mysql体系架构概述 1.mysql体系结构 ...
- MemSQL学习笔记-类似MySQL的数据库
http://gigaom.com/cloud/ex-facebookers-launch-memsql-to-make-your-database-fly/ -- 多主-从 http://www.m ...
- 吴裕雄--天生自然MySQL学习笔记:MySQL 选择数据库
连接到 MySQL 数据库后,可能有多个可以操作的数据库,所以你需要选择你要操作的数据库. 从命令提示窗口中选择MySQL数据库 在 mysql> 提示窗口中可以很简单的选择特定的数据库.可以使 ...
- 吴裕雄--天生自然MySQL学习笔记:MySQL 删除数据库
使用普通用户登陆 MySQL 服务器,可能需要特定的权限来创建或者删除 MySQL 数据库,所以使用 root 用户登录,root 用户拥有最高权限. 在删除数据库过程中,务必要十分谨慎,因为在执行删 ...
- 吴裕雄--天生自然MySQL学习笔记:MySQL 创建数据库
在登陆 MySQL 服务后,使用 create 命令创建数据库,语法如下: CREATE DATABASE 数据库名; 以下命令简单的演示了创建数据库的过程,数据名为 RUNOOB: [root@ho ...
- SQLMAP学习笔记2 Mysql数据库注入
SQLMAP学习笔记2 Mysql数据库注入 注入流程 (如果网站需要登录,就要用到cookie信息,通过F12开发者工具获取cookie信息) sqlmap -u "URL" - ...
- golang学习笔记16 beego orm 数据库操作
golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...
- MySQL笔记(1)---MySQL体系结构和存储引擎
1.前言 本系列记录MYSQL数据库的一些结构和实现特点,方便查询. 2.基本概念 数据库:物理操作系统文件或者其他形式文件类型的集合.MySQL中数据库文件可以是frm.MYD.MYI.ibd结尾的 ...
随机推荐
- C++中的赋值兼容性和重写
1,父子间的赋值兼容: 1,子类对象可以当做父类对象使用(赋值兼容性): 1,子类对象可以直接赋值给父类对象: 2,子类对象可以直接初始化父类对象: 3,父类指针可以直接指向子类对象(得到的是子类对象 ...
- 【算法】快速数论变换(NTT)初探
[简介] 快速傅里叶变换(FFT)运用了单位复根的性质减少了运算,但是每个复数系数的实部和虚部是一个余弦和正弦函数,因此系数都是浮点数,而浮点数的运算速度较慢且可能产生误差等精度问题,因此提出了以数论 ...
- 在tkinter中使用matplotlib
import sys import tkinter as Tk import matplotlib from numpy import arange, sin, pi from matplotlib. ...
- ES6新增语法和内置对象(let,const, Array/String/Set 扩展方法(解构赋值,箭头函数,剩余参数))
1.let ES6中新增的用于声明变量的关键字. let 声明的变量只在所处于的块级有效. 注意:使用 let 关键字声明的变量才具有块级作用域,var 关键字是不具备这个特点的. 1. 防止循环变量 ...
- 【记录】Redis 基础
Redis可以存放五种类型 1:String(字符串) 2:List(列表) 3:Hash(字典) 4:Set(集合) 5:ZSet(有序集合) String (字符串) redis 127.0.0. ...
- Oracle Linux下使用sqlplus的edit命令
1.使当前会话生效 define_editor=vi SQL> select * from dual; D - X SQL> edit Wrote file afiedt.buf 21 1 ...
- 【week8 in ricoh】 Learning CNN
week8:5.27 1.做CNN practical[1]里的example1,了解CNN模块中的每一个部分 (1)卷积层的卷积过程,输入输出维度变化(2)ReLU(3)Pooling层(4)Nor ...
- Codeigniter项目使用phpDocumentor生成api文档
前言 运行环境: vagrant 2.2.4 virtualbox 6.0 box bento/ubuntu-16.04 (Apache 2.4.18 + Mysql 5.7.26 + PHP 5.6 ...
- js 在array的遍历操作中修改arry中元素数量 出现的一些奇特的操作
在js中array是属于复杂类型,在arr1=arr2得赋值操作中,arr1得到的值并不是arr2的value,而是一个指向引用.那么修改arr1的同时arr2读取的值也会同步变化,那么问题来了,上代 ...
- json 文件打读取
1.获取文件路径 /* * BookController.class.getClassLoader().getResource("static/json/book_nav.json" ...