1)非常关键(处理143秒)
1335 0.000037 write(16,"5line from strace1335 0.000328 socket(PF_LOCAL,SOCK_STREAM,0) = 16pIDof MysqLd15393lsof -p 15393MysqLd 15393 MysqL 12u IPv4 26913133 0t0 TCP *:MysqL (ListEN)1335 0.000040 poll([{fd=14,events=PolliN}],1,5000) = 0 (Timeout)1335 5.005295 gettimeofday({1403675502,686212},NulL) = 0INSERT INTO `br_anonymous_user_tokens` (`dtExpires`,`nmToken`,`dtCreated`) VALUES ('2014-08-25','46e35dc39a41e836b806f48d21621b066ea182a9','2014-06-25')",161) = 1611335 0.000111 read(16,"\t42\n",16384) = 131335 143.588134 gettimeofday({1403675497,653337},NulL) = 0
文件描述符#16似乎是MysqL socket:
和这里
所以似乎Apache正在等待MysqL执行写入前一行的套接字的查询.我对吗?这是否意味着我需要理解为什么MysqL执行简单查询需要这么长时间?
2)很长
在这里,我尝试找到文件描述符#14,以找出超时的来源.我使用了here所描述的技术,但没有一个显示出有问题的描述符.如何找出超时的来源?
解决方法 问题得到解决.我查看了information_schema MysqL数据库中的PROCESSList表,发现一些表被锁定状态等待表级锁定.然后我搜索并发现锁定的一个原因可能是MysqLdump备份 – 这正是我最近配置的.但由于工作配置错误,它每分钟都会不停地锁定MysqL.现在备份配置正确,服务器工作正常.但民意调查的第二个问题仍未得到解决.
总结以上是内存溢出为你收集整理的linux – strace显示从mysql socket读取很长时间 – mysql需要很长时间才能执行查询?全部内容,希望文章能够帮你解决linux – strace显示从mysql socket读取很长时间 – mysql需要很长时间才能执行查询?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)