zoukankan      html  css  js  c++  java
  • iftop与dstat-一次网站故障分析经历

    一次网站分析与解决的经历,最后结果虽然很简单但是过程比较曲折.记录一下:
    今天访问网站首页十分缓慢,页面半天都加载不出来.于是上服务器看看情况,通过top看到load和cpu以及磁盘io都很低,只能祭出神器dstat:
    dstat
    查看到流量很大,我们使用的是阿里云的ecs服务器,带宽20m左右,可以看到流量已经达到了带宽上限.
     
    于是马上想到查看nginx服务器日志,但是日志庞大,绝大部分是jpg,js,css等静态资源,很难实际分析到问题.
    接下来去百度搜索,如何查看服务器上的流量分配.很遗憾并没有直接的答案,但是看到一个工具叫iftop,马上apt-get下载之
     
     
    iftop工具可以实时的列出网站当前的流量情况,主要以ip分隔.
    上方的列表=>表示出流量,<=表示入流量.
    底部三行是汇总:
    第一列显示累计的出流量(TX),入流量(RX),总共(TOTAL)
    第二列显示峰值带宽
    最后一列显示平均的统计结果,分别是3s,5s,15s的统计结果,与top命令的load类似吧.
     
    iftop
     
     
    可以看到存在少数ip正在占用大量的带宽,这种情况可以想象到是正在下载大文件了,但是并不知道是什么文件. 但知道方向事情就好办了,还是通过nginx日志,分析其中的一个大流量ip正在干什么...执行
     
    > cat /var/log/nginx/access.log | grep 223.144.191.227 > ~/temp2.log
     
    再来看这个时间点有什么可疑的下载.结果发现一个zip包,这个zip包是我们的app的语音包,有50m以上,估计很有可能是它的问题了!
    执行
    > cat /var/log/nginx/access.log | grep /word_wg_voc.zip |more  部分结果如下:
     
     
     
    可以看到是app的语音包下载出了问题: 链接后面的 200 后面的数字代表的是发送的字节数,而这里很多都不一样,说明是下载不完整. 这也是带宽不足造成的后果...
     
    知道了问题后就ok了,解决办法是:先临时提高带宽,同时配置cdn(因为cdn配置后需要把app重新发一个版本才能用上,有个几天的延迟,iphone app审核你懂得).
     
    顺便打个广告,app叫知米背单词,大家有空可以来学学英语 :) 
  • 相关阅读:
    30个Python常用极简代码,拿走就用
    如果只写一行代码能实现什么?看完我彻底服了
    面试官问我:用了HTTPS就安全了吗?用了HTTPS会被抓包吗?我竟然回答不上来......
    程序员常见的口头禅
    没有心仪的offer,要不要找一个工作先凑合?
    微信新出“拍了拍”功能!
    UVa 340 Master-Mind Hints
    UVa 575 Skew Binary 歪斜二进制
    UVa 10250 The Other Two Trees
    UVa 10106 Product
  • 原文地址:https://www.cnblogs.com/violinn/p/4718620.html
Copyright © 2011-2022 走看看