MySQL性能优化的简单说明

技术 秋水逸冰 26133浏览 17评论

MySQL 作为 LAMP 组件中的重要一环,在网站架构中担当关于数据处理的重任。作为目前流行最为广泛的开源数据库,网络上已经有相当多的各种优化教程。本文将试着从改善 MySQL 配置入手,进一步提升 MySQL 的性能。
关于如何优化数据库结构及 SQL 语句不在本次讨论范围之内。
MySQL 性能优化我打算分为三个部分,一是物理硬件的优化,二是 MySQL 安装时的编译优化,三是 MySQL 的配置文件 my.cnf 的优化。

一、物理硬件的优化
磁盘 I/O 是制约 MySQL 性能的最大因素之一。
采用 SSD 的服务器肯定会比普通 HDD 硬盘性能要好;采用 RAID10 的肯定要比单盘的性能要好。
所谓物理硬件的优化,其实也就是服务器(VPS)硬件的堆砌。更多的内存,更快的磁盘,更强的 CPU 无疑就是最佳的。

二、MySQL 安装时的编译优化
一般情况下不建议直接 yum 安装 MySQL ,一来不能定制功能,二来版本比较老。所以我一般会采取编译安装的方式。
源码编译安装的前提条件(依赖包):
1、CMake。官网:http://www.cmake.org/ 
2、GCC,A working ANSI C++ compiler. GCC 4.2.1 or later。官网:http://www.gnu.org/software/gcc/
3、bison,2.1 or newer。官网:http://www.gnu.org/software/bison/
4、m4。官网:http://www.gnu.org/software/m4/
5、tar。官网:http://www.gnu.org/software/tar/

编译参数:
MySQL 5.5.x
http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html

MySQL 5.6.x
http://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html

LAMP 一键安装脚本里对 MySQL 编译的参数如下:
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock 
-DDEFAULT_CHARSET=utf8 
-DDEFAULT_COLLATION=utf8_general_ci 
-DWITH_EXTRA_CHARSETS=complex 
-DWITH_INNOBASE_STORAGE_ENGINE=1 
-DWITH_READLINE=1 
-DENABLED_LOCAL_INFILE=1 
-DWITH_PARTITION_STORAGE_ENGINE=1 
-DWITH_FEDERATED_STORAGE_ENGINE=1 
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 
-DWITH_MYISAM_STORAGE_ENGINE=1 
-DWITH_EMBEDDED_SERVER=1

由于 -DWITH_DEBUG 默认就是 OFF 状态,所以也无需特别指定此参数。

三、MySQL 的配置文件 my.cnf 的优化
配置文件:
MySQL 5.5.x
https://dev.mysql.com/doc/refman/5.5/en/server-system-variables.html

MySQL 5.6.x
https://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html

结合 LAMP 一键安装脚本的 my.cnf 文件,只列出其中 [mysqld] 段落中的内容,其他段落内容对 MySQL 运行性能影响甚微,因而姑且忽略。
介绍一些优化参数。
[mysqld]
port = 3306
socket = /tmp/mysql.sock
skip-external-locking
#避免 MySQL 的外部锁定,减少出错几率增强稳定性。

key_buffer_size = 16M
#指定用于索引的缓冲区大小,增加它可得到更好的索引处理性能。16M适用于 512MB内存,对于内存在4GB左右的服务器该参数可设置为256M,依此类推即可。注意:该参数值设置的过大反而会是服务器整体效率降低!

max_allowed_packet = 1M
#MySQL 根据此配置会限制 server 接受的数据包大小。

table_open_cache = 64
#指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。注意,不能盲目地把table_open_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。
64 适用于 512MB 内存,1GB 内存则可以设置成 128,依此类推即可。

sort_buffer_size = 512K
#查询排序时所能使用的缓冲区大小。注意:该参数对应的分配内存是每连接独占,如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 512K = 50MB。
512K 适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。

net_buffer_length = 8K
#初始化server 接受的数据包大小,当需要的时候再由 max_allowed_packet 控制增长的大小。注意:该参数值设置的范围只能为1 – 1024K。

read_buffer_size = 256K
#读查询操作所能使用的缓冲区大小。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。
256K 适用于 512MB 内存,1GB 内存则可以设置成 512K,依此类推即可。

