首页 > 数据库 >第一章 MySQL体系结构和存储引擎

第一章 MySQL体系结构和存储引擎

时间:2023-05-18 10:04:13浏览次数:86  
标签:存储 1.3 数据库 第一章 引擎 MySQL 接字 体系结构

1.1 定义数据库和实例 数据库:物理操作系统文件或其他形式文件类型的集合 实例:MySQL数据库由后台线程以及一个共享内存区组成 在MySQL数据库中,实例与数据库的关系通常是一一对应的,即一个实例对应一个数据库,一个数据库对应一个实例 MySQL数据库实例在系统上的表现就是一个进程 MySQL读取配置文件的顺序 /etc/my.cnf => /etc/mysql/my.cnf => /usr/local/mysql/etc/my.cnf => ~/.my.cnf 如果多个配置文件中都有同一个参数,MySQL会以最后一个配置文件中的参数为准 linux下,配置文件一般放在/etc/my.cnf windows下,配置文件后缀名可能是cnf也可能是ini,可通过mysql--help找到类似内容   1.2 MySQL体系结构 MySQL由以下几部分组成:

  • 连接池组件 Connectors:JDBC ODBC NET PHP Python等
  • 管理服务和工具组件 management service&utils
  • SQL接口组件
  • 查询分析器组件
  • 优化器组件
  • 缓冲组件
  • 插件式存储引擎
  • 物理文件
MySQL数据库区别于其他数据库最重要的一个特点就是其插件式的表存储引擎 需要注意的是,存储引擎是基于表的,而不是数据库     1.3 MySQL存储引擎(了解) OLTP:在线事务处理 OLAP: 1.3.1 Innodb存储引擎 Innodb存储引擎支持事务,其设计目标主要面向在线事务处理(OLTP)的应用 特点是行锁设计、支持外键、并支持类似于Oracle的非锁定读,即默认读取操作不会产生锁 Innodb通过使用多版本并发控制(MVCC)来获得高并发性,并实现了四种隔离级别。默认为可重复度(repeatable read)。 同时使用一种被称为next-key locking 的策略来避免幻读现象的产生。 除此以外,InnoDB还提供了 插入缓冲(insert buffer),二次写(double write),自适应哈希索引(adaptive hash index),预读(read ahead)等高性能和高可用的功能。 对于表中的数据,InnoDB存储引擎采用了聚集的方式,因此每张表的存储都是按照主键的顺序进行存放。如果没有显示的在表定义时指定主键,InnoDB存储引擎会为每一行生成一个6字节的ROWID,并以此作为主键。 1.3.2 MyISAM存储引擎 MyISAM存储引擎不支持事务,不支持行锁,只支持表锁,支持全文索引。主要面向一些OLAP的应用。 MySQL5.5.8之前MyISAM存储引擎是默认的存储引擎。另外,MyISAM存储引擎另一个与众不同的地方是它的缓冲池只缓存索引文件,而不缓冲数据文件。 MyISAM存储引擎表由MYD和MYI组成,MYD存放数据文件,MYI存放索引文件。 1.3.3 NDB存储引擎 NDB存储是一个集群存储引擎,特点是数据全部放在内存中,因此主键查找的速度非常快,并且通过添加NDB数据存储节点可以线性地提高数据库性能,是高可用、高性能的集群系统 NDB存储引擎的连接操作是在MySQL数据库层完成的,而不是在存储引擎层完成的。这意味着,复杂的连接操作需要巨大的网络开销,因此查询速度很慢。 1.3.4 Memory存储引擎 Memory存储引擎将表中的数据存放在内存中,如果数据库重启或者发生崩溃,表中的数据都将丢失。适用于存储临时数据的临时表 。默认使用哈希索引,而不是B+树索引。 Memory存储引擎速度上非常快,但在使用上有一些限制,比如,只支持表锁,并发性能较差,并且不支持TEXT,BLOB列类型,并且在存储变长字段(varchar)时是按照定长字段(char)的方式进行的,会产生内存的浪费。 MySQL数据库使用Memory存储引擎作为临时表来存放查询的中间结果集,如果中间结果集大于Memroy存储引擎表的容量设置,又或者中间结果含有TEXT或BLOB列类型字段,则MySQL数据库会把其转换到MyISAM存储引擎表而存放到磁盘中。MyISAM不缓存数据文件,因此这时产生的临时表的性能对于查询会有损失 1.3.5 Archive存储引擎 Archive存储引擎只支持插入和查询操作,从MySQL5.1开始支持索引; Archive存储引擎使用zilb算法将数据行进行压缩后存储,压缩比一般可达1:10; Archive存储引擎非常适合存储归档数据,如日志信息; Archive存储引擎使用行锁来实现高并发的插入操作,但是本身并不是事务安全的存储引擎,其设计目标主要是提供高速的插入和压缩功能。 1.3.6 Federated存储引擎 Federated存储引擎表并不存放数据,它只是指向一台远程MySQL数据库服务器上的表 Federated存储引擎只支持MySQL数据库表,不支持异构数据表 1.3.7 Maria存储引擎 Maria存储引擎是新开发的引擎,设计目标主要是用来取代MyISAM存储引擎,成为MySQL的默认存储引擎 Maria存储引擎的特点是支持缓存数据和索引文件,应用了行锁设计,提供了MVCC功能,支持事务和非事务安全选项,以及更好的BLOB字符类型的处理性能 1.3.8 其他存储引擎 除了以上7中存储引擎外,MySQL数据库还有很多其他的存储引擎,包括Merge、CSV、Sphinx和Infobright   1.4 连接MySQL 1.4.1 TCP/IP TCP/IP套接字方式是MySQL数据库在任何平台下都提供的连接方式 命令:mysql -h address -u username -p password 在通过TCP/IP连接到MySQL实例时,MySQL数据库会先检查一张权限视图,判断发起请求的客户端IP是否允许连接到MySQL实例,该视图在MySQL架构下,表名为 user 1.4.2 命名管道和共享内存 在Windows 2000、Windows XP、Windoes 2003和Windows Vista以及在此之上的平台上,如果两个需要进程通信的进程在同一台服务器上,可以使用命名管道。在MySQL数据库中须在配置文件中启用--eanble-named-pipe选项 在MySQL4.1之后的版本中,MySQL还提供了共享内存的连接方式 1.4.3 Unix域套接字 在Linux和Unix环境下,可以通过使用Unix域套接字进行连接 Unix域套接字不是网络协议,所以只能在MySQL客户端和数据库实例在一台服务器上的情况下使用 用户可以在配置文件中指定套接字文件的路径,如--socket=/tmp/msyql.sock 当数据库实例启动后,通过 " show variables like 'socket' " 命令来进行Unix域套接字文件的查找 获得Unix域套接字文件后,通过 “mysql -udavid -S + 套接字文件地址” 进行连接                

