MySQL大表优化方案之引擎优化

引擎

目前广泛使用的是MyISAM和InnoDB两种引擎:

MyISAM

MyISAM引擎是MySQL 5.1及之前版本的默认引擎,它的特点是:

  • 不支持行锁,读取时对需要读到的所有表加锁,写入时则对表加排它锁
  • 不支持事务
  • 不支持外键
  • 不支持崩溃后的安全恢复
  • 在表有读取查询的同时,支持往表中插入新纪录
  • 支持BLOBTEXT的前500个字符索引,支持全文索引
  • 支持延迟更新索引,极大提升写入性能
  • 对于不会进行修改的表,支持压缩表,极大减少磁盘空间占用
InnoDB

InnoDB在MySQL 5.5后成为默认索引,它的特点是:

  • 支持行锁,采用MVCC来支持高并发
  • 支持事务
  • 支持外键
  • 支持崩溃后的安全恢复
  • 不支持全文索引

总体来讲,MyISAM适合SELECT密集型的表,而InnoDB适合INSERTUPDATE密集型的表

系统调优参数

可以使用下面几个工具来做基准测试:

  • sysbench:一个模块化,跨平台以及多线程的性能测试工具
  • iibench-mysql:基于 Java 的 MySQL/Percona/MariaDB 索引进行插入性能测试工具
  • tpcc-mysql:Percona开发的TPC-C测试工具

具体的调优参数内容较多,具体可参考官方文档,这里介绍一些比较重要的参数:

  • back_log:back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。也就是说,如果MySql的连接数据达到max_connections时,新来的请求将会被存在堆栈中,以等待某一连接释放资源,该堆栈的数量即back_log,如果等待连接的数量超过back_log,将不被授予连接资源。可以从默认的50升至500
  • wait_timeout:数据库连接闲置时间,闲置连接会占用内存资源。可以从默认的8小时减到半小时
  • max_user_connection: 最大连接数,默认为0无上限,最好设一个合理上限
  • thread_concurrency:并发线程数,设为CPU核数的两倍
  • skip_name_resolve:禁止对外部连接进行DNS解析,消除DNS解析时间,但需要所有远程主机用IP访问
  • key_buffer_size:索引块的缓存大小,增加会提升索引处理速度,对MyISAM表性能影响最大。对于内存4G左右,可设为256M或384M,通过查询show status like 'key_read%',保证key_reads / key_read_requests在0.1%以下最好
  • innodb_buffer_pool_size:缓存数据块和索引块,对InnoDB表性能影响最大。通过查询show status like 'Innodb_buffer_pool_read%',保证 (Innodb_buffer_pool_read_requests – Innodb_buffer_pool_reads) / Innodb_buffer_pool_read_requests越高越好
  • innodb_additional_mem_pool_size:InnoDB存储引擎用来存放数据字典信息以及一些内部数据结构的内存空间大小,当数据库对象非常多的时候,适当调整该参数的大小以确保所有数据都能存放在内存中提高访问效率,当过小的时候,MySQL会记录Warning信息到数据库的错误日志中,这时就需要该调整这个参数大小
  • innodb_log_buffer_size:InnoDB存储引擎的事务日志所使用的缓冲区,一般来说不建议超过32MB
  • query_cache_size:缓存MySQL中的ResultSet,也就是一条SQL语句执行的结果集,所以仅仅只能针对select语句。当某个表的数据有任何任何变化,都会导致所有引用了该表的select语句在Query Cache中的缓存数据失效。所以,当我们的数据变化非常频繁的情况下,使用Query Cache可能会得不偿失。根据命中率(Qcache_hits/(Qcache_hits+Qcache_inserts)*100))进行调整,一般不建议太大,256MB可能已经差不多了,大型的配置型静态数据可适当调大.
    可以通过命令show status like 'Qcache_%'查看目前系统Query catch使用大小
  • read_buffer_size:MySql读入缓冲区大小。对表进行顺序扫描的请求将分配一个读入缓冲区,MySql会为它分配一段内存缓冲区。如果对表的顺序扫描请求非常频繁,可以通过增加该变量值以及内存缓冲区大小提高其性能
  • sort_buffer_size:MySql执行排序使用的缓冲大小。如果想要增加ORDER BY的速度,首先看是否可以让MySQL使用索引而不是额外的排序阶段。如果不能,可以尝试增加sort_buffer_size变量的大小
  • read_rnd_buffer_size:MySql的随机读缓冲区大小。当按任意顺序读取行时(例如,按照排序顺序),将分配一个随机读缓存区。进行排序查询时,MySql会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySql会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大。
  • record_buffer:每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。如果你做很多顺序扫描,可能想要增加该值
  • thread_cache_size:保存当前没有与连接关联但是准备为后面新的连接服务的线程,可以快速响应连接的线程请求而无需创建新的
  • table_cache:类似于thread_cache_size,但用来缓存表文件,对InnoDB效果不大,主要用于MyISAM

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/4599.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2018年3月10日 16:33
下一篇 2018年3月10日 16:37

