首页 > 数据库 >MySQL(三)数据目录

MySQL(三)数据目录

时间:2023-02-16 20:47:13浏览次数:50  
标签:rw 15 19 数据 drwxr MySQL mysql root 目录

目录

Mysql的主要目录结构


find / -name mysql

1 数据库文件的存放路径 /var/lib/mysql/

MySQL服务器程序会在启动的时候去文件系统下的某个目录加载一些文件,之后在运行过程中产生的数据也会存储到这个目录下的某个文件中,这个目录就称为数据目录

可以通过命令查看当前数据库的数据目录:

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

[root@hadoop100 ~]# ll /var/lib/mysql
总用量 90568
-rw-r-----. 1 mysql mysql       56 1月  15 19:38 auto.cnf
-rw-r-----. 1 mysql mysql     4094 1月  15 21:55 binlog.000001
-rw-r-----. 1 mysql mysql       16 1月  15 19:39 binlog.index
-rw-------. 1 mysql mysql     1676 1月  15 19:38 ca-key.pem
-rw-r--r--. 1 mysql mysql     1112 1月  15 19:38 ca.pem
-rw-r--r--. 1 mysql mysql     1112 1月  15 19:38 client-cert.pem
-rw-------. 1 mysql mysql     1676 1月  15 19:38 client-key.pem
-rw-r-----. 1 mysql mysql   196608 1月  15 21:54 #ib_16384_0.dblwr
-rw-r-----. 1 mysql mysql  8585216 1月  15 19:38 #ib_16384_1.dblwr
-rw-r-----. 1 mysql mysql     5985 1月  15 19:38 ib_buffer_pool
-rw-r-----. 1 mysql mysql 12582912 1月  15 21:54 ibdata1
-rw-r-----. 1 mysql mysql 12582912 1月  15 19:39 ibtmp1
drwxr-x---. 2 mysql mysql     4096 1月  15 19:39 #innodb_redo
drwxr-x---. 2 mysql mysql      187 1月  15 19:39 #innodb_temp
drwxr-x---. 2 mysql mysql      143 1月  15 19:38 mysql
-rw-r-----. 1 mysql mysql 25165824 1月  15 21:54 mysql.ibd
srwxrwxrwx. 1 mysql mysql        0 1月  15 19:39 mysql.sock
-rw-------. 1 mysql mysql        6 1月  15 19:39 mysql.sock.lock
drwxr-x---. 2 mysql mysql     8192 1月  15 19:38 performance_schema
-rw-------. 1 mysql mysql     1680 1月  15 19:38 private_key.pem
-rw-r--r--. 1 mysql mysql      452 1月  15 19:38 public_key.pem
-rw-r--r--. 1 mysql mysql     1112 1月  15 19:38 server-cert.pem
-rw-------. 1 mysql mysql     1676 1月  15 19:38 server-key.pem
drwxr-x---. 2 mysql mysql       28 1月  15 19:38 sys
-rw-r-----. 1 mysql mysql 16777216 1月  15 21:54 undo_001
-rw-r-----. 1 mysql mysql 16777216 1月  15 21:54 undo_002

2 相关命令目录 /usr/bin/mysql /usr/sbin/mysql

bin下的命令(mysqladmin、mysqlbinlog、mysqldump等命令)

[root@hadoop100 bin]# ls | grep mysql
mysql
mysqladmin
mysqlbinlog
mysqlcheck
mysql_config_editor
mysqld_pre_systemd
mysqldump
mysqldumpslow
mysqlimport
mysql_migrate_keyring
mysqlpump
mysql_secure_installation
mysqlshow
mysqlslap
mysql_ssl_rsa_setup
mysql_tzinfo_to_sql
mysql_upgrade

sbin下的目录:

[root@hadoop100 bin]# cd /usr/sbin/
[root@hadoop100 sbin]# ls | grep mysql
mysqld

安装目录下非常中要的bin命令目录,它里面存储了许多关于控制客户端程序和服务器程序的命令(许多可执行文件,如mysql、mysqld、mysqld_safe等)。而数据目录是用来存储mysql运行过程中产生的数据。

3 配置文件目录 /usr/share/mysql-8.0(命令及配置文件) /etc(如my.conf)

/usr/share/mysql-8.0(命令及配置文件)

