视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL服务器进程CPU占用100%解决办法
2020-11-09 09:51:52 责编:小采
文档

现在使用mysql数据库服务器的朋友有很多,我们也经常会碰到mysql进程CPU占用100%,下面我来总结一些解决方法。

解决方法一,修改my.cnf文件

找到

query_cache_size =0

估计就是这个问题在造成的,没有开查询缓存

(一般1G 就M缓存)

我的服务器的内存4G,

调整到

代码如下
query_cache_size =256M

如果你系统需要大的临时缓存我们可以再找到

代码如下

tmp_table_size

修改 My.ini, 将 tmp_table_size 赋值到 200M 这个大小大家可自行调整。

系统 占用cpu 100% 问题处理

原因分析

部署的应用每30秒与master report一次;每次report,都新建一个到mysql的连接,处理完之后,再关闭mysql连接,
但是在mysql连接关闭之后,tcp资源并没有释放,在2-3分钟内还是会处于TIME_WAIT状态。
在高IO操作时,会造成对mysq请求的堆积,新建大批的mysql连接,然后再关闭,所以就会有超多TIME_WAIT的tcp连接。
最终导致新来的mysql连接,没有tcp资源可以用,最后mysql connect fail

可能的解决方案:

1. 更改应用连接的方式,更改为每个线程对应一个mysql长连接。(变短连接为长连接)
2. 改变mysql所用磁盘,使得与应用不部署在同一台物理机上,或者使用的磁盘。
3. 更改项:innodb_flush_log_at_trx_commit = 2

下载本文
显示全文
专题