相关推荐

  • 经验分享mysql一行数据长度限制。

    MySQL是一种关系型数据库管理系统,它使用表格来存储数据,在MySQL中,一行被称为记录,一列被称为字段,下面我们将详细介绍MySQL中的行和列。 (图片来源网络,侵删) 1、行(Record) 在MySQL中,行是一张表中的…

    2024年6月20日
    02
  • 聊聊教程宝塔面板一键安装配置详解视频。

    本视频教程详细讲解了如何使用宝塔面板一键安装配置,方便用户快速搭建网站。 教程宝塔面板一键安装配置详解 简介 宝塔面板是一款服务器管理工具,支持Linux和Windows系统,它可以帮助用户轻松管理服务器,包括网站…

    2024年7月8日
    03
  • 我来说说mysql如何查看表是否存在。

    在MySQL数据库中,查询一个表是否存在可以通过几种不同的方法来实现,以下是一些常用的技术教学和步骤说明: (图片来源网络,侵删) 方法一:使用SHOW TABLES语句 最简单直接的方法是使用SHOW TABLES语句来列出数…

    2024年6月19日
    08
  • 说说云服务器内存耗尽怎么解决的。

    当云服务器内存耗尽时,首先需要查看内存使用情况。如果发现内存使用率≥80%,则可以定义为内存使用率过高。此时,可以通过创建虚拟内存磁盘卷来扩展内存,大概设置在2G左右,视磁盘大小和需求而定。具体操作步骤包…

    2024年7月17日
    03
  • 关于宝塔登入。

    宝塔面板是一款非常流行的服务器管理软件,它以可视化界面、功能丰富和操作简便而受到广大网站管理员的喜爱,本指南旨在帮助初学者轻松上手宝塔面板,实现快速部署和管理服务器。 安装宝塔面板 要使用宝塔面板,首…

    2024年7月22日
    00
  • 说说mysql怎么删除数据库命令。

    在MySQL中,删除数据库的操作可以通过`DROP DATABASE`语句来实现,这个操作会删除整个数据库及其包含的所有表、视图、存储过程等对象,请注意,这是一个不可逆的操作,所以在执行前请确保已经备份好重要数据。 以下…

    2024年6月19日
    05
  • 我的php学习第二十五天——网页版的数据库管理和php基本语法

    Phpmyadmin,网页版的数据库管理 下载一个phpmyadmin,并解压 2.将phpmyadmin放入到htdocs下面 3.直接在浏览器中输入localhost/phpadmin/index.php 4.开启mysqli扩展即可php.ini 5.重启Apache 6.输入数据库的用户名…

    2017年5月2日 MySQL自学教程
    0233
  • 关于纯真数据库。

    【纯真数据库】是一个基于SQL的开源数据库管理系统,它具有轻量级、易用性强等特点,下面是【纯真数据库】的一些特点: 1. 开源免费:【纯真数据库】是一款完全免费的开源数据库管理系统,用户可以自由使用和修改源…

    2024年6月18日
    02

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息