linux主机监控工具

Posted on Posted in 监控
Tips: 本文创建于2015年5月20日,已超过 2 年,内容或图片可能已经失效!

1、iftop

效果图

iftop

相关参数

界面上面显示的是类似刻度尺的刻度范围,为显示流量图形的长条作标尺用的。

中间的<= =>这两个左右箭头,表示的是流量的方向。

TX:发送流量
RX:接收流量
TOTAL:总流量
Cumm:运行iftop到目前时间的总流量
peak:流量峰值
rates:分别表示过去 2s 10s 40s 的平均流量
常用的参数
-i设定监测的网卡,如:# iftop -i eth1

-B 以bytes为单位显示流量(默认是bits),如:# iftop -B

-n使host信息默认直接都显示IP,如:# iftop -n

-N使端口信息默认直接都显示端口号,如: # iftop -N

-F显示特定网段的进出流量,如# iftop -F 10.10.1.0/24或# iftop -F 10.10.1.0/255.255.255.0

-h(display this message),帮助,显示参数信息

-p使用这个参数后,中间的列表显示的本地主机信息,出现了本机以外的IP信息;

-b使流量图形条默认就显示;

-f这个暂时还不太会用,过滤计算包用的;

-P使host信息及端口信息默认就都显示;

-m设置界面最上边的刻度的最大值,刻度分五个大段显示,例:# iftop -m 100M
进入iftop画面后的一些操作命令(注意大小写)
按h切换是否显示帮助;

按n切换显示本机的IP或主机名;

按s切换是否显示本机的host信息;

按d切换是否显示远端目标主机的host信息;

按t切换显示格式为2行/1行/只显示发送流量/只显示接收流量;

按N切换显示端口号或端口服务名称;

按S切换是否显示本机的端口信息;

按D切换是否显示远端目标主机的端口信息;

按p切换是否显示端口信息;

按P切换暂停/继续显示;

按b切换是否显示平均流量图形条;

按B切换计算2秒或10秒或40秒内的平均流量;

按T切换是否显示每个连接的总流量;

按l打开屏幕过滤功能,输入要过滤的字符,比如ip,按回车后,屏幕就只显示这个IP相关的流量信息;

按L切换显示画面上边的刻度;刻度不同,流量图形条会有变化;

按j或按k可以向上或向下滚动屏幕显示的连接记录;

按1或2或3可以根据右侧显示的三列流量数据进行排序;

按<根据左边的本机名或IP排序;

按>根据远端目标主机的主机名或IP排序;

按o切换是否固定只显示当前的连接;

按f可以编辑过滤代码,这是翻译过来的说法,我还没用过这个!

按!可以使用shell命令,这个没用过!没搞明白啥命令在这好用呢!

按q退出监控。

2、pktstat

pktstat可以实时显示所有活动连接,并显示哪些数据通过这些活动连接传输的速度。它还可以显示连接类型,比如TCP连接或UDP连接;如果涉及HTTP连接,还会显示关于HTTP请求的详细信息。

效果图

pktstat

sudo pktstat -i eth0 -nt

3、speedometer

效果图

speedometer

speedometer -rx eth0 -c -tx eth0

可以测读写速度

dd if=/dev/zero of=big_nothing bs=102M count=3 &

4、GoAccess

goaccess

最简单、常用的命令就是直接调用goaccess命令啦,不带任何影响效率的其他参数

goaccess -f access.log

打开之后会跳出选择日志文件类型的界面:Nginx日志是属于Combined Log Format (XLF/ELF)类型的,所以我们选择第三个。用上下光标移动,空格选中,回车确定。
如果想重新选择

sudo goaccess -f access.log -c -a

ga
使用GoAccess生成html报告:

  1. goaccess -d -f web.log -a -p /home/user/.goaccessrc > test.html  

生成json报告:

goaccess -f access.log -a -d -o json > report.json

CSV:

goaccess -f access.log -o csv > report.csv

由于nginx会自动压缩日志,一下命令可以直接分析压缩后的日志:

zcat access.log.*.gz | goaccess
#或者
zcat -f access.log* | goaccess

支持各种管道:

sed -n '/11\/Dec\/2014/,$ p' access.log | goaccess -a

sed -n '/05/Dec/2010/,$ p' access.log | goaccess -s -b

分析从11月5号到12月5号一个月内的日志

sed -n ‘/5/Nov/2010/,/5/Dec/2010/ p’ access.log | goaccess -s -b

想分析下百度/google对你网站爬了些啥内容?Easy:

grep -E "(google|baidu)"access.log | goaccess -a

当你不希望在服务器上安装goaccess程序,可以通过调用本地的goaccess程序来分析服务器上的日志(很神奇吧^_^):

ssh user@server ‘cat /var/log/apache2/access.log’ | goaccess -s -a -b

5、iptraf

iptraf

 

6、bmon

bmon

bmon -p eth0

随后 bmon 会显示监控界面,输入 g 打开图形监控栏,输入 d 可以开启详细模式

bmon 不只是这么简单,它还有许多高级用法,其中对个人认为最实用的就是输出为 html 网页文件,

bmon -I distribution:multicast -o null -O html:path=/var/htdocs/

 

» 转载请注明来源:若我若鱼 » linux主机监控工具

Leave a Reply

Your email address will not be published. Required fields are marked *

three + 17 =