您当前的位置:首页 > 电脑百科 > 数据库 > MYSQL

MySQL的文件系统(Linux环境)

时间:2022-05-09 10:38:33  来源:博客园  作者:那只斑马还没有睡

目录

数据库文件目录

/var/lib/MySQL/

可通过以下sql命令查看:

mysql> show variables like 'datadir';
+---------------+-----------------+
| Variable_name | Value           |
+---------------+-----------------+
| datadir       | /var/lib/mysql/ |
+---------------+-----------------+
1 row in set (0.00 sec)

相关命令目录

/usr/bin/

mysqladmin、mysqlbinlog、mysqldump等命令

[root@shanghAI01 bin]# cd /usr/bin
[root@shanghai01 bin]# find . -name "*mysql*"
./mysql_secure_installation
./mysql_upgrade
./mysql_migrate_keyring
./mysql_config_editor
./mysqlimport
./mysqlpump
./mysql
./mysqlslap
./mysqld_pre_systemd
./mysqlshow
./mysqlbinlog
./mysqldumpslow
./mysql_ssl_rsa_setup
./mysqlcheck
./mysqladmin
./mysqldump
./mysql_tzinfo_to_sql

/usr/sbin/

[root@shanghai01 bin]# cd /usr/sbin
[root@shanghai01 sbin]# find . -name "*mysql*"
./mysqld
./mysqld-debug

配置文件目录

/usr/share/mysql-8.0/

错误消息,字符集、安装文件和配置文件等

[root@shanghai01 mysql-8.0]# cd /usr/share/mysql-8.0
[root@shanghai01 mysql-8.0]# ll
total 1100
drwxr-xr-x 2 root root   4096 Apr 25 00:25 bulgarian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 charsets
drwxr-xr-x 2 root root   4096 Apr 25 00:25 czech
drwxr-xr-x 2 root root   4096 Apr 25 00:25 danish
-rw-r--r-- 1 root root  25575 Dec 18 00:07 dictionary.txt
drwxr-xr-x 2 root root   4096 Apr 25 00:25 dutch
drwxr-xr-x 2 root root   4096 Apr 25 00:25 english
drwxr-xr-x 2 root root   4096 Apr 25 00:25 estonian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 french
drwxr-xr-x 2 root root   4096 Apr 25 00:25 german
drwxr-xr-x 2 root root   4096 Apr 25 00:25 greek
drwxr-xr-x 2 root root   4096 Apr 25 00:25 hungarian
-rw-r--r-- 1 root root   3999 Dec 18 00:07 innodb_memcached_config.sql
-rw-r--r-- 1 root root   2216 Dec 18 00:58 install_rewriter.sql
drwxr-xr-x 2 root root   4096 Apr 25 00:25 italian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 japanese
drwxr-xr-x 2 root root   4096 Apr 25 00:25 korean
-rw-r--r-- 1 root root 616528 Dec 18 00:07 messages_to_clients.txt
-rw-r--r-- 1 root root 359072 Dec 18 00:07 messages_to_error_log.txt
-rw-r--r-- 1 root root   1977 Dec 18 00:58 mysql-log-rotate
drwxr-xr-x 2 root root   4096 Apr 25 00:25 norwegian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 norwegian-ny
drwxr-xr-x 2 root root   4096 Apr 25 00:25 polish
drwxr-xr-x 2 root root   4096 Apr 25 00:25 portuguese
drwxr-xr-x 2 root root   4096 Apr 25 00:25 romanian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 russian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 serbian
drwxr-xr-x 2 root root   4096 Apr 25 00:25 slovak
drwxr-xr-x 2 root root   4096 Apr 25 00:25 spanish
drwxr-xr-x 2 root root   4096 Apr 25 00:25 swedish
drwxr-xr-x 2 root root   4096 Apr 25 00:25 ukrainian
-rw-r--r-- 1 root root   1248 Dec 18 00:58 uninstall_rewriter.sql

/etc/my.cnf

