Linux操作系统调优相关工具(四)查看Network运行状态 和系统整体运行状态

简介: Linux操作系统调优相关工具(四)查看Network运行状态 和系统整体运行状态

一、使用nload监控总体带宽使用情况

1.1安装nload

[root@120 ~]# yum install epel-release -y  

[root@120 ~]# yum install nload -y

二、开始监控

[root@120 ~]# nload   #开始监控

然后另一个终端上运行ab,开始测试:

[root@120 ~]# ab -n 1000 -c 2 http://www.baidu.com/index.html  #产生一些测试数据

三、使用nethogs找出使用带宽最多的进程

nethogs是一款小巧的"net top"工具,可以显示每个进程所使用的带宽,并对列表排序,将耗用带宽最多的进程排在最上面。3.1上传到nethogs到linux上:

[root@120 ~]# yum install  epel-release  nethogs -y

[root@120 ~]# nethogs    就可以看到

3.2在另一个终端生成一些数据:下载个文件

 四、 查看系统整体运行状态

4.1  使用vmstat查看内存及系统整体运行状态
vmstat  :命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,MEM内存使用,VMSwap虚拟内存交换情况,IO读写情况。
使用vmstat可以看到整个机器的CPU,内存,IO的使用情况,而不是单单看到各个进程的CPU使用率和内存使用率。  比top命令节省资源。
注:当机器运行比较慢时,建议大家使用vmstat查看运行状态,不需要使用top,因top使用资源比较多。
例:[root@120 ~]# vmstat

每一列参数作用:

r 运行状态的进程个数 。展示了正在执行和等待cpu资源的任务个数。当这个值超过了cpu个数,就会出现cpu瓶颈。

b 不可中断睡眠 正在进行i/o等待--阻塞状态的进程个数  进程读取外设上的数据,等待时

free   剩余内存,单位是KB

buffers #内存从磁盘读出的内容

cached #内存需要写入磁盘的内容

si  swapin   swap换入到内存

so swapout  内存换出到swap   换出的越多,内存越不够用

bi  blockin 从硬盘往内存读。 单位是块。   把磁盘中的数据读入内存

bo blockout 从内存拿出到硬盘 (周期性的有值) 写到硬盘

#判断是读多还是写多,是否有i/o瓶颈

in 系统的中断次数,cpu调度的次数多

cs 每秒的上下文切换速度  

CPU上下文切换--程序在运行的时候,CPU对每个程序切换的过程。

us 用户CPU时间

sy 系统CPU时间,如果太高,表示系统调用时间长,例如是IO操作频繁。

id  空闲 CPU时间,一般来说,id + us + sy = 100,一般我认为id是空闲CPU使用率,us是用户CPU使用率sy是系统CPU使用率。

wt  等待IO CPU时间。

st:Steal time  虚拟 CPU 等待实际 CPU 的时间的百分比

 

4.2  使用sar命令记录系统一段时间的运行状态

安装sar命令

[root@120 ~]# yum -y install sysstat

sysstat 工具包可以把检查到的信息保存下来,存在/var/log/sa目录下。 sar 默认显示每10分钟统计一次状态信息(从装sysstat包开始)

sar 命令行的常用格式: sar [options] [-A] [-o file] t [n]

在命令行中,n 和t 两个参数组合起来定义采样间隔和次数,t为采样间隔,是必须有的参数,n为采样次数,是可选的,默认值是1,-o file表示将命令结果以二进制格式存放在文件中,file 在此处不是关键字,是文件名。options 为命令行选项,sar命令的选项很多,

下面只列出常用选项:

-A:所有报告的总和。

-n:网络接口的情况。

-u:CPU利用率

-v:进程、I节点、文件和锁表状态。

-d:硬盘使用报告。

-r:没有使用的内存页面和硬盘块。

-g:串口I/O的情况。

-b:缓冲区使用情况。

-a:文件读写情况。

-c:系统调用情况。

-R:进程的活动情况。

-y:终端设备活动情况。

-w:系统交换活动。

-o 文件名:打印到屏幕并将采样结果以二进制形式存入当前目录下的文件中。

-f 文件名:查看之前保存的二进制文件。

-d 显示磁盘

-d 1 100 必须得指定次数

-c 每秒创建进程的个数

-i 1 10 指定时间间隔

-P 查看cpu

-r 查看内存

-w 每秒上下文切换次数

-o /cpu.sar 保存并显示

-f cpu.sar 读取

例1:每2秒采样一次,连续采样5次,观察CPU 的使用情况,并将采样结果以二进制形式存入当前目录下的文件cpu.sar中

[root@120 ~]# sar -u 2 5 -o cpu.sar  #屏幕显示以一下内容,同时内容也会写到当前目录的./cpu.sar中

[root@120 ~]#  sar -u 2 5 -o cpu.sar

在显示内容包括:

%usr:CPU处在用户模式下的时间百分比。