[root@hadoop100 mysql-8.0]# ll
总用量 1032
drwxr-xr-x. 2 root root     24 1月  15 19:34 bulgarian
drwxr-xr-x. 2 root root   4096 1月  15 19:34 charsets
drwxr-xr-x. 2 root root     24 1月  15 19:34 czech
drwxr-xr-x. 2 root root     24 1月  15 19:34 danish
-rw-r--r--. 1 root root  25575 9月  13 09:15 dictionary.txt
drwxr-xr-x. 2 root root     24 1月  15 19:34 dutch
drwxr-xr-x. 2 root root     24 1月  15 19:34 english
drwxr-xr-x. 2 root root     24 1月  15 19:34 estonian
drwxr-xr-x. 2 root root     24 1月  15 19:34 french
drwxr-xr-x. 2 root root     24 1月  15 19:34 german
drwxr-xr-x. 2 root root     24 1月  15 19:34 greek
drwxr-xr-x. 2 root root     24 1月  15 19:34 hungarian
-rw-r--r--. 1 root root   3999 9月  13 09:15 innodb_memcached_config.sql
-rw-r--r--. 1 root root   2216 9月  13 11:45 install_rewriter.sql
drwxr-xr-x. 2 root root     24 1月  15 19:34 italian
drwxr-xr-x. 2 root root     24 1月  15 19:34 japanese
drwxr-xr-x. 2 root root     24 1月  15 19:34 korean
-rw-r--r--. 1 root root 624277 9月  13 09:15 messages_to_clients.txt
-rw-r--r--. 1 root root 378839 9月  13 09:15 messages_to_error_log.txt
-rw-r--r--. 1 root root   1977 9月  13 11:45 mysql-log-rotate
drwxr-xr-x. 2 root root     24 1月  15 19:34 norwegian
drwxr-xr-x. 2 root root     24 1月  15 19:34 norwegian-ny
drwxr-xr-x. 2 root root     24 1月  15 19:34 polish
drwxr-xr-x. 2 root root     24 1月  15 19:34 portuguese
drwxr-xr-x. 2 root root     24 1月  15 19:34 romanian
drwxr-xr-x. 2 root root     24 1月  15 19:34 russian
drwxr-xr-x. 2 root root     24 1月  15 19:34 serbian
drwxr-xr-x. 2 root root     24 1月  15 19:34 slovak
drwxr-xr-x. 2 root root     24 1月  15 19:34 spanish
drwxr-xr-x. 2 root root     24 1月  15 19:34 swedish
drwxr-xr-x. 2 root root     24 1月  15 19:34 ukrainian
-rw-r--r--. 1 root root   1248 9月  13 11:45 uninstall_rewriter.sql

/etc(如my.conf)

[root@hadoop100 etc]# ls | grep my.cnf
my.cnf
my.cnf.d
my.cnf.rpmsave

数据库和文件系统的关系


InnoDBMyISAM这样的存储引擎都是把表存储在磁盘上,然后操作系统用来管理磁盘的结构称为文件系统,即:InnoDB、MyISAM这样的存储引擎都是把表存放在文件系统上,当我们需要读数据,这些存储引擎就会从文件系统中获取数据返回给我们,当我们想写入数据,这些存储引擎又会把这些数据写入文件系统。

1 mysql默认的数据库

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)

  • mysql:MySQL系统自带的核心数据库,存储mysql用户及其权限等信息

  • information_schema:这个数据库保存着MySQL服务器维护的所有其他数据库的信息,比如有哪些表、哪些视图、哪些触发器、哪些列、哪些索引等信息。

  • performace_schema:MySQl自带的数据库,主要保存MySQL最近运行的一些状态信息,可以用来监控MySQL服务的各类性能指标,包括最近执行了哪些语句,在执行过程中的每个阶段花费了多长时间,内存的使用情况等信息

  • sys:MySQl自带的数据库,主要是通过视图的形式,把information_schemaperformace_schema结合起来,帮助系统管理员和开发人员监控MySQL性能。

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

InnoDB

在/var/lib/mysql数据目录下,每个数据库都对应着一个文件夹,查看文件夹的内容如下:

image-20230116153439539

  • opt文件:记录数据库的字符集、比较规则等信息
  • frm:记录数据库表中的结构信息
  • ibd:独立表空间,每个数据库中的表对应一个文件,用于存储表中的数据

5.7版本及之前的版本,数据还会存放到/var/lib/mysql/idata1文件中,这个文件独立于数据库,默认大小12M,是系统表空间

8.0版本后就没有frm了,和ibd合并成一个,表结构和表数据统一存放在ibd文件里面了

ibd文件的查看 ibd2sdi --dump-file=emp1.txt emp1.ibd

ibd2sdi 是8.0版本后提供的一个ibd文件查看工具:

