linux性能分析(三)查看系统的性能指标

news2025/1/16 14:11:18

一  查看系统的性能指标

这里'简略'的将系统'监控指标'分为:cpu、memory、disk、network、os '五大'类

强调: 这'五类'命令的输出与'/proc'虚目录下的'文件信息'强相关

说明: 后续专门讲解'这五大类'的'系统'命令,尽可能'全面罗列'每个工具的使用'场景'

补充: 有些命令是'综合'命令,刻意查看'多种类型'各种'维度'的指标信息

本系列暂时只考虑'操作系统'的性能指标,'不考虑'相关中间件的性能指标

IAAS 虚拟机 CPU计算密集型、IO密集型、数据密集型 

++++++++++++++++++  "<<性能之巅>>"  ++++++++++++++++++

类比: '人' 和 '系统'

  1、人的组成: 计算机系统的组成

  2、衡量'人'健康状况: 系统各项'指标'

①  性能分析的生命周期

②  CPU

lscpu、top、nproc、cpulimit、mpstat、'/proc/cpuinfo 文件'

lscpu  : 显示CPU '架构' 的有关信息

mpstat :  显示'变化'的CPU数据

③  内存

free、top、htop、atop、vmstat、memstat、ps、'/proc/meminfo 文件'

ps aux --sort -rss

内存相关的'内核'参数 : '/proc/sys/vm/drop_caches'

动态查看CPU和内存的占用率: ps -ef | grep '进程名' --> 获取 'pid' --> top -p $pid

查看内存占用'前10名'的程序: ps aux|sort -k4,4nr|head -n 10 

cat /proc/$pid/status  --> 'VmSize对应的值就是物理内存占用'

linux常用内存相关高级命令    linux下查看某一进程占用的内存 

free -m 各输出说明      free -m 详解    free 各选项参数   腾讯 free -m 面试

buffer 和 cache的区别

④  磁盘

df: 用来显示'磁盘空间'的'使用'和'挂载信息'等情况        --> 常用 'df -hT'

du: 显示'对应'目录下每个'子目录和文件'的'磁盘空间'使用量  --> 常用 'du -sh'

补充: ls -lsh /path/to/file

fdisk、parted 、mkfs、mount、umount  --> '磁盘分区'、'格式化文件系统'、'挂载'、'卸载'

lsblk: 列出所有'可用块设'备的信息,以及他们之间的'依赖'关系

+++++++++++++  "LVM 逻辑卷"  +++++++++++++

pvcreate、vgcreate、lvcreate     --> '物理卷'、'卷组'、'逻辑卷'

pvdisplay、vgdisplay、lvdisplay  --> 查看 'lvm' 状态信息

lvremove、vgremove、pvremove     --> 删除  '逻辑卷'

sync:  强制把'文件系统buff'的内容写入'系统磁盘'

思考: 如何查找'大 [大的标准是什么]'文件?

+++++++++++++  "innode"  +++++++++++++

场景:由于每个文件都必须有一个inode,因此有可能发生'inode已经用光',但是硬盘'还未存满'情况

注意: 避免产生'大量'的小文件,导致把'innode'系统资源耗尽

需求1: 只列出文件的'inode number'   --> stat --format=%i wzj.txt 

需求2: 显示'文件系统inode'的使用信息  --> df -i 分区、'tune2fs -l'、ls -il

sync命令 

+++++++++++++  "磁盘I/O"  +++++++++++++

衡量'磁盘性能'的'基本'指标:利用率、饱和度、IOPS、吞吐量、响应时间

sar:      sar -d -p 1 2   --> 查看当前'磁盘'性能

iostat:   iostat -d -x 1  --> 只提供了观察磁盘的'整体I/O'性能数据

pidstat:  pidstat -d 1    --> 查看'哪些进程'行正在读写磁盘

iotop:    刻意按'I/O'大小对进程进行'排序'

fio:     专门测试 'iops' 的命令,对磁盘进行'压力'测试

dd:       dd 命令只能'大致 [复制原理]'测出磁盘的 IO 性能,不是非常准确

案例: time dd if=/dev/zero of=test.file bs=1G count=2 oflag=direct

vmstat:   vmstat 2 '每2s' -w '宽输出模式' 80 -t '将时间戳附加到每一行' -d '磁盘'

查看系统磁盘I/O的情况     sar命令查看磁盘     磁盘压力测试   vmstat

⑤  网络

++++++++++++++++  "网络配置类"  ++++++++++++++++

1、ip、ifconfig、route、nmcli、hostname、ifdown、ifup、ethtool、netcat、nmtui 图形

