mysql性能下降怎么办 mysql 性能调优( 三 )


MySQL速度变慢,怎么办MySQL 在崩溃恢复时mysql性能下降怎么办,会遍历打开所有 ibd 文件mysql性能下降怎么办的 header page 验证数据字典mysql性能下降怎么办的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时 。MySQL 下崩溃恢复确实和表数量有关 , 表总数越大 , 崩溃恢复时间越长 。另外磁盘 IOPS 也会影响崩溃恢复时间 , 像这里开发库mysql性能下降怎么办的 HDD IOPS 较低,因此面对大量的表空间 , 校验速度就非常缓慢 。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍 。不过 MySQL 8.0 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描 , 加快表空间校验过程 。
如何跳过校验MySQL 5.7 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种mysql性能下降怎么办:
1. 配置 innodb_force_recovery可以使 srv_force_recovery != 0 , 那么 validate= false,即可以跳过表空间校验 。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了 。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程 , 快速启动 MySQL,个人目前暂时未发现有什么隐患 。2. 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间 。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势 。
临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了 。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长 。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭 。
如何优化mysql写入速单机MySQL数据库的优化
一、服务器硬件对MySQL性能的影响
①磁盘寻道能力 (磁盘I/O),我们现在上的都是SAS15000转的硬盘 。MySQL每秒钟都在进行大量、复杂的查询操作,对磁盘的读写量可想而知 。所以 , 通常认为磁 盘I/O是制约MySQL性能的最大因素之一 , 对于日均访 问量在100万PV以上的Discuz!论坛,由于磁盘I/O的制约,MySQL的性能会非常低下!解决这一制约因素可以考虑以下几种解决方案: 使用RAID1+0磁盘阵列 , 注意不要尝试使用RAID-5,MySQL在RAID-5磁盘阵列上的效率不会像你期待的那样快 。
②CPU 对于MySQL应用,推荐使用DELL R710,E5620 @2.40GHz(4 core)* 2 ,我现在比较喜欢DELL R710,也在用其作Linuxakg 虚拟化应用;
③物理内存对于一台使用MySQL的Database Server来说 , 服务器内存建议不要小于2GB , 推荐使用4GB以上的物理内存,不过内存对于现在的服务器而言可以说是一个可以忽略的问题 , 工作中遇到高端服务器基本上内存都超过了32G 。
我们工作中用得比较多的数据库服务器是HP DL580G5和DELL R710 , 稳定性和性能都不错;特别是DELL R710,我发现许多同行都是采用它作数据库的服务器,所以重点推荐下 。
二、MySQL的线上安装我建议采取编译安装的方法,这样性能上有较大提升,服务器系统我建议用64bit的Centos5.5,源码包的编译参数会默 认以Debgu模式生成二进制代码,而Debug模式给MySQL带来的性能损失是比较大的,所以当我们编译准备安装的产品代码时,一定不要忘记使用“— without-debug”参数禁用Debug模式 。而如果把—with-mysqld-ldflags和—with-client-ldflags二 个编译参数设置为—all-static的话 , 可以告诉编译器以静态方式编译和编译结果代码得到最高的性能 。使用静态编译和使用动态编译的代码相比,性能 差距可能会达到5%至10%之多 。我参考了简朝阳先生的编译参数,特列如下 , 供大家参考

推荐阅读