[root@hadoop100 dbtest1]# ibd2sdi --dump-file=emp1.txt emp1.ibd
[root@hadoop100 dbtest1]# ls
emp1.ibd  emp1.txt
[root@hadoop100 dbtest1]# cat emp1.txt
MyISAM

首先使用MYISAM引擎创建一张表:

CREATE TABLE `student_myisam` (
	`id` BIGINT NOT NULL AUTO_INCREMENT,
  `name` varchar(64) DEFAULT NULL,
  `age` int DEFAULT NULL,
	`sex` varchar(2) DEFAULT NULL,
	PRIMARY KEY(`id`)
) ENGINE=MYISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;


然后在文件目录中查看表对应的文件:

[root@hadoop100 dbtest1]# ll
总用量 136
-rw-r-----. 1 mysql mysql 114688 1月  15 23:57 emp1.ibd
-rw-------. 1 root  root   11112 1月  15 23:58 emp1.txt
-rw-r-----. 1 mysql mysql   4335 1月  16 00:31 student_myisam_366.sdi
-rw-r-----. 1 mysql mysql      0 1月  16 00:31 student_myisam.MYD
-rw-r-----. 1 mysql mysql   1024 1月  16 00:31 student_myisam.MYI

看到这里MYISAM引擎创建的表有三个文件,5.7中为frm、MYD和MYI,8.0为sdi、MYD、MYI,其中frm和sdi存储表结构,MYD和MYI分别存储数据和索引

3 视图在文件系统中的表示

会存储一个视图名.frm的文件,不会存在.ibd文件,侧面印证了视图只是一个虚拟的表,也就是某个查询语句的一个别名而已

4 数据目录下的其他文件

  • 服务器进程文件
  • 服务器日志文件
  • 默认/自动生成的SSL和RSA证书和密钥文件

标签:rw,15,19,数据,drwxr,MySQL,mysql,root,目录
From: https://www.cnblogs.com/tod4/p/17128213.html

相关文章

  • java数据类型转换
    title:java基本数据类型转换time:2023-1-15-16-32-6900当把一种基本数据类型的值赋给另一种变量时,就涉及到数据转换。将这些类型按精读由低到高排列:byteshortchar......
  • 2.15数据类型和常用方法
      字符串string 用来记录人的名字,家庭住址,性别等描述性质的状态定义方式name='abc'列表list中括号括起来,内部可以存放多个元素,元素与元素之间使用逗号隔开,可......
  • MySQL--索引的数据结构
    1.为什么使用索引索引是存储引擎用于快速找到数据记录的一种数据结构,就好比一本教科书的目录部分,通过目录中找到对应文章的页面,便可以快速定位到需要的文章,mysql中也是一......
  • vue项目,使用query传参,页面显示重新刷新或回归后数据丢失
    1、将需要传输的数据使用  JSON.stringify()  转译成字符串形式进行传输  2、在需要接收的页面使用  JSON.parse()  将数据格式再转回来即可使用,且刷新回......
  • Epoll原理解析--网卡接收数据说起
     转至 https://blog.csdn.net/armlinuxww/article/details/92803381 太重要了怕丢失,冒昧转一下  从网卡接收数据说起下边是一个典型的计算机结构图,计算机由CPU......
  • Django操作mongo数据库二(MongoClient方式)
    一、基本环境1、开发环境:Python环境:Python3.8.16Django环境:4.12、需要安装的包pipinstallpymongopipinstallmongoengine二、开发参数配置1、先创建一个mongoA......
  • Django操作mongo数据库一(配置文件里写连接信息)
    一、基本环境1、开发环境:Python环境:Python3.8.16Django环境:4.12、需要安装的包pipinstallpymongopipinstallmongoengine  二、开发参数配置1、先创建一个......
  • SFTP多用户不同权限目录
    SFTP多用户不同权限目录1.创建新的组和用户2.创建SFTP访问目录3.修改用户的home4.目录授权5.修改SFTP配置6.重启SFTP服务器7.验证SFTPSFTP多用户不同权......
  • 解析MYSQL建表语句,生成表结构的JSON
    根据建表语句解析表结构,并将表结构解析为JSON。根据MYSQL的建表语句,建表语句:CREATETABLE`TEST`(`ID`varchar(56)NOTNULL,`CREAETE_TIME`datetimeN......
  • 数据解析-正则匹配
    一、正则基础1、为什么使用正则需求判断一个字符串是否是手机号解决编写一个函数,给函数一个字符串,如果是手机号则返回True,否则返回False代码defisPhone(phon......