++++++++++++++++  "网络测试类"  ++++++++++++++++

2、ping、tcping、traceroute、mtr、curl、wget、nc、telnet、dig、nslookup、nmap、arp

说明: '网络'联通性、'域名'解析、'端口'联通性、'远程'连接

补充: scp、rsync、ssh

++++++++++++++++  "网络抓包类"  ++++++++++++++++

3、tcpdump、wireshark、tshark  

备注: '网络抓包'相关

++++++++++++++++  "网络防火墙规则类"  ++++++++++++++++

4、iptables、ipset

备注: 查看和设置'防火墙'规则

反弹shell:控制端监听在某TCP/UDP端口,被控端发起请求到该端口,并将其命令行的输入输出转到控制端

ipset 和 iptables 配合使用  iptables+dnsmasq+ipset联合使用配置方法

netcat  反弹shell   反弹shell概念

⑥  OS

涉及: '端口'、'进程'、'线程'、'pid'、'TCP状态'、'负载'、'文件描述符'

[1]、netstat、ss  'TCP状态'

   1、netstat -s                      --> '统计信息'

   2、netstat -antlupe | grep '端口'  --> '端口占用'

   3、netstat -n | awk '/^tcp/{++s[$NF]} END { for (a in s) print a, s[a] }'

[2]、pid '相关' 信息

   ps、lsof、pstree、pidof、pidstat

   场景: df -hT 发现'删除了',但是'lsof'查看实际还'占用'

[3]、负载

   uptime、top、w

[4]、流量

   vnstat、iftop

[5]、'调试' 追踪

   strace、gdb、perf

[6]、'java' 相关

  jps、jstack、jmap、jhat、pstack

遗留: '软和硬'中断和'网络、磁盘 I/O等待'、上下文切换

awk 统计 scoekt 状态分析      conntrack 连接跟踪   conntrack为什么会崩溃

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1111441.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智能水印相机微信小程序源码

相信大家日常在生活中或者工作中都有使用过水印相机来拍照记录吧&#xff0c;但是又要在手机上面多下载一个APP。 那么小编今天给大家带来一款智能水印相机&#xff0c;拍照自动添加时间、地点、经纬度等水印文字&#xff0c;可用于工作考勤、学习打卡、工作取证等&#xff0c…

深度学习 | Pytorch深度学习实践 (Chapter 1~9)

一、overview 基于pytorch的深度学习的四个步骤基本如下&#xff1a; 二、线性模型 - Linear Model 基本概念 数据集分为测试集和训练集&#xff08;训练集、开发集&#xff09;训练集&#xff08;x&#xff0c;y&#xff09;测试集只给&#xff08;x&#xff09;过拟合&#…

世界国家/地区行驶方向数据

Part1数据背景 道路通行方向规则是交通规则的重要部分之一。不同国家及地区通行方向并不一样&#xff0c;受风俗、习惯、风潮因素等影响。 最近也在学道路行驶&#xff0c;结果差强人意&#xff0c;继续努力吧。祝学车的小伙伴们一次过~ Part2数据详情 今天分享的国家/地区行…

二叉搜索树的详解及Map和Set的介绍

目录 1.二叉搜索树 1.1二叉搜索树的介绍 1.2.二叉搜索树的实现 1.2.1二叉搜索树的创建 1.2.2查找关键字 1.2.3插入 1.2.4删除 1.3二叉搜索树的性能分析 2.Map Map官方文档 2.1Map 的常用方法说明 2.2关于Map.Entry的说明,> 2.3注意事项 2.4reeMap和HashMap的区别 …

Django小白开发指南

文章目录 HTTP协议socket实现一个web服务器WSGI实现一个web服务器WSGI实现支持多URL的web服务器WSGI实现图片显示的web服务器MVC && MTV1.MVC2.MTV3.总结 一、创建Django项目1.创建项目2.创建app3.第一次django 请求 二、模板1.配置settings.py2.模板语法3.继承模板 三…

[云原生1.]Docker数据管理与Cgroups资源控制管理

文章目录 1. Docker的数据管理1.1 数据卷1.1.1 示例 1.2 数据卷容器 2. 容器互联3. Cgroups资源控制管理3.1 简介3.2 cgroups的主要功能3.3 cpu时间片的简单介绍3.4 对CPU使用的限制3.4.1 对CPU使用的限制&#xff08;基于单个容器&#xff09;3.4.2 对CPU使用的限制&#xff0…

MySQL高可用架构学习

