找回密码
 立即注册
搜索
查看: 212|回复: 0

MySQL性能优化

[复制链接]

989

主题

92

回帖

5万

积分

管理员

积分
55362
发表于 2022-7-4 16:57:12 | 显示全部楼层 |阅读模式
5 B8 ^' o* }. l

' l* b: Z1 j3 B3 DMySQL 作为 LAMP 组件中的重要一环,在网站架构中担当关于数据处理的重任。作为目前流行最为广泛的开源数据库,网络上已经有相当多的各种优化教程。本文将试着从改善 MySQL 配置入手,进一步提升 MySQL 的性能。2 w% Y. o: D' r* G! r; _3 k( i
关于如何优化数据库结构及 SQL 语句不在本次讨论范围之内。
* d8 z- P) o- U  fMySQL 性能优化我打算分为三个部分,一是物理硬件的优化,二是 MySQL 安装时的编译优化,三是 MySQL 的配置文件 my.cnf 的优化。0 ~' O. h9 j( @6 \
        5 B2 o  Q+ g/ p, E: |
一、物理硬件的优化
3 u7 y$ I* F- v/ _磁盘 I/O 是制约 MySQL 性能的最大因素之一。
+ F* f4 n; a. w采用 SSD 的服务器肯定会比普通 HDD 硬盘性能要好;采用 RAID10 的肯定要比单盘的性能要好。7 `1 {% x+ I0 M1 G5 V: Q
所谓物理硬件的优化,其实也就是服务器(VPS)硬件的堆砌。更多的内存,更快的磁盘,更强的 CPU 无疑就是最佳的。) o  }% l5 f/ _& E! M) _2 s  [& h
二、MySQL 安装时的编译优化( ?6 F# y8 h- j7 L
一般情况下不建议直接 yum 安装 MySQL ,一来不能定制功能,二来版本比较老。所以我一般会采取编译安装的方式。
% Y: J& M& a; p源码编译安装的前提条件(依赖包):  F! [5 s# r4 z+ o
1、CMake。官网:http://www.cmake.org/ % t/ x% T$ K; m+ e+ w: u
2、GCC,A working ANSI C++ compiler. GCC 4.2.1 or later。官网:http://www.gnu.org/software/gcc/3 H: a+ F- N- L6 ]' I; E4 Q
3、bison,2.1 or newer。官网:http://www.gnu.org/software/bison/, i! _% X' n# S% q. @6 |- M1 p5 g
4、m4。官网:http://www.gnu.org/software/m4/
$ [3 v( o5 d% u; u( C2 U( u" C5、tar。官网:http://www.gnu.org/software/tar/
6 {, r3 Q7 d6 q7 Y编译参数:4 w9 o% A1 P2 W5 }; J0 O6 i
MySQL 5.5.x) n- x% A# c2 G3 v, N; d
http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html7 k) Z2 \3 g. P
MySQL 5.6.x
- s' l& L2 B' ~' v. S( m$ N' ahttp://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html" m$ G: V) v0 E- _* v* m' X1 O5 R
LAMP 一键安装脚本里对 MySQL 编译的参数如下:  M& D9 z4 o7 O: c# t1 B
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql $ B1 K! b+ E/ G( H/ V
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock
' y5 R0 \: C8 h& l5 V- \0 k, P-DDEFAULT_CHARSET=utf8 ' Z( t/ u! G. `; N- n
-DDEFAULT_COLLATION=utf8_general_ci
+ e) {& T* Z5 C: o8 M# S" k-DWITH_EXTRA_CHARSETS=complex
7 U( ^1 Q' S$ n7 j% u-DWITH_INNOBASE_STORAGE_ENGINE=1
/ N0 L6 S2 I( D-DWITH_READLINE=1 - Y/ I# V" O) F+ t& R1 w+ g
-DENABLED_LOCAL_INFILE=1 * }: \" {  B0 N) Q' }0 J
-DWITH_PARTITION_STORAGE_ENGINE=1 . u5 y. _/ G" U0 j
-DWITH_FEDERATED_STORAGE_ENGINE=1 & C- N0 b" i; [  I& D5 q3 q3 p
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
+ S/ v* w/ W9 p0 k-DWITH_MYISAM_STORAGE_ENGINE=1 % G8 _5 x# p' W- H! T; h: ^
-DWITH_EMBEDDED_SERVER=1# G% U1 Z# U7 V+ S
由于 -DWITH_DEBUG 默认就是 OFF 状态,所以也无需特别指定此参数。
+ z8 y0 m# o. J8 W# O* n7 J三、MySQL 的配置文件 my.cnf 的优化4 j0 c  y4 T; e7 X$ |* F. t
配置文件:
" z" `& k1 F, L4 D( Z; ?% T9 IMySQL 5.5.x
2 V1 l: k( `1 f2 [https://dev.mysql.com/doc/refman/5.5/en/server-system-variables.html7 E% Q" ?% l7 `9 e9 N
MySQL 5.6.x
8 i6 }0 G+ R" D! h5 ehttps://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html
3 s4 o( b: }/ e9 c( g9 X结合 LAMP 一键安装脚本的 my.cnf 文件,只列出其中 [mysqld] 段落中的内容,其他段落内容对 MySQL 运行性能影响甚微,因而姑且忽略。$ O9 A+ N7 A# f% b
介绍一些优化参数。
8 h' U7 x( e2 L* X& `' `[mysqld]
% z( w1 U9 p0 x! O) W, Cport = 3306
) A7 R. ?' e  d4 Vsocket = /tmp/mysql.sock( S! u) ?3 Y4 T  J4 h/ R+ d
skip-external-locking
, |# X" `% B, w  A0 w7 [#避免 MySQL 的外部锁定,减少出错几率增强稳定性。
" d6 b. B9 ^+ h& _2 ]( c' Qkey_buffer_size = 16M0 x) O& h8 N7 L9 m- J
#指定用于索引的缓冲区大小,增加它可得到更好的索引处理性能。16M适用于 512MB内存,对于内存在4GB左右的服务器该参数可设置为256M,依此类推即可。注意:该参数值设置的过大反而会是服务器整体效率降低!. s$ a! y( K9 U+ I& W  F
max_allowed_packet = 1M
/ e" \5 m6 R) s/ G/ g4 Y" q9 {#MySQL 根据此配置会限制 server 接受的数据包大小。" Y: i. e/ m  L
table_open_cache = 642 a* K; d$ }0 `! w  u) ~; E
#指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。注意,不能盲目地把table_open_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。6 w+ e5 V/ U8 _2 E! l+ L; Z
64 适用于 512MB 内存,1GB 内存则可以设置成 128,依此类推即可。
. m& q% g% o+ d+ B1 gsort_buffer_size = 512K
5 F8 ^. l( B4 t, N4 p9 l#查询排序时所能使用的缓冲区大小。注意:该参数对应的分配内存是每连接独占,如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 512K = 50MB。( F1 m+ `" f+ |. z
512K 适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。
0 p1 N  x- r/ u( y7 T, Enet_buffer_length = 8K) p' K4 {. [6 e
#初始化server 接受的数据包大小,当需要的时候再由 max_allowed_packet 控制增长的大小。注意:该参数值设置的范围只能为1 – 1024K。8 @& I  u) g& P
read_buffer_size = 256K
- U, h2 d, P: ?4 }' l2 a#读查询操作所能使用的缓冲区大小。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。, w1 D0 S% v0 }* E* [( T
256K 适用于 512MB 内存,1GB 内存则可以设置成 512K,依此类推即可。
3 X, U& L0 G- D: J$ P7 nread_rnd_buffer_size = 512K
4 {5 z8 y# \, B( g#查询操作多表所能使用的缓冲区大小。设置较大的值可以有效提升 ORDER BY 的性能。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。
8 X1 x! I. l' `( a+ W" o# J512K适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。5 i- C# v( K9 ~+ H5 B
myisam_sort_buffer_size = 8M
3 F. B# q% o( K& ~. w+ J2 \#MyISAM 排序所能使用的缓冲区大小。( G" S6 Z+ i  k6 v8 o/ u( n
8M 适用于 512MB 内存,1GB 内存则可以设置成 16M,依此类推即可。4 z# y& w- y& v( @; E3 [) @: R
max_connections = 256
" N" l/ g5 K/ T$ q4 N1 x#指定MySQL允许的最大连接进程数。如果在访问时经常出现 Too Many Connections 的错误提示,则需要增大该参数值。9 [- r% a9 M4 ]4 u
注意:该参数默认值为 151,最大可以设置为 1000000 Q) }9 g; |) A; ?6 U
这里建议设置成内存的一半,比如 512MB 内存就设置成 256,依此类推。
3 a6 m0 H- a  a; ]+ B' F+ F[写在最后]
  G8 A5 y/ `  e/ w7 x' s我发现所谓的 MySQL 优化大部分都是来自于官方文档的说明。2 Y) Z; s  t4 _
国内的教程要么是很老的,要么是随处转载的,几乎没有多大参考价值。
8 H& ~" n' U* ^6 ]0 q9 G8 r$ t, r( ]没有最优的配置文件,只有适合自己的配置。所以需要结合实际情况,比如内存大小,磁盘 I/O 状况来调整。# u: L' o) w9 D" y8 w
LAMP 一键脚本默认的配置(默认是用于 512MB 内存的 VPS),肯定不是适合你的(是适合我的)。
0 Q( x9 l4 C2 I  S而上面只是列举出几个比较重要的参数,更多的参数请参照官方网站。3 e2 I* |5 T  T; F9 x' u
# K, \8 d4 {; e7 T1 S% p0 F  l
& l$ W6 I- v, A& K
& s' o- ~9 Y$ l+ g! _
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|

GMT+8, 2026-5-6 08:39 AM , Processed in 0.092346 second(s), 23 queries .

Powered by xyh-moon X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表