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

MySQL性能优化

[复制链接]

991

主题

92

回帖

5万

积分

管理员

积分
55422
发表于 2022-7-4 16:57:12 | 显示全部楼层 |阅读模式

0 J/ c& U8 |/ Y% e1 N0 Y( G2 m2 C" R/ w/ M
MySQL 作为 LAMP 组件中的重要一环,在网站架构中担当关于数据处理的重任。作为目前流行最为广泛的开源数据库,网络上已经有相当多的各种优化教程。本文将试着从改善 MySQL 配置入手,进一步提升 MySQL 的性能。+ M4 c0 e: Q" _% P4 i$ m/ R
关于如何优化数据库结构及 SQL 语句不在本次讨论范围之内。# k" M7 k9 Z! x2 S$ [) K
MySQL 性能优化我打算分为三个部分,一是物理硬件的优化,二是 MySQL 安装时的编译优化,三是 MySQL 的配置文件 my.cnf 的优化。6 ?& v# @$ c$ Y1 r
        * W) s, w+ @! `* f5 j6 h+ D0 E3 O- @! B
一、物理硬件的优化
# w; z! a, Y! e磁盘 I/O 是制约 MySQL 性能的最大因素之一。5 |& }& }( f' ^% d
采用 SSD 的服务器肯定会比普通 HDD 硬盘性能要好;采用 RAID10 的肯定要比单盘的性能要好。
# w  t9 A8 e! y; f所谓物理硬件的优化,其实也就是服务器(VPS)硬件的堆砌。更多的内存,更快的磁盘,更强的 CPU 无疑就是最佳的。6 k) e4 O. A$ F
二、MySQL 安装时的编译优化3 w) w$ U( I/ e' N) B2 }2 m
一般情况下不建议直接 yum 安装 MySQL ,一来不能定制功能,二来版本比较老。所以我一般会采取编译安装的方式。
- u2 o. s  i3 u- O6 s1 _源码编译安装的前提条件(依赖包):
0 O  ]& i  f2 T! I+ C1、CMake。官网:http://www.cmake.org/
) z& d. a) ?  M. o  G2 b2、GCC,A working ANSI C++ compiler. GCC 4.2.1 or later。官网:http://www.gnu.org/software/gcc/( A5 L* s% k! n0 v5 _  w
3、bison,2.1 or newer。官网:http://www.gnu.org/software/bison/2 j" q. A+ i: X- j# X
4、m4。官网:http://www.gnu.org/software/m4/5 j% Z$ N4 e: `0 t8 F
5、tar。官网:http://www.gnu.org/software/tar/
$ y, Y0 n$ o- v: I! {) p' R编译参数:8 S  N8 N! ?1 Z4 h3 M& ~- o- s
MySQL 5.5.x' H' A9 R' |( M# _5 V
http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html) S! L' _! W' ?
MySQL 5.6.x
/ h/ P' T2 X  ghttp://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html- M0 v' H4 @" z" i
LAMP 一键安装脚本里对 MySQL 编译的参数如下:
9 _/ Y/ N( a; |4 o6 L-DCMAKE_INSTALL_PREFIX=/usr/local/mysql 2 A2 y% l( B& G4 B" Z
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock ( n1 j5 F- @5 m7 k# A
-DDEFAULT_CHARSET=utf8
  u. `2 O4 s2 e% I5 Z' ?+ b  ~0 }5 e-DDEFAULT_COLLATION=utf8_general_ci 5 }' v& G& i  C
-DWITH_EXTRA_CHARSETS=complex # v. P. l# F* N/ U1 l
-DWITH_INNOBASE_STORAGE_ENGINE=1
8 g+ w4 o  ^. r, t  n+ T-DWITH_READLINE=1 . M8 v6 O  f! K( z: s
-DENABLED_LOCAL_INFILE=1 / K3 q$ W  _9 |( E. q7 v, O
-DWITH_PARTITION_STORAGE_ENGINE=1 ! x, K. e+ D, w
-DWITH_FEDERATED_STORAGE_ENGINE=1 ! f1 k8 `. f- g. }, @4 p
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
: Z5 }* {/ W: V5 V-DWITH_MYISAM_STORAGE_ENGINE=1 % T' K. k. x7 |6 }& e
-DWITH_EMBEDDED_SERVER=1
6 @5 x& K0 ]" X/ m* R0 i由于 -DWITH_DEBUG 默认就是 OFF 状态,所以也无需特别指定此参数。
: b1 E+ s! M! L& N1 {3 h" [* z2 c三、MySQL 的配置文件 my.cnf 的优化7 z7 _$ `. y, {) l: r
配置文件:1 {7 ]* q9 F0 l! r/ _% w( t, o
MySQL 5.5.x6 m: M8 l. {3 |0 A" j
https://dev.mysql.com/doc/refman/5.5/en/server-system-variables.html
* e; ?  q3 k* e6 p* J* VMySQL 5.6.x
# ]) W& T3 f0 {) {- l  x, B7 p2 Chttps://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html" \  K+ Q* k2 J+ C) u
结合 LAMP 一键安装脚本的 my.cnf 文件,只列出其中 [mysqld] 段落中的内容,其他段落内容对 MySQL 运行性能影响甚微,因而姑且忽略。, [. Y. w6 o& o& }! `
介绍一些优化参数。; h3 l. K7 j$ R$ p/ I
[mysqld]3 E1 K' E6 i' e) `; W* C! t
port = 3306" _7 o5 J2 [- v3 V; [+ t7 l
socket = /tmp/mysql.sock# H# ^- p3 z# \4 z
skip-external-locking
* q! v  O% a5 ]; `$ v#避免 MySQL 的外部锁定,减少出错几率增强稳定性。# L2 B9 O; u0 T* f5 o' F) w
key_buffer_size = 16M) r5 n  D1 n4 G9 `
#指定用于索引的缓冲区大小,增加它可得到更好的索引处理性能。16M适用于 512MB内存,对于内存在4GB左右的服务器该参数可设置为256M,依此类推即可。注意:该参数值设置的过大反而会是服务器整体效率降低!
6 |& X6 Q& J* M* y! f+ Lmax_allowed_packet = 1M
: |2 ^% V" R+ P, v% ]#MySQL 根据此配置会限制 server 接受的数据包大小。
1 S+ N# J: t* p9 T7 jtable_open_cache = 64
1 E) {9 @* |3 `. p2 }' n7 g+ H, h#指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。注意,不能盲目地把table_open_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。
7 R) e% R( x1 B% \$ ?/ l64 适用于 512MB 内存,1GB 内存则可以设置成 128,依此类推即可。0 q2 `) s. v6 |# q& e  r
sort_buffer_size = 512K
' M6 q& w0 y- W% p' s0 @#查询排序时所能使用的缓冲区大小。注意:该参数对应的分配内存是每连接独占,如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 512K = 50MB。
% \6 `! l& F7 A# d512K 适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。5 Q7 k# ]4 |7 \9 G: C$ _
net_buffer_length = 8K) P* Z7 J# r) }$ V, [- K
#初始化server 接受的数据包大小,当需要的时候再由 max_allowed_packet 控制增长的大小。注意:该参数值设置的范围只能为1 – 1024K。9 @. U: U2 i# ]% \5 |; l
read_buffer_size = 256K$ O5 Z; u, ~' e; ?5 `
#读查询操作所能使用的缓冲区大小。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。
% W2 }3 R$ f$ q) M! x# ~1 ~256K 适用于 512MB 内存,1GB 内存则可以设置成 512K,依此类推即可。
) p9 E& H- p: w/ R& ?! A3 ^$ w1 iread_rnd_buffer_size = 512K
- Q& k. R/ A% l+ s0 ?#查询操作多表所能使用的缓冲区大小。设置较大的值可以有效提升 ORDER BY 的性能。和 sort_buffer_size 一样,该参数对应的分配内存也是每连接独享。
* K: p  i) x$ t; g8 c* C" K512K适用于 512MB 内存,1GB 内存则可以设置成 1M,依此类推即可。5 ^+ U- K" h( A6 F2 [& A+ s" k9 r- A
myisam_sort_buffer_size = 8M
) K5 v* ^  @4 P- b( G. ]- n# v#MyISAM 排序所能使用的缓冲区大小。- {1 W5 N% D' i: p0 Y0 I
8M 适用于 512MB 内存,1GB 内存则可以设置成 16M,依此类推即可。" Q; `8 h& q! |; O% }
max_connections = 256$ Z: ]" M6 q0 j8 [/ B, c
#指定MySQL允许的最大连接进程数。如果在访问时经常出现 Too Many Connections 的错误提示,则需要增大该参数值。
. y: ^& t: J, \* ]注意:该参数默认值为 151,最大可以设置为 100000
% @* A! |& @4 u6 E这里建议设置成内存的一半,比如 512MB 内存就设置成 256,依此类推。, `0 K5 }* d6 X- V
[写在最后]
& R" t3 g& u$ a2 N# E" p我发现所谓的 MySQL 优化大部分都是来自于官方文档的说明。9 i3 A+ t+ I" s8 d5 w/ U
国内的教程要么是很老的,要么是随处转载的,几乎没有多大参考价值。/ |& F4 v& I% ~: W
没有最优的配置文件,只有适合自己的配置。所以需要结合实际情况,比如内存大小,磁盘 I/O 状况来调整。
) B9 K' M4 j% v9 s* M% VLAMP 一键脚本默认的配置(默认是用于 512MB 内存的 VPS),肯定不是适合你的(是适合我的)。: R: Z( c4 y; I0 ]; M4 c% O  T2 @. ?
而上面只是列举出几个比较重要的参数,更多的参数请参照官方网站。3 f2 D' e2 k+ D

' U5 o3 G$ X, i
' y/ h, B! @3 a# Q& }$ r6 Z5 L# ]. J* U! t. K
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|

GMT+8, 2026-6-20 02:40 PM , Processed in 0.115866 second(s), 22 queries .

Powered by xyh-moon X3.5

© 2001-2025 Discuz! Team.

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