知识大全 MySQL 性能调优

Posted

篇首语:既靠天,也靠地,还靠自己。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 MySQL 性能调优相关的知识,希望对你有一定的参考价值。

MySQL 性能调优  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

    使用主备复制 因此需要打开Log Bin 这里就涉及一个sync bin的概念 缺省情况下 sync bin 在mysql中是关闭的 但存在一个风险 因为写日志没有刷新到硬盘中去的话 日志是写在操作系统的文件系统里的Cache中 这样若机器断电 那么日志信息将部分丢失 为了减少数据丢失 我们测试了sync bin= sync bin= 和sync bin= 三种情况 sync bin= 的情况下 丢失数据最坏概率是丢一个事务的数据 但性能非常差 设置sync bin= 的情况下 性能可以提高 倍左右 设置sync bin= 时 性能比sync bin= 又可以提高 倍 设置大于 的值 基本上相差不大 性能提高不了多少 最坏 个事务数据丢失是在我们的允许范围之内 因此设置 是个合理的值 这个值具体取决于你的系统能够最坏允许丢少的事务数据     若你的系统对数据丢失不于考虑 可以关闭sync bin 这时数据刷新到硬盘完全取决于操作系统的配置 相关的配置参数有如下     /proc/sys/vm/dirty_ratio    这个参数控制一个进程在文件系统中的文件系统写缓冲区的大小 单位是百分比 表示系统内存的百分比 表示当一个进程中写缓冲使用到系统内存多少的时候 再有磁盘写操作时开始向磁盘写出数据 增大之会使用更多系统内存用于磁盘写缓冲 也可以极大提高系统的写性能 但是 当你需要持续 恒定的写入场合时 应该降低其数值 一般缺省是 更新方法    echo >/proc/sys/vm/dirty_ratio (或则修改/etc/nf文件 增加sys vm dirty_ratio= 重起机器)    /proc/sys/vm/dirty_background_ratio    这个参数控制文件系统的pdflush进程 在何时刷新磁盘 单位是百分比 表示系统总内存的百分比 意思是当磁盘的脏数据缓冲到系统内存多少的时候 pdflush开始把脏数据刷新到磁盘 增大会使用更多系统内存用于磁盘写缓冲 也可以极大提高系统的写性能 但是 当你需要持续 恒定的写入场合时 应该降低其数值 一般缺省是     /proc/sys/vm/dirty_writeback_centisecs    Pdflush写后台进程每隔多久被唤醒并执行把脏数据写出到硬盘 单位是 / 秒 缺省数值是 也就是 秒 如果你的系统是持续地写入动作 那么实际上还是降低这个数值比较好 这样可以把尖峰的写操作削平成多次写操作 设置方法如下     echo >/proc/sys/vm/dirty_writeback_centisecs    /proc/sys/vm/dirty_expire_centisecs    这个参数声明Linux内核写缓冲区里面的脏数据多 旧 了之后 pdflush进程就开始考虑写到磁盘中去 单位是 / 秒 缺省是 也就是 秒的数据就算旧了 将会刷新磁盘 对于特别重载的写操作来说 这个值适当缩小也是好的 但也不能缩小太多 因为缩小太多也会导致IO提高太快 建议设置为 也就是 秒算旧     echo >/proc/sys/vm/ dirty_expire_centisecs    因此若没有调整这些参数 全部以缺省值 而且关闭sync bin的话 那么最多丢失的数据是     秒种(dirty_writeback_centisecs)之内的 小于 G的数据(dirty_background_ratio G/ = G)    当然 实际上 秒之内不太可能写 G的数据 因此最坏就是 秒钟之内的数据丢失 因此若要关闭sync bin 又不想丢失太多数据的话 可以通过调整dirty_writeback_centisecs这个参数 如调整到 ( 秒) 这样最多就丢 秒钟的数据 又可以提高数据的写能力     Mysql里还有一个参数可以调整 提高数据库的写能力 那就是    innodb_flush_log_at_trx_mit    这个参数默认是 即每次事务Commit时 都刷新日志 以免数据丢失 因为我们的系统允许丢失少量数据 因此可以把innodb_flush_log_at_trx_mit设置为 允许丢失一个事务的数据 经测试 发现 可以提高 %左右的性能     另外对于文件系统的mount方式 noatime方式也可以提高部分性能(数据库专用的服务器 一般是noatime)    当数据有删除更新操作后 时间长后一般有碎片 导致索引空间不紧凑 占用更多的硬盘空间 因此会导致查询编码 解决办法是定期执行下面的语句     ALTER TABLE tbl_name ENGINE=INNODB    另外若sql语句中有sort 和group by之类 需要增大sort_buffer_size    这个参数是每客户端连接的 当有sort/group查询时 会分配sort_buffer_size大小的内存 因此若连接很多 则要小心 合适的值可以查看SHOW GLOBAL STATUS里面Sort_merge_passes的信息以及Created_tmp_tables之类信息    原文地址 ?play=reply&id= cha138/Article/program/MySQL/201311/29481

相关参考

知识大全 mysql性能的检查和调优方法

  我一直是使用mysql这个数据库软件它工作比较稳定效率也很高在遇到严重性能问题时一般都有这么几种可能  索引没有建好  sql写法过于复杂  配置错误  机器实在负荷不了  索引没有建好  如果看

知识大全 mysql性能的检查和调优方法[1]

   我一直是使用mysql这个数据库软件它工作比较稳定效率也很高在遇到严重性能问题时一般都有这么几种可能   索引没有建好 &n

知识大全 mysql性能的检查和调优方法[5]

   这时可以看到结果集还是条但是Extra中的filesort不见了这时mysql使用userid_clicks这个索引去查询这不但能快速查询到userid=admin

知识大全 mysql性能的检查和调优方法[6]

   机器实在负荷不了   如果做了以上调整服务器还是不能承受那就只能通过架构级调整来优化了   mysql同

知识大全 mysql性能的检查和调优方法[3]

   嗯这时可以看到mysql使用了userid这个索引搜索了用userid索引一次搜索后结果集有条然后虽然使用了filesort一条一条排序但是因为结果集只有区区条效率

知识大全 mysql性能的检查和调优方法[2]

   rowinset(sec)   注意keyrows和Extra这三项这条语句返回的结果说明了该sql会使用PRIMARY主键索引来查询

知识大全 Hibernate性能调优

Hibernate性能调优  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  inverse=?  

知识大全 Hibernate性能调优[2]

Hibernate性能调优[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  Hibernat

知识大全 Hibernate性能调优[1]

Hibernate性能调优[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  inverse=

知识大全 Java程序性能优化-设计调优

Java程序性能优化-设计调优  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!   性能调