找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1750|回复: 0
打印 上一主题 下一主题

php include类文件超时问题处理

[复制链接]

2487

主题

2487

帖子

7391

积分

论坛元老

Rank: 8Rank: 8

积分
7391
跳转到指定楼层
楼主
发表于 2018-2-14 05:49:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            最近发现,php运行自动加载类函数时总是超时,跟踪php慢查询日志,发现程序卡在了include某个类文件时竟然超时。
    初步定位是io响应超时,硬盘读取有问题。
    通过几个命令来定位:
    iostat -d -x -k 1 10 // 运行10次查看iostat中wait参数很大,一般不超过5ms,await  svctm这2个参数越接近,io性能越好。
    参考别的博客,
await:  每一个IO请求的处理的平均时间(单位是微秒毫秒)。这里可以理解为IO的响应时间,一般地系统IO响应时间应该低于5ms,如果大于10ms就比较大了。
         这个时间包括了队列时间和服务时间,也就是说,一般情况下,await大于svctm,它们的差值越小,则说明队列时间越短,反之差值越大,队列时间越长,说明系统出了问题。svctm    表示平均每次设备I/O操作的服务时间(以毫秒为单位)。如果svctm的值与await很接近,表示几乎没有I/O等待,磁盘性能很好,如果await的值远高于svctm的值,则表示I/O队列等待太长,         系统上运行的应用程序将变慢。
    sudo iotop -o , // 查看在划硬盘的程序,查看进程io占用比例
    sudo perf top // 查看进程io占用比例
    sudo hdparm -t /dev/**** 查看磁盘读取效率
    显示: Timing buffered disk reads:   10 MB in  3.14 seconds =   3.18 MB/sec
    查看非中断睡眠
    while true; do date; ps auxf | awk '{if($8=="D") print $0;}'; sleep 1; done
通过上述命令跟踪后,硬盘读取效率很低,进一步原因,还不得而知,猜想可能是硬盘有坏道。
            
            
您可能感兴趣的文章:
  • PHP访问MySQL查询超时处理的方法
  • PHP中几种常见的超时处理全面总结
  • 深入php函数file_get_contents超时处理的方法详解
  • 处理(php-cgi.exe - FastCGI 进程超过了配置的请求超时时限)的问题
  • PHP file_get_contents设置超时处理方法
  • php页面函数设置超时限制的方法
  • PHP中捕获超时事件的方法实例
  • php设置页面超时时间解决方法
  • PHP函数超时处理方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端