mysql性能优化的简单说明-kb88凯时官网登录

时间:2018-08-10
阅读:
免费资源网 - https://freexyz.cn/

mysql 作为 lamp 组件中的重要一环,在网站架构中担当关于数据处理的重任。作为目前流行最为广泛的开源数据库,网络上已经有相当多的各种优化教程。本文将试着从改善 mysql 配置入手,进一步提升 mysql 的性能。

关于如何优化数据库结构及 sql 语句不在本次讨论范围之内。

mysql 性能优化我打算分为三个部分,一是物理硬件的优化,二是 mysql 安装时的编译优化,三是 mysql 的配置文件 my.cnf 的优化。

一、物理硬件的优化

磁盘 i/o 是制约 mysql 性能的最大因素之一。

采用 ssd 的肯定会比普通 hdd 硬盘性能要好;采用 raid10 的肯定要比单盘的性能要好。

所谓物理硬件的优化,其实也就是服务器()硬件的堆砌。更多的内存,更快的磁盘,更强的 cpu 无疑就是最佳的。

二、mysql 安装时的编译优化

一般情况下不建议直接 yum 安装 mysql ,一来不能定制功能,二来版本比较老。所以我一般会采取编译安装的方式。

源码编译安装的前提条件(依赖包):

1、cmake。d88尊龙官网手机app官网:http://www.cmake.org/ 

2、gcc,a working ansi c compiler. gcc 4.2.1 or later。d88尊龙官网手机app官网:http://www.gnu.org/software/gcc/

3、bison,2.1 or newer。d88尊龙官网手机app官网:http://www.gnu.org/software/bison/

4、m4。d88尊龙官网手机app官网:http://www.gnu.org/software/m4/

5、tar。d88尊龙官网手机app官网: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),肯定不是适合你的(是适合我的)。

而上面只是列举出几个比较重要的参数,更多的参数请参照官方网站。

免费资源网 - https://freexyz.cn/
返回顶部
顶部
网站地图