| 您的当前位置:首页 --> MYSQL教程 --> MySQL thread_stack连接线程的优化 |
| MYSQL教程 MySQL thread_stack连接线程的优化 |
| 浏览次数:1269 关键词 ( ) |
| 查看使用该CPU的产品 查看CPU天梯 |
| CPU型号:MySQL thread_stack连接线程的优化 |
| 主频:Ghz |
| 睿频:Ghz |
| 核心数:个 |
| 不支持超核心 |
| 制作工艺: |
| 插槽类型: |
| 功耗:0W |
| L3缓存:0MB |
| 支持最大内存: 0GB |
| CPU详细参数 |
|
MySQL连接不仅能通过网络方式,还可以通过命名管道的方式,不论是哪种方式连接MySQL,在MySQL中都是通过线程的方式管理所有客户端请求的。每一个客户端连接都会有一个与之对应的连接线程。在MySQL中实现了一个Thread Cache池,将空闲的连接线程存放其中,而不是完成请求后就销毁。这样,当有新的连接请求时,MySQL首先会检查Thread Cache中是否存在空闲连接线程,如果存在则取出来直接使用,如果没有空闲连接线程,才创建新的连接线程。具体参数: mysql> show variables like 'thread%'; 如图,系统设置了Thread Cache池最多将缓存25个连接线程,每个连接线程创建之初,系统分配192KB的内存堆栈给它。 mysql> show status like 'connections'; mysql> show status like '%thread%'; 系统启动到现在共接受到客户端的连接620次,共创建了7个连接线程,当前有1个连接线程处于和客户端连接的状态,而3个连接状态的线程中只有一个处于 active 状态,即只有一个正在处理客户端提交的请求,。而在Thread Cache池中共缓存了3个连接线程。 实际应用: 针对16G/32G的机器,一般设置 512K 当然如果遇到下面的错误提示就应该考虑增加这个值了。 mysql-debug: Thread stack overrun bug info 报错信息: 官方相应信息: The default (192KB) is large enough for normal operation. If the thread stack size is too small, it limits the complexity of the SQL statements that the server can handle, the recursion depth of stored procedures, and other memory-consuming actions 可以使用
查询当前数据库的默认线程栈的大小,一般情况下都能正常使用,但是当查询语句或者存储过程复杂时会报Thread stack overrun错误,此时只要修改默认配置就可以。 解决 windows: 修改mysql安装目录下的my-small.ini或者my.ini设置为256k,或者更大,然后重启服务 [mysqld] [mysqld] |
| 下一个产品 SQL计算timestamp的差值的方法 上一个产品 CentOS下RPM方式安装MySQL5.6教程 |