%sys:CPU处在系统模式下的时间百分比。

%iow:CPU等待输入输出完成时间的百分比。

%idle:CPU空闲时间百分比。

在所有的显示中,我们应主要注意%iow和%idle,%iow的值过高,表示硬盘存在I/O瓶颈,%idle值高,表示CPU较空闲,如果%idle值高但系统响应慢时,有可能是CPU等待分配内存,此时应加大内存容量。%idle值如果持续低于10,那么系统的CPU处理能力相对较低,表明系统中最需要解决的资源是CPU。

例:查看二进制文件cpu.sar中的内容
[root@120 ~]# sar -u -f cpu.sar
注:sar命令即可以实时采样,又可以对以往的采样结果进行查询。

4.3  查看sar 的计划任务并读取日志:
1、查看sar 的计划任务
[root@120 ~]# cat  /etc/cron.d/sysstat

2、读取日志

[root@120 ~]# ls /var/log/sa   #只要安装sar后就会定期收集系统信息

sa15  sa19

使用参数-n查看网络接口流量情况

[root@120 ~]# sar -n DEV -f  /var/log/sa/sa04  #查看网络相关信息

3、查看内存和硬盘

[root@120 ~]#  sar -r -f  /var/log/sa/sa15  

-r 查看内存

[root@120 ~]#  sar -d -f  /var/log/sa/sa15  

-d:硬盘使用报告。

4、sar最大特点是可以监控所有状态,sar的其他使用方法如下:

sar -r 1       #查看内存

sar -n ALL    #查看所有

sar -b 1 10    #缓冲区使用情况,每秒刷新一次,查看10次

sar -I ALL 1 10

sar -r -f /tmp/file      -n    -r   -b   -m

sar -s 15:00:00 -e 15:30:00  #查看某个时间段,系统运行情况

sar -s 15:00:00 -e 15:30:20 -f /var/log/sa/sa01

sar -r -s 15:00:00 -e 15:30:20 -f /var/log/sa/sa01

 

还有个工具 netstat   查看网络连接数。

实战:查看恶意访问服务器次数最多的IP地址并封掉

通过:netstat  查看网络连接数。如果一个IP地址对服务器建立很多连接数(比如一分钟产生了100个连接),就认为发生了DDOS

netstat -ntu | awk '{print $5}' | cut -d: -f4 | sort | uniq -c | sort -n
注释:
netstat -ntu | awk '{print $5}' | cut -d: -f4    | sort | uniq -c | sort -n
            
              截取外网IP和端口     截取外网的IP以:为分隔符  |排序 | 排除相同的记录  | 排序并统计

 

以上就是总结的linu调优思路和常用的调优工具。

总结

  • 系统调优4大子系统
  • 实战1:找出系统中使用CPU最多的进程   top  -》 P 或  ps -axu --sort -pcpu
  • 实战2:找出系统中使用内存最多的进程  top -》 M   或  ps -axu --sort -rss
  • 实战3:找出系统中对磁盘读写最多的进程 iostat  和 iotop
  • 实战4:找出系统中使用网络最多的进程  nload , iptraf ,nethogs
目录
相关文章
|
3月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
303 0
|
3月前
|
Unix 物联网 Linux
都什么年代了,你还不懂啥是Linux操作系统
至于华为鸿蒙操作系统是不是独树一帜,这个留给各位阅读本文的网友们来讨论
111 0
|
3月前
|
安全 Linux iOS开发
linux属于什么操作系统
Linux是一种自由和开放源代码的操作系统,具有高度的灵活性和可定制性。与常见的操作系统如Windows和macOS相比,Linux具有自由、安全和稳定等优势。Linux已广泛应用于服务器、桌面电脑、超级计算机和嵌入式设备等领域,并且在未来的发展前景广阔。由于其自由和开放源代码的特性,Linux还促进了计算机技术和社区的发展,为全球的计算机用户提供了更多的选择和可能性。
|
3月前
|
安全 Ubuntu Unix
关于Linux操作系统,你必须要知道的事
我们可以看到无论是Debian还是Buildroot都有各自的特点,为客户提供了更大的选择空间和灵活性,大家可以根据自己的需求选择合适的版本来满足终端用户的体验和功能需求。从平技术将会一直关注更多更安全、灵敏、易于开发的Linux版本,做好适配工作,不断为客户带来“简单开发、方便应用”的使用体验。
|
3月前
|
安全 Ubuntu Linux
如何安装Linux操作系统?
此时,您可以选择重新启动计算机,然后从硬盘上的Linux系统启动。以上是一个大致的安装过程。请注意,不同的Linux发行版可能会在细节上有所差异,因此在进行安装之前,请确保您阅读并理解了相应发行版的安装指南或文档。
|
2月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
420 2
二、Linux文本处理与文件操作核心命令
|
2月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
290 137
|
2月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
676 57
|
1月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
401 2
|
2月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
274 0
Linux内存问题排查命令详解