前提: mysql在5.0之前,读写性能相差很大,读性能:myisam 很强

mysql在5.0之后,差距不是很大

http://www.taobaodba.com/

由于近期有个项目对系统性能要求很高,技术选型上由于种种原因已经确定使用Mysql数据库,接下来就是要确定到底使用哪种存储引擎。我们的应用是典型的写多读少,写入内容为也很短,对系统的稳定性要求很高。所以存储引擎肯定就定在广泛使用的Innodb和MyISAM之中了。

至于两者的比较网上也有很多,但是毕竟这个事情也不复杂,决定还是自己来做,去验证一下在我们的场景下谁更优。

测试的版本是mysql  Ver 14.14 Distrib 5.1.49, for debian-linux-gnu (i686),使用的是Innodb plugin 1.0.8(官方称比built-in版本性能更好)和默认的MyISAM。

测试机器是我的笔记本,配置如下:Intel 酷睿2双核 P8600,2G*2 DDR3 1066内存,320G硬盘5400转。

测试一:数据插入性能测试,这里我分别对innodb_flush_log_at_trx_commit参数打开和关闭都测了了一下,每次测试都是运行40s,表中数字都是实际插入条数。

MyISAM Innodb (打开) Innodb (关闭)

单线程,逐个插入120000 6000060000

4线程,逐个插入 40000*4 20000*440000*4

单线程,批量100条/次插入3600*100800*1003000*100

单线程,批量200条/次插入1800*200400*2001600*200

可以发现批量插入的性能远高于单条插入,但是一次批量的大小对性能影响不大。每条记录是否都刷新日志的参数对innodb性能的影响巨大。总体上来说,MyISAM性能更优一点。这里有一点需要注意,在插入测试过程中,我对系统资源进行了监控,发现MyISAM对系统资源占用很低,但是Innodb对磁盘占用却很高,应该是对事务控制多了很多需要记录的日志。

测试二:数据读取性能测试。每次随机读取1000条记录,反复进行读取。

MyISAM Innodb

单线程,200次读取5.7s16.7s

4线程,200次读取12s40.8s

可以看出MyISAM的读取性能非常恐怖,性能差距在3倍的样子。

以上两个测试发现MyISAM在无事务的需求下几乎完胜,但是要知道它是表锁,Innodb是行锁,那么在并发读写同时存在的情况下,那结果会是怎么样呢?!

测试三:两个线程并发写入,2个线程并发读取。

MyISAM Innodb

逐个插入写入40s:10000*2 读取200次*2:14s 写入40s:60000*2 读取200次*2:50s

批量100条/次插入写入40s:1000*100*2 读取200次*2:10s写入40s:1500*100*2 读取200次*2:50s

这下立刻显示出Innodb在并发情况下强劲的性能,几乎没有什么性能衰减。而MyISAM单条插入速度变得非常慢,批量插入也下降了40%性能。

总结一下,在写多读少的应用中还是Innodb插入性能更稳定,在并发情况下也能基本,如果是对读取速度要求比较快的应用还是选MyISAM。

另外提一下,这里需要用到对Innodb的热备份,除了用Master-Slave的方式,还可以选用XtraBackup这个开源软件。

