• 1548阅读
  • 0回复

MySQL性能优化之max_connections配置参数浅析

楼层直达
UI~hB4V$]  
这篇文章主要介绍了MySQL性能优化之max_connections配置参数浅析,本文着重讲解了3种配置max_connections参数的方法,需要的朋友可以参考下 aeEio;G1  
02YmV%  
. Bt(nm> Ng  
. n-OQCz9Xl  
&QFc)QP{  
MySQL的max_connections参数用来设置最大连接(用户)数。每个连接MySQL的用户均算作一个连接,max_connections的默认值为100。本文将讲解此参数的详细作用与性能影响。 M5N #xgR  
s'BlFB n  
与max_connections有关的特性 8KsPAK_  
)kYDN_W  
MySQL无论如何都会保留一个用于管理员(SUPER)登陆的连接,用于管理员连接数据库进行维护操作,即使当前连接数已经达到了max_connections。因此MySQL的实际最大可连接数为max_connections+1; FJn.V1  
这个参数实际起作用的最大值(实际最大可连接数)为16384,即该参数最大值不能超过16384,即使超过也以16384为准; zu 7Fq]zD  
增加max_connections参数的值,不会占用太多系统资源。系统资源(CPU、内存)的占用主要取决于查询的密度、效率等; q w @g7  
该参数设置过小的最明显特征是出现”Too many connections”错误; @E>I<j,D  
2G_]Y8  
我们先来看下如何查看当前mysql的max_connections的值: msQ?V&+<  
bL5u;iy)  
如下sql S F da?>  
b Rr3:"=sE  
aj<r=  
复制代码 代码如下: m^w{:\p  
r;+a%?P  
?%n"{k?#  
show variables like "max_connections"; \9`.jB~<  
x~K79Mya  
D  ,[yx='  
7m}fVLk  
显示的结果如下格式 I1I-,~hO  
wJ"]H!r0  
+-----------------+-------+ }F|B'[wn  
| Variable_name   | Value | fB]NEx|o~  
+-----------------+-------+ {qOqtkj  
| max_connections | 100   | lQy-&d|=#^  
+-----------------+-------+ Ul}<@d9: B  
i1'G_bo4F7  
可以通过下面的sql语句将max_connections的值设置为200,当然前提是当前登录的用户有足够的权限: _ {6l}  
8H`L8: CM  
set global max_connections = 200; c2?VjuB0  
Uv652DC  
这个设置会马上生效,但是当mysql重启时这个设置会失效,更好的办法是修改mysql的ini配置文件my.ini NEvNj  
cBv"d ~  
找到mysqld块,修改或者添加下面的设置: rm-;Z<  
E0yx @Vx  
max_connections=200 sZEa8  
^@{"a  
这样修改之后,即便重启mysql也会默认载入这个配置了 "_&c[VptWi  
.!Kqcz% A  
不过为了安全期间,建议大家直接到my.ini里修改,么有可以加上。 B2a#:E,6  
HFlExa u  
调整max_connections参数的值 "z;R"sv\  
w=a$]`  
调整此参数的方法有几种,既可以在编译的时候设置,也可以在MySQL配置文件 my.cnf 中设置,也可以直接使用命令调整并立即生效。 es~1@Jb  
=8%*Rrj^  
1、在编译的时候设置默认最大连接数 29VX-45  
vxLr034  
打开MySQL的源码,进入sql目录,修改mysqld.cc文件: ByO?qft>u  
k7;i^$@c  
9+xO2n  
复制代码 代码如下: 3bR%#G%  
nc\2A>f`  
oif|X7H;  
{"max_connections", OPT_MAX_CONNECTIONS, )9[u*|+  
"The number of simultaneous clients allowed.", (gptr*) &max_connections, CV_M |  
(gptr*) &max_connections, 0, GET_ULONG, REQUIRED_ARG, 100, 1, 16384, 0, 1, `wQs$!a  
0}, YD;d*E%t  
k0#s{<I]E  
红色的”100″即为该参数的默认值,修改为想要的数值,存盘退出。然后执行 i/H;4#Bz  
hITYBPqRO  
复制代码 代码如下: ('UTjV  
U]_WX(4 @  
QKB+mjMH#x  
./configure;make;make install Tsj/alC[  
Ui"{0%  
重新编译安装MySQL;注意,由于编译安装且修改了MySQL源码,此操作最好在安装MySQL之前进行; L8!yP.3   
W=w]`'  
2、在配置文件my.cnf中设置max_connections的值 D4|Ajeo;1  
k ,+,,W  
打开MySQL配置文件my.cnf =~Qg(=U0U  
m"'LT0nur  
eOF *|9  
复制代码 代码如下: |N% l at  
oy5K* }  
u_ l?d  
[root@www ~]# vi /etc/my.cnf ?%qaoxG37  
!/u  
找到max_connections一行,修改为(如果没有,则自己添加), :r hB=  
KCw  
复制代码 代码如下: {d;z3AB  
M!Ao!D[  
gN:F50   
max_connections = 1000 [~ 2m*Q  
=FV(m S  
上面的1000即该参数的值。 2p\xgAW?  
!E?+1WDS0  
3、实时(临时)修改此参数的值 zQ{bMj<S  
w)zJ $l  
首先登陆mysql,执行如下命令: 0 3v&k  
SsW<,T  
OzrIiahz/  
复制代码 代码如下: W-#DEU 7_  
1~K'r&  
&T0]tzk*,  
[root@www ~]# mysql -uroot -p >wmHCOL:  
JfWkg`LqL  
然后输入MySQL Root的密码。 cYg J}(>}  
upaP,ik}~  
查看当前的Max_connections参数值: iY07lvG<  
99ZWB  
sU&v B:]~  
复制代码 代码如下: c:.5@eq^  
U?f-/@fc  
Pa Q lQ#  
mysql> SELECT @@MAX_CONNECTIONS AS 'Max Connections'; xJ{r9~  
$%DoLpE>  
设置该参数的值: [T =>QS@g  
lAi5sN)|$  
复制代码 代码如下: uXFI7vV6P  
m0ra  
mm +V*L{x  
mysql> set GLOBAL max_connections=1000; ohKoX$|p~  
DKfpap}8u  
(注意上面命令的大小写) ])F+ C/Px1  
oH0g>E;  
修改完成后实时生效,无需重启MySQL。 d"?"(Q_8n  
}FS_"0  
总体来说,该参数在服务器资源够用的情况下应该尽量设置大,以满足多个客户端同时连接的需求。否则将会出现类似”Too many connections”的错误。 #2%V  
一般情况下根据同时在线人数设置一个比较综合的数字,我们设置的是10000. ?sdSi--  
快速回复

限100 字节
安逸网提示:批量上传需要先选择文件,再选择上传
 
认证码:
上一个 下一个