MHA&#xff08;Master HA&#xff09;是一款开源的由Perl语言开发的MySQL高可用架构方案。它为MySQL 主从复制架构提供了 automating master failover 功能。MHA在监控到 master 节点故障时&#xff0c;会提升其中拥有最新数据的 slave 节点成为新的 master 节点&#xff0c;在…

基于Java的农资采购销售管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09; 代码参考数据库参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&am…

(转)STR 内核做了什么

参考这篇文章&#xff1a; Linux电源管理(6)_Generic PM之Suspend功能 写的很清晰

了解SUI质押和发行计划

SUI是Sui链上的原生资产&#xff0c;总供应量100亿个&#xff0c;并非所有SUI token在一开始就完全流通。相反&#xff0c;随着Sui生态的发展&#xff0c;新token将逐步解锁以奖励生态的早期支持者。质押补贴用于支持网络当前的运营&#xff0c;并由Sui基金会分发给Sui的构建者…

<C++> 模拟实现string

目录 前言 一、模拟实现string 1. 成员变量 2. 构造函数 2.1 构造函数 2.2 重载默认构造 2.3 合并 3. 析构函数 4. 拷贝构造函数 5. c_str 6. size 7. operator[ ] 7.1 普通版 7.2 const版本 8. 迭代器—iterator 8.1 普通版iterator 8.2 const版本iterator 9. 尾插 10. …

数学笔记——直角坐标方程转参数方程

目录 背景第一步&#xff0c;原式转换成参数方程第二步&#xff0c;将参数方程绕x轴旋转一周结果程序与图形注 背景 学习matlab三维作图时遇到的一道题&#xff0c;搞不懂为什么要将直角方程转换成参数方程&#xff0c;在经过多次直角作图失败后&#xff0c;还是决定老老实实学…

Redis入门到实战(四、原理篇)RESP协议

目录 2、Redis内存回收-过期key处理3、Redis内存回收-内存淘汰策略 Redis是一个CS架构的软件&#xff0c;通信一般分两步&#xff08;不包括pipeline和PubSub&#xff09;&#xff1a; 客户端&#xff08;client&#xff09;向服务端&#xff08;server&#xff09;发送一条命令…

【LeetCode-数组】-- 寻找数组的中心索引

寻找数组的中心索引 class Solution {public int pivotIndex(int[] nums) {int n nums.length,sum 0;for(int i 0;i<n;i){ //计算所有元素之和sumnums[i];}int sum_l 0; //统计左边元素之和for(int i 0;i<n;i){sum - nums[i];if(sum_l sum){return i;}sum_l nums…

Django中ORM框架的各个操作

我们会好奇&#xff0c;python这么简洁的语言&#xff0c;数据查询是如何做的呢&#xff1f;我将进一步详细和深入地介绍Django中ORM框架的各个方面&#xff0c;包括MySQL的增删改查和复杂查询。让我们分步骤进行。 ORM框架介绍 Django的ORM框架是一个用于与数据库进行交互的工…

基于java的校园论坛系统,ssm+jsp,Mysql数据库,前台用户+后台管理,完美运行,有一万多字论文

目录 演示视频 基本介绍 论文目录 功能架构 系统截图 演示视频 基本介绍 基于java的校园论坛系统&#xff0c;Mysql数据库&#xff0c;系统整体采用ssmjsp设计&#xff0c;前台用户后台管理&#xff0c;完美运行&#xff0c;有一万多字论文。 用户功能&#xff1a; 1.系统…

分类预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入分类预测

分类预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入分类预测 目录 分类预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入分类预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现基于GRU-AdaBoost门控循环单元结…

【四:httpclient的使用】

目录 1、Demo案例2、请求一个带cookies的get请求3、请求一个带cookies的post请求案例一&#xff0c;案例二的properties的配置 1、Demo案例 public class MyHttpClient {Testpublic void test1() throws IOException {//用来存放我们的结果String result;HttpGet get new Htt…

小黑子—Maven基础

Maven基础 一 小黑子的Maven学习1. Mavn的介绍2. Maven基础概念2.1 仓库2.2 坐标2.3 仓库配置 3. 手动写一个maven项目3.1 Maven项目构建命令3.2 插件创建工程 4. IDEA下的maven项目5. 依赖管理5.1 依赖配置5.2 依赖传递5.3 可选依赖&#xff08;不透明&#xff09;5.4 排除依赖…

【AI视野·今日Sound 声学论文速览 第二十七期】Tue, 17 Oct 2023

AI视野今日CS.Sound 声学论文速览 Tue, 17 Oct 2023 Totally 15 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Sound Papers LocSelect: Target Speaker Localization with an Auditory Selective Hearing Mechanism Authors Yu Chen, Xinyuan Qian, Zexu Pan, Ka…