mysql myisam写入性能_(转)innodb 与 myisam 读写性能分析相关推荐

  1. MySQL学习笔记--常用存储引擎InnoDB与MyISAM总结

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一.MyISAM 特性 1. 并发性与锁级别 2. 表损坏修复 3. MyISAM表支持的索引 4. MyISAM表支持压缩 ...

  2. mysql的缓冲池大小_配置InnoDB缓冲池(Buffer Pool)大小

    1.配置InnoDB缓冲池(Buffer Pool)大小 当服务器正运行时,用户可以离线(启动时)或在线配置InnoDB缓冲池大小.这部分描述的行为适用这两种方法. 当增加或减少innodb_buff ...

  3. mysql blob 写入表_文件存入MYSql表的blob

    向MYSql的数据表中存入文件,这看似没有什么大问题,只要把文件存入longblob字段就行了.但是最近的实践发现看似简单的背后其实有很多陷阱.下面就来分享一下我遇到的问题及我的解决办法. 先介绍一下 ...

  4. 分散mysql的写入压力_缓解MySQL写入压力和主从延迟的尝试

    标签: 缓解MySQL写入压力和主从延迟的尝试 http://mp.weixin.qq.com/s?__biz=MzA5Njg5ODMzMg==&mid=208512935&idx=1 ...

  5. mysql更新写入数据_七、MySQL插入、更新与删除数据

    存储在系统中的数据是数据库管理系统(DBMS)的核心,数据库被设计用来管理数据的存储.访问和维护数据的完整性.MySQL中提供丰富的数据管理语句,包括插入数据的INSERT.更新数据的UPDATE以及 ...

  6. mysql索引innodb和myisam的区别

    引用 引用 区别 InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一 ...

  7. mysql 事务的好坏_mysql存储引擎:InnoDB和MyISAM的差别/优劣评价/评测/性能测试

    InnoDB和MyISAM简介 MyISAM:这个是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的 顺序访问方法) 的缩写 ...

  8. MySQL(三):InnoDB和MyISAM

    文章目录 一.InnoDB 和 MyISAM的不同 一.InnoDB 和 MyISAM的不同 InnoDB 支持事务,MyISAM 不支持.对于InnoDB每一条SQL语言都默认封装成事务,自动提交, ...

  9. MySQL 数据存储和优化------MySQL架构原理 ---- (架构---索引---事务---锁---集群---性能---分库分表---实战---运维)持续更新

    Mysql架构体系全系列文章主目录(进不去说明还没写完)https://blog.csdn.net/grd_java/article/details/123033016 本文只是整个系列笔记的第一章: ...

  10. InnoDB和MyISAM的区别与选择

    MyISAM 性能(适合小项目,读快速)MyISAM 是MySQL中默认的存储引擎,比如适合新闻系统,读为主. InnoDB 事务或外键支持(适合大项目,高并发读写)活跃用户20多万时候,也能很轻松应 ...

最新文章

  1. 一次搞懂 Runnable、Callable、Future、FutureTask,不懂不要钱!
  2. MER: 基于ITS区域marker扩增真菌群落的准确性
  3. 判别模型的玻尔兹曼机论文源码解读
  4. 【每日一题】4月1日题目 Rinne Loves Edges
  5. 如何实现一个符合泊松分布的即时消息发生器?
  6. 《大数据》2022年第1期目次摘要
  7. SpringBoot之项目实践一
  8. ★一张图弄明白从零维到十维
  9. ug添加imachining变量_UG变量设置)
  10. win7系统关闭445端口
  11. 更改VS主题及设置背景图片
  12. 什么是函数指针 ? 什么是指针函数? int (*P)( ) 和int *p()有什么区别
  13. 批量制作学校图书馆条码标签
  14. js主要是用来向html页面中,javascript是用来干什么的?
  15. STM32F7学习笔记(一)-LED
  16. 天河微信小程序入门《四》:融会贯通,form表单提交数据库
  17. 鸿蒙3.0 APP混合开发闪退问题笔记
  18. 详解Unity中的粒子系统Particle System (四)
  19. Python+Vue计算机毕业设计牙无忧6ayy4(源码+程序+LW+部署)
  20. matlab 颗粒碰撞,Lsdyna颗粒碰撞图 - 仿真模拟 - 小木虫 - 学术 科研 互动社区

热门文章

  1. linux绑定硬件的软件吗,Linux下安装的硬件方法
  2. win10你的电脑设备需要修复_图文详解win10升级失败的解决方法
  3. MySQL将一张表数据插入到另一张表
  4. vue项目原理分析-3:vuex
  5. 在 Win10 中配置 Linux 开发环境
  6. 外推主要发布平台(JM)
  7. 异常:Exception
  8. unity3D游戏开发实战原创视频讲座系列7之消消乐游戏开发
  9. 如何把域名解析到网站空间IP上?
  10. 冲突、冲突域、广播、广播域、洪泛的基本概念