98
MySQL性能优化

最后更新时间:2018-10-26 9:58:01



  • 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

结合my.cnf 文件,只列出其中 [mysqld] 段落中的内容,其他段落内容对 MySQL 运行性能影响甚微,因而姑且忽

略。

介绍一些优化参数。

  1. [mysqld]

  2. port = 3306

  3. socket = /tmp/mysql.sock

  4. 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,依此类推即可。

  • ead_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,依此类推。


这条帮助是否解决了您的问题? 已解决 未解决

提交成功!非常感谢您的反馈,我们会继续努力做到更好! 很抱歉未能解决您的疑问。我们已收到您的反馈意见,同时会及时作出反馈处理!