linux 查看mysql运行时间_linux – strace显示从mysql socket读取很长时间 – mysql需要很长时间才能执行查询?...

我的Apache服务器需要很长时间来处理请求.我附上了strace,可以看到以下两个延迟:

1)非常关键(处理143秒)

1335 0.000037 write(16, "\235\0\0\0\3INSERT INTO `br_anonymous_user_tokens` (`dtExpires`, `nmToken`, `dtCreated`) VALUES ('2014-08-25', '46e35dc39a41e836b806f48d21621b066ea182a9', '2014-06-25')", 161) = 161

1335 0.000111 read(16, "\t\0\0\1\0\1\374\262\n\2\0\0\0", 16384) = 13

1335 143.588134 gettimeofday({1403675497, 653337}, NULL) = 0

文件描述符#16似乎是mysql socket:

line from strace

1335 0.000328 socket(PF_LOCAL, SOCK_STREAM, 0) = 16

和这里

pidof mysqld

15393

lsof -p 15393

mysqld 15393 mysql 12u IPv4 26913133 0t0 TCP *:mysql (LISTEN)

所以似乎Apache正在等待mysql执行写入前一行的套接字的查询.我对吗?这是否意味着我需要理解为什么MySQL执行简单查询需要这么长时间?

2)很长

1335 0.000040 poll([{fd=14, events=POLLIN}], 1, 5000) = 0 (Timeout)

1335 5.005295 gettimeofday({1403675502, 686212}, NULL) = 0

在这里,我尝试找到文件描述符#14,以找出超时的来源.我使用了here所描述的技术,但没有一个显示出有问题的描述符.如何找出超时的来源?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值