a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 75|回复: 0

[LPI认证] linux认证辅导:MySQL性能调优详解

[复制链接]
发表于 2012-8-4 12:13:19 | 显示全部楼层 |阅读模式
使用主备复制,因此需要打开Log-Bin,这里就涉及一个sync-bin的概念,缺省情况下,sync-bin 在mysql中是关闭的,但存在一个风险,因为写日志没有刷新到硬盘中去的话,日志是写在操作系统的文件系统里的Cache中,这样若机器断电,那么日志信息将部分丢失。为了减少数据丢失,我们测试了sync-bin=1,sync-bin=5和sync-bin=20,三种情况,sync-bin=1的情况下,丢失数据最坏概率是丢一个事务的数据,但性能非常差;设置sync-bin=5的情况下,性能可以提高1倍左右;设置sync-bin=20时,性能比sync-bin=5又可以提高1倍,设置大于20的值,基本上相差不大,性能提高不了多少,最坏20个事务数据丢失是在我们的允许范围之内,因此设置20是个合理的值,这个值具体取决于你的系统能够最坏允许丢少的事务数据。
& n- N3 X5 h& @" ~5 M    若你的系统对数据丢失不于考虑,可以关闭sync-bin,这时数据刷新到硬盘完全取决于操作系统的配置,相关的配置参数有如下:+ R( g& j4 m" C5 q
    /proc/sys/vm/dirty_ratio
' Y. _( V$ m1 w1 N$ k! q& e+ a1 ]  P    这个参数控制一个进程在文件系统中的文件系统写缓冲区的大小,单位是百分比,表示系统内存的百分比,表示当一个进程中写缓冲使用到系统内存多少的时候,再有磁盘写操作时开始向磁盘写出数据。增大之会使用更多系统内存用于磁盘写缓冲,也可以极大提高系统的写性能。但是,当你需要持续、恒定的写入场合时,应该降低其数值,一般缺省是 40。更新方法
; a* n) [* \8 C3 ~+ x5 H    echo 30 >/proc/sys/vm/dirty_ratio (或则修改/etc/sysctl.conf文件,增加sys.vm.dirty_ratio=30 重起机器)
9 `, J4 |, Z2 [6 s0 B" k    /proc/sys/vm/dirty_background_ratio
  A9 p. |7 p8 j/ p- h$ b; ?    这个参数控制文件系统的pdflush进程,在何时刷新磁盘。单位是百分比,表示系统总内存的百分比,意思是当磁盘的脏数据缓冲到系统内存多少的时候,pdflush开始把脏数据刷新到磁盘。增大会使用更多系统内存用于磁盘写缓冲,也可以极大提高系统的写性能。但是,当你需要持续、恒定的写入场合时,应该降低其数值,一般缺省是10。+ {: B9 G" W+ j. |% c, d$ y
    /proc/sys/vm/dirty_writeback_centisecs
( v4 O  f9 A3 U    Pdflush写后台进程每隔多久被唤醒并执行把脏数据写出到硬盘。单位是 1/100 秒。缺省数值是500,也就是 5 秒。如果你的系统是持续地写入动作,那么实际上还是降低这个数值比较好,这样可以把尖峰的写操作削平成多次写操作。设置方法如下:
% V) ~9 P4 C- ~    echo 200 >/proc/sys/vm/dirty_writeback_centisecs5 O0 K& B/ }/ q# [/ S! f8 [1 e
    /proc/sys/vm/dirty_expire_centisecs
! C( O. ~" ~! @3 M6 K3 w" g2 ?    这个参数声明Linux内核写缓冲区里面的脏数据多“旧”了之后,pdflush进程就开始考虑写到磁盘中去。单位是 1/100秒。缺省是 30000,也就是 30 秒的数据就算旧了,将会刷新磁盘。对于特别重载的写操作来说,这个值适当缩小也是好的,但也不能缩小太多,因为缩小太多也会导致IO提高太快。建议设置为 1500,也就是15秒算旧。
1 r+ U8 w( T; x- D; `    echo 1500 >/proc/sys/vm/ dirty_expire_centisecs
9 W, l/ n) X' x" U    因此若没有调整这些参数,全部以缺省值,而且关闭sync-bin的话,那么最多丢失的数据是:
+ P6 P5 C' F8 C! m1 w$ t    5秒种(dirty_writeback_centisecs)之内的,小于1.6G的数据(dirty_background_ratio,16G/10=1.6G)0 {0 s. V" t  I1 H8 @) u, c
    当然,实际上5秒之内不太可能写1.6G的数据,因此最坏就是5秒钟之内的数据丢失。因此若要关闭sync-bin,又不想丢失太多数据的话,可以通过调整dirty_writeback_centisecs这个参数,如调整到200(2秒),这样最多就丢2秒钟的数据。又可以提高数据的写能力。% m3 w# m! d& w* W% n' n
    Mysql里还有一个参数可以调整,提高数据库的写能力,那就是
& L* p* P/ w9 m( i( _) V0 U    innodb_flush_log_at_trx_commit  X+ d8 ^5 E. w7 o. D& B" M: _+ Q
    这个参数默认是1,即每次事务Commit时,都刷新日志,以免数据丢失。因为我们的系统允许丢失少量数据,因此可以把innodb_flush_log_at_trx_commit设置为2,允许丢失一个事务的数据,经测试,发现2可以提高25%左右的性能。$ H( y& M/ B( l3 E
    另外对于文件系统的mount方式,noatime方式也可以提高部分性能(数据库专用的服务器,一般是noatime)
3 T( ]2 ?7 {  j4 r3 Z) S" G    当数据有删除更新操作后,时间长后一般有碎片,导致索引空间不紧凑,占用更多的硬盘空间,因此会导致查询编码,解决办法是定期执行下面的语句:
  {2 _6 M+ S& ^* d) p: L8 t    ALTER TABLE tbl_name ENGINE=INNODB
4 A  v- R/ h3 F7 w1 k    另外若sql语句中有sort 和group by之类,需要增大sort_buffer_size1 @+ G: h( M  n9 O6 d6 U
    这个参数是每客户端连接的,当有sort/group查询时,会分配sort_buffer_size大小的内存,因此若连接很多,则要小心;合适的值可以查看SHOW GLOBAL STATUS里面Sort_merge_passes的信息以及Created_tmp_tables之类信息。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-5-16 16:41 , Processed in 0.178683 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表