ERROR 1040(HY000):Too many connections
- 数据库的整体架构,数据库自己也有一个连接池,你的每个系统部署在一台机器上的时候,你那台机器上部署的系统实例/服务自己也是一个连接池的,你的系统每个连接Socket 都会对应着数据库连接池里的一个连接socket。
- 当数据库报错Too many connections的时候,就是说他的连接池的连接已经满了,你的业务不能跟他建立更多的连接了。
max_connections
- 我们的mysql配置文件my.cnf,里面有一个关键的参数
max_connections,就是mysql能建立的最大连接数,默认设置为800 - 我们用命令查看一下
show variables like 'max_connections'
此时你可以看到mysql仅仅建立了214个连接而已;mysql根本不管我们设置的那个max_connections,就是直接强行把最大连接数设置为214.(mysql源码通过计算公式计算的)
mysql限制最大连接数的原因
- 原因时因为底层的linux操作系统把进程可以打开的文件句柄数限制为1024了,导致mysql最大连接数时214

解决方案
# 修改linux的文件句柄限制
ulimit -HSn 65535
# 可以通过如下命令查看最大句柄数是否被修改
cat /etc/security/limits.conf
cat /etc/rc.local
- 重启服务器之后,linux的最大文件句柄就会生效了,mysql的最大连接数也会生效了。
linux的ulimit
- linux默认会限制每个进程对机器资源的使用,包括可以打开的文件句柄的限制,可以打开的子进程数的限制,网络缓存的限制,最大可以锁定的内存大小,
- 一般在生产环境部署了一个系统,比如数据库系统,消息中间件系统,存储系统,缓存系统之后,都需要调整linux的一些内核参数,这个文件句柄的数量是一定要调整的,通常都设置为65535
- 可以用ulimit命令来设置每个进程被限制使用的资源量,用
ulimit -a就可以看到进程被限制使用的各资源的量。
本文解析了MySQL错误1040(Too many connections)的根本原因,涉及到数据库连接池和系统实例之间的关系。深入探讨了max_connections参数的作用,以及Linux操作系统对文件句柄数的限制如何影响最大连接数。提供了通过修改Linux文件句柄限制来解决此问题的具体步骤。
1433

被折叠的 条评论
为什么被折叠?



