数据库引擎InnoDB和myisam的区别和联系

1、ENGINE=InnoDB 数据库存储引擎,DEFAULT 默认,CHARSET=utf8
数据库字符编码

mysql优化的几个方面

  • 硬件 主要有 cpu、内存、磁盘io、网络
  • 系统配置 操作系统的不同、版本、以及操作系统的配置
  • 数据库 存储引擎的选择、数据库服务器配置参数、
  • 表结构设计及sql语句 sql语句优化、编写、表结构的设计

2、数据库的存储引擎,

硬件

mysql中engine=innodb和engine=myisam的区别

cpu选择

应用为计算密集型,应该使用更高的频率
应用的并发量高,则需要更多的核数

myisam:读取速度比较快,不占用大批量资源,但是又两个缺点,1、不支持事物,2、容错不好。硬盘崩溃了,数据就没了,如果说坚持要用在那个关键程序,要通过其复制特性实时的去备份数据,,MySQL能够支持这样的备份应用程序。MyISAM类型的二进制数据文件可以在不同操作系统中迁移。也就是可以直接从Windows系统拷贝到linux系统中使用。

内存

  • 一般来说通过增加内存,将数据缓存到内存中,从而提高数据吞吐性能
    瓶颈,如所有的数据都缓存到内存中了,在增加内存不会有性能的提升
    myisam 会将索引缓存到内存中
    数据通过操作系统缓存
    innodb 会同时在内存中缓存数据和索引

  • 内存的提升对于写会有提升,可以将多次写入改为一次写入

  • 内存的频率越高,速度越快

Innodb:它提供了事务控制能力功能,它确保一组命令全部执行成功,或者当任何一个命令出现错误时所有命令的结果都被回退,在电子银行中事务控制能力是非常重要的。支持COMMIT、ROLLBACK和其他事务特性。目前数据库表结构设计的时候一般都选择这种存储引擎。但是速度慢,占用磁盘空间比较多。

磁盘的配置和选择

  • 传统机械磁盘

读取过程:1)移动磁头到磁盘表面正确的位置上,2)等待磁盘旋转,使所需的数据在磁头之下,3)等待磁盘旋转过去,所有所需的数据被磁头读出
12称为访问时间,3传输速度

选择因素:磁盘容量,传输速度,访问时间,主轴转速,物理尺寸

  • raid机械磁盘 磁盘冗余队列的简称

  • ssd
    相比机械磁盘,可以加强随机读写性能,随机读的性能提升明显
    支持的更好的并发
    长时间密集写操作容易损坏ssd

  • 网络存储
    外部文件存储设备加载到服务器上的方法
    最适合用于数据库备份

详细解释转载于:

系统

mysql适合的操作系统
windows、FreeBSD、Solaris、linux

  • centos优化
    linux优化
  • 插件式存储引擎 存储引擎针对于表,而不是针对于库的
![](https://upload-images.jianshu.io/upload_images/7357680-3810dcef62fd9615.png)

存储引擎

myisam

myisam存储引擎由MYD和MYI组成

特性

  • 并发性和锁级别 使用的是表级锁,读写混合操作并发差,
  • 表损坏修复 check table tablename 进行检查, repair table tablename
    进行修复
  • 支持的索引类型 全文索引,
  • 支持数据压缩 myisampack命令压缩 已压缩的表只能进行读操作

限制

  • mysql5.0之前默认表大小为4g,5.0之后支持256tb

适用场景

  • 非事务应用
  • 只读类应用
  • 空间类应用

innodb

mysql5.5版本之后称为默认存储引擎
适合处理大量小事务
innodb使用表空间进行数据存储
innodb_file_per_tabl
on 独立表空间:tablename.ibd; 通过optimize
table命令收缩系统文件,可以同时向多个文件刷新数据
off 系统表空间 ibdatax 无法简单收缩文件大小,会产生io瓶颈
将系统表空间转到独立表空间,1mysqldump导出,2停止mysql服务,修改参数,3重启mysql,重建innodb表空间,4重新导入

特性

  • innodb 是一种事务型存储引擎
  • 完全支持事务的acid特性
  • redo log 和 undo log redo log 实现事务持久性,undo log 未提交事务
  • innodb
    支持行级锁,行级锁可以最大程度支持并发,行级锁是由存储引擎实现的

发表评论

电子邮件地址不会被公开。 必填项已用*标注