使用iftop分析容器网络流量
由于最近工作上配合压测,在采集性能指标的时候需要对某个业务容器进行流量分析,目的是区分该服务模块与其他模块交互的具体网络流量构成。我第一个想法就是使用iftop配合查看系统连接的方式进行分析,顺便把过程整理成这个知识手册。
安装
centos7 epel-release源里边直接yum安装即可;编译安装的情况,我的下载地址是iftop-1.0pre4,依赖gcc,和libpcap,选择一种适合的方式安装即可。
使用
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 filter code。例子(统计端口是8001-8003,IP是10.72.2.22/23/24的流量):iftop -NnP -f "portrange 8001-8003 and (host 10.72.2.22 or host 10.72.2.23 or host 10.72.2.24)"。还有很多参数,对流量分析有很大帮助,详细语法见filter code。
-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退出监控。
容器流量分析
在worker node安装上述过程安装iftop。
进入容器的网络名称空间
nsenter -n -t`docker inspect --format {{.State.Pid}} 7eda30670285
基于业务关系和netstat显示的连接,通过iftop根据不同的IP端口进行分析即可。
浙公网安备 33010602011771号