-- 查看最大连接数
show variables like '%max_connection%';
-- 重新设置最大连接数
set global max_connections=700;
-- 查看数据库状态
-- threads_created:表示创建过的线程数,threads_created过大,
-- 表明mysql服务器一直在创建线程,这也是比较耗资源,说明服务器不健康。
show status like 'Threads%';
-- 查询服务器 thread_cache_size 配置
show variables like 'thread_cache_size';
-- 设置 线程缓存数量
set global thread_cache_size=100;
1、max_connections最大连接数
查询数据库当前设置的最大连接数
show variables like '%max_connections%';
Variable_name | Value |
---|---|
max_connections | 1000 |
MySQL无论如何都会保留一个用于管理员(SUPER)登陆的连接,用于管理员连接数据库进行维护操作,即使当前连接数已经达到了max_connections。因此MySQL的实际最大可连接数为max_connections+1;
这个参数实际起作用的最大值(实际最大可连接数)为16384,即该参数最大值不能超过16384,即使超过也以16384为准;
增加max_connections参数的值,不会占用太多系统资源。系统资源(CPU、内存)的占用主要取决于查询的密度、效率等;
该参数设置过小的最明显特征是出现”
Too many connections
”错误;
MySQL比较理想的最大连接数计算方式为:max_used_connections / max_connections*100% ≈ 85%
最大连接数占上限连接数的85%左右,如果发现比例在10%以下,MySQL服务器连接数上限设置的过高了。
调整max_connections参数的值
方式一:实时(临时)修改此参数的值
使用root用户登录。
set global max_connections=1000;
修改完成后实时生效,无需重启MySQL。
方式二:在配置文件my.ini中设置max_connections的值
找到max_connections一行,修改为(如果没有,则自己添加)1000
2、max_used_connections 查看最大连接数
show global status like 'Max_used_connections';
Variable_name | Value |
---|---|
Max_used_connections | 258 |
Max_used_connections_time | 2025-3-5 17:45:11 |
这两个状态说的是MYSQL自上次启动起来 最大连接数量和发生的时间。
3、max_user_connections 每个MySQL用户的最大连接数
查看全局每个用户最大连接数max_user_connections
-- 查看max_user_connections 默认值(每个用户最大连接数)
show variables like 'max_user_connections';
-- 或者
select @@max_user_connections;
Variable_name | Value |
---|---|
max_user_connections | 0 |
默认情况值为 0。代表:不限制用户资源的。
设置全局每个用户最大连接数max_user_connections
-- 设置max_user_connections
set global max_user_connections=1;
-- 或
set @@global.max_user_connections=1;
该设置为 实时(临时)修改,在服务器重启后失效,想一直保存的话就放在配置文件里面。
设置后,用该用户重新开一个连接。会出现以下错误提示:意思是这个用户已经达到最大的连接数,不能再连接拥有资源!
针对某个用户进行最大连接数限制
max_user_connections 该参数只能对整体限制资源,不能对某个用户进行限制,如果需要对某个用户限制的话,你可以在权限表里面看到
- max_questions: 0
- max_updates: 0
- max_connections: 0
- max_user_connections: 0
这几个参数可以对某个用户进行限制。
4、mysql服务器的线程数
查看mysql的线程情况
show global status like 'Thread%';
Variable | Value |
---|---|
Threads_cached | 12 |
Threads_ connected | 379 |
Threads_created | 16725 |
Threads_running | 10 |
参数说明:
-
Treads_cached
:表示是缓冲池中的线程个数。 -
Threads_connected
:表示当前连接的线程数。跟show processlist
结果相同。 -
Threads_created
:表示创建过的线程数,如果发现Threads_created
值过大的话,表明MySQL服务器一直在创建线程,这是比较耗资源,可以适当增加配置文件中thread_cache_size值。 -
Threads_running
:这个数值指的是激活的连接数,这个数值一般远低于Threads_connected
数值。准确的来说Threads_running
当前并发数。
thread_cache_size缓存线程 优化
thread_cache_size
:当客户端断开之后,服务器处理此客户的线程将会缓存起来以响应下一个客户,而不是销毁(前提是缓存数未达上限)。
即可以重新利用保存在缓存中线程的数量,当断开连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,如果有很多新的线程,增加这个值可以改善系统性能。
查询thread_cache_size
-- 查询服务器 thread_cache_size 配置
show variables like 'thread_cache_size';
设置线程缓存数量 thread_cache_size
如果是短连接,适当设置大一点,因为短连接往往需要不停创建,不停销毁,如果大一点,连接线程都处于取用状态,不需要重新创建和销毁,所以对性能肯定是比较大的提升。
对于长连接,不能保证连接的稳定性,所以设置这参数还是有一定必要,可能连接池的问题,会导致连接数据库的不稳定性,也会出现频繁的创建和销毁,但这个情况比较少,如果是长连接,可以设置成小一点,一般在50-100左右。
物理内存设置规则:通过比较Connections 和 Threads_created 状态的变量,可以看到这个变量的作用。
方式1:实时(临时)设置,重启后失效
-- 设置 线程缓存数量
set global thread_cache_size=100;
方式2:配置文件修改
thread_concurrency = 100
评论区