标签:存储,1.3,数据库,第一章,引擎,MySQL,接字,体系结构
From: https://www.cnblogs.com/Esummer/p/17411016.html

相关文章

  • 新特性解读 | MySQL 8.0 新密码策略
    转载于:https://mp.weixin.qq.com/s/GK56N5SaafCIKuP6N3lMUg引言这里来介绍下MySQL8.0版本自带的新密码验证策略。正文我们非常熟悉这样的模式:用户想更改自己密码,需要提供原来密码或者追加手机验证码才可以,这种模式在MySQL数据库里一直不存在。在MySQL8.0之前的版本,普......
  • 5大主流方案对比:MySQL千亿级数据线上平滑扩容实战
    转载于:https://mp.weixin.qq.com/s/DWUIy0Bt2Jw-lHRGm50cow1.五个方案1.1停机方案1.2停写方案1.3日志方案1.4双写方案(中小型数据)1.5平滑2N方案(大数据量)2. 平滑2N扩容方案实践2.1 实现应用服务级别的动态扩容2.2 实现数据库的秒级平滑2N扩容3.keepalived......
  • mysqlfrm读取frm文件获取建表ddl并恢复数据
    环境:OS:Centos6[[email protected]]#python-VPython2.6.6 ##################################获取建表ddl#########################1.下载下载地址:https://downloads.mysql.com/archives/utilities/下载的版本为:mysql-utilities-1.6.5.tar.gz......
  • 【ⓂMySQL】行级锁(索引项加锁)
    InnoDB行锁是通过给索引上的索引项加锁来实现的。所以,只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁。其他注意事项:在不通过索引条件查询的时候,InnoDB使用的是表锁,而不是行锁。由于MySQL的行锁是针对索引加的锁,不是针对记录加的锁,所以即使是访问不同行的记......
  • MySQL基础巩固
    selectdistinctuniversityfromuser_profile;--distinct去重 selectdevice_idfromuser_profilelimit0,2ViewCodeselectdevice_idfromuser_profileWHEREid=1orid=2;--取出固定值的两种方式 selectdevice_idasuser_infos_example......
  • MySQL-索引
    索引原理索引是对数据库表中一列或多列的值进行排序的一种结构索引被用来快速找出在一个列上用一特定值的行。没有索引,MySQL不得不首先以第一条记录开始,然后读完整个表直到它找出相关的行。表越大,花费时间越多。对于一个有序字段,可以运用二分查找(BinarySearch),这就是为什么性......
  • MySQL中的索引
    MySQL中常见的索引InnoDB存储引擎支持以下几种常见的索引:B+树索引、全文索引、哈希索引,其中比较关键的是B+树索引。一、B+树索引InnoDB中的索引按照B+树来组织的,数据都存放在B+树(为了快速检索数据而提出的一种数据结构)的叶子节点中。聚集索引/聚簇索引InnoDB中使用了聚集索引,就是将......
  • Python 连接 MySQL 数据库
    在实际数据分析和建模过程中,我们通常需要从数据库中读取数据,并将其转化为Pandasdataframe对象进行进一步处理。而MySQL数据库是最常用的关系型数据库之一,因此在Python中如何连接MySQL数据库并查询数据成为了一个重要的问题。本文将介绍两种方法来连接MySQL数据库,并将......
  • 2022-2023年大二上mysql学习汇总
    CRUD等操作(DDL、DML、DQL)权限操作:createuser用户名@"localhost或%" identifiedby'密码'  showgrantsfor用户名@主机名 grant权限列表(all/insert/delete/select等)on库名(*).表名(*)to用户名@主机名  remove与授予一样函数:内置(后面加as......
  • PHP+MySql+jQuery实现的“顶”和“踩”投票功能
    当我们浏览网页时,我们想对网页内容如文章、评论中的观点持赞同或反对意见时,可以通过点击网页中的“顶”和“踩”来进行投票。而整个交互过程,开发者可以通过ajax异步来实现,从而提高用户体验。 本文结合实例,讲解使用PHP+MySql+jQuery实现的“顶”和“踩”投票功能,通过记录用户IP,判断......