read_rnd_buffer_size = 512K
#查询操作多表所能使用的缓冲区大小。设置较大的值可以有效提升 ORDER BY 的性能。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。
512K适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。

myisam_sort_buffer_size = 8M
#MyISAM 排序所能使用的缓冲区大小。
8M 适用于 512MB 内存,1GB 内存则可以设置成 16M,依此类推即可。

max_connections = 256
#指定MySQL允许的最大连接进程数。如果在访问时经常出现 Too Many Connections 的错误提示,则需要增大该参数值。
注意:该参数默认值为 151,最大可以设置为 100000
这里建议设置成内存的一半,比如 512MB 内存就设置成 256,依此类推。

[写在最后]
我发现所谓的 MySQL 优化大部分都是来自于官方文档的说明。
国内的教程要么是很老的,要么是随处转载的,几乎没有多大参考价值。
没有最优的配置文件,只有适合自己的配置。所以需要结合实际情况,比如内存大小,磁盘 I/O 状况来调整。
LAMP 一键脚本默认的配置(默认是用于 512MB 内存的 VPS),肯定不是适合你的(是适合我的)。
而上面只是列举出几个比较重要的参数,更多的参数请参照官方网站。

转载请注明:秋水逸冰 » MySQL性能优化的简单说明

发表我的评论
取消评论

请输入正确答案后提交评论 *超出时限。 请再次填写验证码。

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

网友最新评论 (17)

  1. key_buffer_size = 16M,16M适用于 512MB内存,对于内存在4GB左右的服务器该参数可设置为256M.我觉得4GB按理应该是128MB比较合适,为啥翻了一倍
    一缕青烟5年前(2019-10-05)回复
  2. 基本的操作都在虚拟主机
    什么最值买8年前(2016-04-17)回复
  3. 高手! 写的很详细. 谢谢了 学习了
    您好9年前(2015-11-08)回复
  4. 感謝博主的詳細解說,除了推薦參數外,連怎麼算的都講的相當清楚,此篇文比起 google 上搜尋一堆沒有 vps 環境、無法舉一反三的「教學文」(文章都還很類似,偷來的?)實用太多了。對剛碰主機的我獲益良多,真誠的,謝謝你的幫助。
    Kreen9年前(2015-09-12)回复
  5. 怎么编译 openwrt的最新版本mysql呢 ,op官方的还是5.1的 太落后鸟
    夜曦9年前(2015-08-03)回复
    • 不知道,自己去找官方教程来看吧。
      秋水逸冰9年前(2015-08-03)回复
  6. 还有一个问题:以后升级MYSQL会覆盖已修改的/etc/my.cnf 文件吗? thanks
    Ave9年前(2015-07-28)回复
  7. 我安装的150718发布的最新LAMP一键安装包,打开/etc/my.cnf,找不到 max_connections 这一项,是否漏掉了?要手动添加进去吗?
    Harry9年前(2015-07-18)回复
    • max_connections 确实没有加进去。嗯,我已经改好加进去了。 你当然可以手动加进去。
      秋水逸冰9年前(2015-07-19)回复
      • 多谢!
        Harry9年前(2015-07-19)回复
  8. 感谢楼主的认真研究!我的VPS是768MB内存,一键安装您的LAMP后,重启,然后输入TOP命令,发现mysqld占用内存竟然达110M!对比我安装的VestaCP或者CWP面板,mysqld的内存占用一般为23M左右。为何差距这么大呢?
    Harry9年前(2015-07-18)回复
    • 编译安装的和二进制安装的肯定不一样。
      秋水逸冰9年前(2015-07-19)回复
  9. 感觉很有用,但是不太懂,不过现在能操作。
    Python Swift9年前(2015-07-15)回复
  10. 感谢楼主的教程,我的VPS是1G内存用你的LAMP一键脚本,请问以上优化参数是在哪里修改呢?是不是直接修改 my.cnf 这个文件即可?但是我也找不到这个文件的路径在何处。望楼主指教 THX
    Ave9年前(2015-07-14)回复
    • 修改 /etc/my.cnf 文件里对应的参数,然后重启 mysql 即可。
      秋水逸冰9年前(2015-07-15)回复
      • ok 多谢解答
        Ave9年前(2015-07-15)回复