MySQL数据库 连接出现以下异常:
ERROR 1135 (HY0000):?Can’t create a new thread (errno 11); if you are not out of available memory, you can consult the manual for a possible OS-dependent bug
?以上是OS层面的max processes不够导致的,通过以下实验可以重现此异常:
#设置mysql最大连接数1024 操作系统的Max process为1024
#使用如下方法模拟100个连接到mysql
~]# cat conn.sh
#!/bin/bash
for i in {1..1024}
do
mysql -uroot –p123456 -h 127.0.0.1 -e "select sleep(1000)" &
done
sh conn.sh
运行此脚本,稍后出现如下报错
此时查看mysql中的连接数
我们知道max connections是1024 但到了975个连接的时候,再次连接就会报Can’t create a new thread (errno 11)的错误
从 OS kernel 2.6.32 开始 :
动态修改mysql进程的limits参数,可以使用如下方式:
echo -n ‘Max processes=SOFT_LIMITS:HARD_LIMITS’ > /proc/`pidof mysqld`/limits
通过如上命令就可以动态调整已经存在的mysqld的processes限制了。
例如,在此实验环境中,操作系统信息如下:
~]# uname -r
2.6.32-131.0.15.el6.x86_64
~]# echo -n "Max processes=10240:10240" > /proc/12946/limits
发现mysql进程对应的limit参数已经动态变成10240,此时再次模拟多个连接到mysql:
此时,抛出的异常是过多的连接了 而不再是:?Can’t create a new thread (errno 11)
综上,数据库服务器的max process limit需要调整,至少要保证数据库的max connections小于它,如果已经运行的mysql遇到此问题,而实际真的需要增大max connections时,可以通过echo -n ‘Max processes=SOFT_LIMITS:HARD_LIMITS’ > /proc/`pidof mysqld`/limits 方式来动态调整正在运行的mysql的limits参数,从而避免重启数据库的操作
参考https://www.percona.com/blog/2013/02/04/cant_create_thread_errno_11/
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27000195/viewspace-1979138/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/27000195/viewspace-1979138/