[root@shanghai01 /]# cat /etc/my.cnf
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/8.0/en/server-configuration-defaults.html

[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove the leading "# " to disable binary logging
# Binary logging captures changes between backups and is enabled by
# default. It's default setting is log_bin=binlog
# disable_log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
#
# Remove leading # to revert to previous value for default_authentication_plugin,
# this will increase compatibility with older clients. For background, see:
# https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_default_authentication_plugin
# default-authentication-plugin=mysql_native_password

datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock

log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

文件

数据库在文件系统中的表示

除了information_schema这个系统数据库外,其他的数据库在数据目录下都有对应的子目录。

[root@shanghai01 ~]# cd /var/lib/mysql/
[root@shanghai01 mysql]# ll
total 188876
-rw-r----- 1 mysql mysql       56 Apr 25 00:43 auto.cnf
-rw-r----- 1 mysql mysql     1433 Apr 25 11:26 binlog.000001
-rw-r----- 1 mysql mysql       16 Apr 25 00:48 binlog.index
-rw------- 1 mysql mysql     1676 Apr 25 00:43 ca-key.pem
-rw-r--r-- 1 mysql mysql     1112 Apr 25 00:43 ca.pem
-rw-r--r-- 1 mysql mysql     1112 Apr 25 00:43 client-cert.pem
-rw------- 1 mysql mysql     1676 Apr 25 00:43 client-key.pem
-rw-r----- 1 mysql mysql   196608 Apr 25 12:11 #ib_16384_0.dblwr
-rw-r----- 1 mysql mysql  8585216 Apr 25 00:43 #ib_16384_1.dblwr
-rw-r----- 1 mysql mysql     5517 Apr 25 00:43 ib_buffer_pool
-rw-r----- 1 mysql mysql 12582912 Apr 25 12:11 ibdata1
-rw-r----- 1 mysql mysql 50331648 Apr 25 12:11 ib_logfile0
-rw-r----- 1 mysql mysql 50331648 Apr 25 00:43 ib_logfile1
-rw-r----- 1 mysql mysql 12582912 Apr 25 00:48 ibtmp1
drwxr-x--- 2 mysql mysql     4096 Apr 25 00:48 #innodb_temp
drwxr-x--- 2 mysql mysql     4096 Apr 25 00:43 mysql
-rw-r----- 1 mysql mysql 25165824 Apr 25 11:25 mysql.ibd
srwxrwxrwx 1 mysql mysql        0 Apr 25 00:48 mysql.sock
-rw------- 1 mysql mysql        6 Apr 25 00:48 mysql.sock.lock
drwxr-x--- 2 mysql mysql     4096 Apr 25 00:43 performance_schema
-rw------- 1 mysql mysql     1680 Apr 25 00:43 private_key.pem
-rw-r--r-- 1 mysql mysql      452 Apr 25 00:43 public_key.pem
-rw-r--r-- 1 mysql mysql     1112 Apr 25 00:43 server-cert.pem
-rw------- 1 mysql mysql     1676 Apr 25 00:43 server-key.pem
drwxr-x--- 2 mysql mysql     4096 Apr 25 00:43 sys
-rw-r----- 1 mysql mysql 16777216 Apr 25 11:27 undo_001
-rw-r----- 1 mysql mysql 16777216 Apr 25 00:55 undo_002

MySQL5.7中会在数据库子目录下生成db.opt文件,用于保存数据库的相关配置。比如:字符集、比较规则。而MySQL8.0不再提供db.opt文件。

表在文件系统中的表示

创建测试数据库和表

CREATE DATABASE db_innodb_myisam;

USE db_innodb_myisam;

CREATE TABLE tb_innodb
(
    id INT PRIMARY KEY,
    NAME VARCHAR(20) NOT NULL
)
    ENGINE = innodb;

SHOW CREATE TABLE tb_innodb;

CREATE TABLE tb_myisam
(
    id INT PRIMARY KEY,
    NAME VARCHAR(20) NOT NULL
)
    ENGINE = myisam;

SHOW CREATE TABLE tb_myisam;

查看数据库目录下的文件

[root@shanghai01 mysql]# cd /var/lib/mysql/db_innodb_myisam/
[root@shanghai01 db_innodb_myisam]# ll
total 120
-rw-r----- 1 mysql mysql 114688 May  7 14:50 tb_innodb.ibd
-rw-r----- 1 mysql mysql   2901 May  7 14:51 tb_myisam_363.sdi
-rw-r----- 1 mysql mysql      0 May  7 14:51 tb_myisam.MYD
-rw-r----- 1 mysql mysql   1024 May  7 14:51 tb_myisam.MYI

InnoDB存储引擎模式

表结构:

在mysql8以前,为了保存表结构,InnoDB会在数据目录下对应的数据库子目录下创建一个专门用于描述表结构的文件,文件名是表名.frm,这个后缀名为.frm是以二进制格式存储的。在mysql8中,表结构和表数据一起存在后缀名为.ibd的文件中。

表中数据和索引:

系统表空间

默认情况下,InnoDB会在数据目录下创建一个名为ibdata1、大小为12M的文件,这个文件就是系统表空间在文件系统上的表示。这个文件是自动扩展文件,当不够用的时候它会自己增加文件大小。

当然,如果想让系统表空间对应文件系统上多个实际文件,或者想要修改ibdata1这个文件名,那可以在MySQL启动时,配置对应的文件路径以及它们的大小,比如这样修改一下my.cnf配置文件:

[server]
innodb_data_file_path=data1:512M;data2:512M:autoextend

独立表空间

在MySQL5.6.6以及之后的版本中,InnoDB并不会默认的把各个表的数据存储到系统表空间中,而是为每一个表建立一个独立表空间,也就是说我们创建了多少个表,就有多少个独立表空间。

使用独立表空间来存储表数据的话,会在该表所属数据库对应的子目录下创建一个表示该独立表空间的文件,文件名和表名相同,只不过添加了一个.ibd的扩展名而已,所以完整的文件名称长这样:表名.ibd

例如tb_innodb.ibd中存储了测试表tb_innodb的结构、数据、索引。

可以用ibd2sdi工具解析ibd文件。

系统表空间与独立表空间的设置

可以自己指定使用系统表空间还是独立表空间来存储数据,这个功能由启动参数innodb_file_per_table控制,比如说我们想刻意将表数据都存储到系统表空间时,可以在启动MySQL服务器的时候这样配置:

[server]
innodb_file_per_table=0 # 0:代表使用系统表空间; 1:代表使用独立表空间

其他类型的表空间

随着MySQL的发展,除了上述两种老牌表空间之外,现在还新提出了一些不同类型的表空间,比如通用
表空间(general tablespace)、临时表空间(temporary tablespace)等。

MyISAM存储引擎模式

表结构:

mysql8中后缀为.sdi,mysql5.7中后缀为.frm。

例如tb_myisam_363.sdi中存储了测试表tb_myisam表结构。

表中数据和索引:

在MyISAM中的索引全部都是二级索引,该存储引擎的数据和索引是分开存放的。所以在文件系统中也是使用不同的文件来存储数据文件和索引文件,同时表数据都存放在对应的数据库子目录下。

例如tb_myisam.MYD存储数据(MYData)、tb_myisam.MYI存储索引(MYIndex)。

 

如果本文对你有帮助,别忘记给我个3连 ,点赞,转发,评论,,咱们下期见。

收藏 等于白嫖,点赞才是真情。

 

 

原文
https://www.cnblogs.com/herecwh/p/16242893.html



Tags:MySQL   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
MySQL 核心模块揭秘
server 层会创建一个 SAVEPOINT 对象,用于存放 savepoint 信息。binlog 会把 binlog offset 写入 server 层为它分配的一块 8 字节的内存里。 InnoDB 会维护自己的 savepoint...【详细内容】
2024-04-03  Search: MySQL  点击:(10)  评论:(0)  加入收藏
MySQL 核心模块揭秘,你看明白了吗?
为了提升分配 undo 段的效率,事务提交过程中,InnoDB 会缓存一些 undo 段。只要同时满足两个条件,insert undo 段或 update undo 段就能被缓存。1. 关于缓存 undo 段为了提升分...【详细内容】
2024-03-27  Search: MySQL  点击:(18)  评论:(0)  加入收藏
MySQL:BUG导致DDL语句无谓的索引重建
对于5.7.23之前的版本在评估类似DDL操作的时候需要谨慎,可能评估为瞬间操作,但是实际上线的时候跑了很久,这个就容易导致超过维护窗口,甚至更大的故障。一、问题模拟使用5.7.22...【详细内容】
2024-03-26  Search: MySQL  点击:(14)  评论:(0)  加入收藏
从 MySQL 到 ByteHouse,抖音精准推荐存储架构重构解读
ByteHouse是一款OLAP引擎,具备查询效率高的特点,在硬件需求上相对较低,且具有良好的水平扩展性,如果数据量进一步增长,可以通过增加服务器数量来提升处理能力。本文将从兴趣圈层...【详细内容】
2024-03-22  Search: MySQL  点击:(29)  评论:(0)  加入收藏
MySQL自增主键一定是连续的吗?
测试环境:MySQL版本:8.0数据库表:T (主键id,唯一索引c,普通字段d)如果你的业务设计依赖于自增主键的连续性,这个设计假设自增主键是连续的。但实际上,这样的假设是错的,因为自增主键不...【详细内容】
2024-03-10  Search: MySQL  点击:(14)  评论:(0)  加入收藏
准线上事故之MySQL优化器索引选错
1 背景最近组里来了许多新的小伙伴,大家在一起聊聊技术,有小兄弟提到了MySQL的优化器的内部策略,想起了之前在公司出现的一个线上问题,今天借着这个机会,在这里分享下过程和结论...【详细内容】
2024-03-07  Search: MySQL  点击:(33)  评论:(0)  加入收藏
MySQL数据恢复,你会吗?
今天分享一下binlog2sql,它是一款比较常用的数据恢复工具,可以通过它从MySQL binlog解析出你要的SQL,并根据不同选项,可以得到原始SQL、回滚SQL、去除主键的INSERT SQL等。主要...【详细内容】
2024-02-22  Search: MySQL  点击:(54)  评论:(0)  加入收藏
如何在MySQL中实现数据的版本管理和回滚操作?
实现数据的版本管理和回滚操作在MySQL中可以通过以下几种方式实现,包括使用事务、备份恢复、日志和版本控制工具等。下面将详细介绍这些方法。1.使用事务:MySQL支持事务操作,可...【详细内容】
2024-02-20  Search: MySQL  点击:(54)  评论:(0)  加入收藏
为什么高性能场景选用Postgres SQL 而不是 MySQL
一、 数据库简介 TLDR;1.1 MySQL MySQL声称自己是最流行的开源数据库,它属于最流行的RDBMS (Relational Database Management System,关系数据库管理系统)应用软件之一。LAMP...【详细内容】
2024-02-19  Search: MySQL  点击:(39)  评论:(0)  加入收藏
MySQL数据库如何生成分组排序的序号
经常进行数据分析的小伙伴经常会需要生成序号或进行数据分组排序并生成序号。在MySQL8.0中可以使用窗口函数来实现,可以参考历史文章有了这些函数,统计分析事半功倍进行了解。...【详细内容】
2024-01-30  Search: MySQL  点击:(55)  评论:(0)  加入收藏
▌简易百科推荐
MySQL 核心模块揭秘
server 层会创建一个 SAVEPOINT 对象,用于存放 savepoint 信息。binlog 会把 binlog offset 写入 server 层为它分配的一块 8 字节的内存里。 InnoDB 会维护自己的 savepoint...【详细内容】
2024-04-03  爱可生开源社区    Tags:MySQL   点击:(10)  评论:(0)  加入收藏
MySQL 核心模块揭秘,你看明白了吗?
为了提升分配 undo 段的效率,事务提交过程中,InnoDB 会缓存一些 undo 段。只要同时满足两个条件,insert undo 段或 update undo 段就能被缓存。1. 关于缓存 undo 段为了提升分...【详细内容】
2024-03-27  爱可生开源社区  微信公众号  Tags:MySQL   点击:(18)  评论:(0)  加入收藏
MySQL:BUG导致DDL语句无谓的索引重建
对于5.7.23之前的版本在评估类似DDL操作的时候需要谨慎,可能评估为瞬间操作,但是实际上线的时候跑了很久,这个就容易导致超过维护窗口,甚至更大的故障。一、问题模拟使用5.7.22...【详细内容】
2024-03-26  MySQL学习  微信公众号  Tags:MySQL   点击:(14)  评论:(0)  加入收藏
从 MySQL 到 ByteHouse,抖音精准推荐存储架构重构解读
ByteHouse是一款OLAP引擎,具备查询效率高的特点,在硬件需求上相对较低,且具有良好的水平扩展性,如果数据量进一步增长,可以通过增加服务器数量来提升处理能力。本文将从兴趣圈层...【详细内容】
2024-03-22  字节跳动技术团队    Tags:ByteHouse   点击:(29)  评论:(0)  加入收藏
MySQL自增主键一定是连续的吗?
测试环境:MySQL版本:8.0数据库表:T (主键id,唯一索引c,普通字段d)如果你的业务设计依赖于自增主键的连续性,这个设计假设自增主键是连续的。但实际上,这样的假设是错的,因为自增主键不...【详细内容】
2024-03-10    dbaplus社群  Tags:MySQL   点击:(14)  评论:(0)  加入收藏
准线上事故之MySQL优化器索引选错
1 背景最近组里来了许多新的小伙伴,大家在一起聊聊技术,有小兄弟提到了MySQL的优化器的内部策略,想起了之前在公司出现的一个线上问题,今天借着这个机会,在这里分享下过程和结论...【详细内容】
2024-03-07  转转技术  微信公众号  Tags:MySQL   点击:(33)  评论:(0)  加入收藏
MySQL数据恢复,你会吗?
今天分享一下binlog2sql,它是一款比较常用的数据恢复工具,可以通过它从MySQL binlog解析出你要的SQL,并根据不同选项,可以得到原始SQL、回滚SQL、去除主键的INSERT SQL等。主要...【详细内容】
2024-02-22  数据库干货铺  微信公众号  Tags:MySQL   点击:(54)  评论:(0)  加入收藏
如何在MySQL中实现数据的版本管理和回滚操作?
实现数据的版本管理和回滚操作在MySQL中可以通过以下几种方式实现,包括使用事务、备份恢复、日志和版本控制工具等。下面将详细介绍这些方法。1.使用事务:MySQL支持事务操作,可...【详细内容】
2024-02-20  编程技术汇    Tags:MySQL   点击:(54)  评论:(0)  加入收藏
MySQL数据库如何生成分组排序的序号
经常进行数据分析的小伙伴经常会需要生成序号或进行数据分组排序并生成序号。在MySQL8.0中可以使用窗口函数来实现,可以参考历史文章有了这些函数,统计分析事半功倍进行了解。...【详细内容】
2024-01-30  数据库干货铺  微信公众号  Tags:MySQL   点击:(55)  评论:(0)  加入收藏
mysql索引失效的场景
MySQL中索引失效是指数据库查询时无法有效利用索引,这可能导致查询性能显著下降。以下是一些常见的MySQL索引失效的场景:1.使用非前导列进行查询: 假设有一个复合索引 (A, B)。...【详细内容】
2024-01-15  小王爱编程  今日头条  Tags:mysql索引   点击:(88)  评论:(0)  加入收藏
站内最新
站内热门
站内头条