linux/unix的proc系列[/proc/partitions]

下面分别给出IDE硬盘和SCSI硬盘的信息,IDE 硬盘在Linux一般表示为hd* ,比如hda、hdb … … , SCSI 和SATA 硬

盘在Linux通常也是表示为sd

[root@localhost /]# cat /proc/partitions
major minor #blocks name
3 0 120060864 hda
3 1 10241406 hda1
3 2 40957717 hda2
3 3 14338012 hda3
3 4 1 hda4
3 5 40957686 hda5
3 6 13558828 hda6

另一台计算机

[work@localhost ~]$ cat /proc/partitions
major minor #blocks name
8 0 71833096 sda
8 1 20482843 sda1
8 2 1959930 sda2
8 3 1 sda3
8 5 49383778 sda5
8 16 71833096 sdb
8 17 8193118 sdb1
8 18 2048287 sdb2
8 19 1 sdb3
8 21 39070048 sdb5
8 22 22515066 sdb6
8 32 71833096 sdc
8 33 48837568 sdc1
8 34 22989015 sdc2
8 48 71833096 sdd
8 49 71826583 sdd1
[work@localhost ~]$

就对上表
第二行解释
参数 解释
major 主设备号。3 代表 hda
minor 次设备号。0 代表 第7 分区
#blocks 设备总块数 (1024 bytes/block)。120060864*1024 => 122942324736(bytes) ~122.9GB
Name 设备名称
<think>嗯,用户现在想让我详细介绍一下/proc文件系统。之前他们在使用monitor.sh脚本时遇到了mpstat和free命令的问题,我建议他们通过安装sysstat和procps-ng来解决,但同时也提到了使用/proc文件系统作为替代方案,可能兼容性更好。现在用户可能想深入了解/proc,特别是如何在脚本中利用它来获取系统信息,而避免依赖外部命令。 首先,我需要回忆/proc的基本概念。它是一个虚拟文件系统,提供内核和进程信息的接口。在Linux中,/proc下的文件和目录不是真实的磁盘文件,而是动态生成的数据,反映系统实时状态。但用户是在MSYS2环境下,MSYS2模拟了部分Linux特性,所以/proc是否存在呢?可能部分存在,比如/proc/meminfo和/proc/stat,但可能不如完整Linux系统全面。需要确认这一点,否则用户可能会遇到信息不全的问题。 接下来,用户可能需要知道如何通过读取/proc中的文件来替代mpstat和free命令。比如,之前提到的替代方案中,get_cpu函数使用top命令,而get_mem函数直接读取/proc/meminfo。但用户可能更希望直接通过/proc来获取CPU使用率,而不是依赖top,这样减少外部依赖。 我需要详细说明/proc下哪些文件有用,比如/proc/stat包含CPU统计信息,/proc/meminfo包含内存信息,/proc/diskstats或/proc/partitions可能包含磁盘信息。然后举例如何解析这些文件,比如从/proc/stat计算CPU使用率,或者从/proc/meminfo获取内存总量和可用量。 另外,需要注意在MSYS2环境中,/proc可能提供的文件是否完整。例如,某些信息可能不可用,或者路径不同。可能需要建议用户检查是否存在这些文件,或者是否有其他替代路径。 用户可能还需要了解/proc文件系统的其他用途,比如查看进程信息(/proc/PID/),或者调整内核参数(/proc/sys/)。但当前场景主要是监控脚本,所以应重点介绍与系统资源监控相关的部分。 此外,需要提醒用户,处理/proc中的文件时要注意格式,因为这些文件的结构可能随着内核版本变化,或者在MSYS2中有不同的呈现方式。解析时应确保兼容性,比如使用awk或grep来提取特定字段。 最后,可能需要给出具体的示例代码,展示如何修改监控脚本,使用/proc替代mpstat和free,并验证在MSYS2中的可行性。同时,指出可能的限制,比如某些指标无法获取,或者需要其他处理方式。</think>━━━━━━━━━━━━━━━━━━━━ /proc 文件系统深度解析 ━━━━━━━━━━━━━━━━━━━━ /proc 是类Unix系统中特殊的虚拟文件系统(在Windows的MSYS2/Cygwin环境中为模拟实现),它作为内核与用户空间的通信接口,提供动态访问系统内核数据的能力。以下是其核心特性及应用场景: ▨ 本质特征 ├─ 虚拟性:不占用磁盘空间,数据存储在内存中 ├─ 实时性:内容动态生成,反映系统即时状态 ├─ 层次结构:以文件/目录形式组织系统信息 └─ 只读/可写:部分文件支持写入调整内核参数 ▨ 核心目录结构 ```bash /proc ├─ [PID] # 每个进程独立目录(MSYS2中可能受限) │ ├─ cmdline # 进程启动命令 │ ├─ status # 进程状态信息 │ └─ fd/ # 打开文件描述符 ├─ cpuinfo # CPU规格信息 ├─ meminfo # 内存使用详情 ├─ stat # 全局CPU统计 ├─ diskstats # 磁盘I/O统计 └─ sys/ # 内核参数调整接口 ``` ━━━━━━━━━━━━━━━━━━━━ 监控脚本关键数据获取 ━━━━━━━━━━━━━━━━━━━━ 1. CPU使用率计算(替代mpstat) ```bash function get_cpu_usage() { read -r cpu user nice system idle iowait irq softirq steal guest < <(awk '/^cpu /{print $0}' /proc/stat) total=$((user + nice + system + idle + iowait + irq + softirq + steal + guest)) idle_total=$((idle + iowait)) echo "scale=2; 100 * ($total - $idle_total) / $total" | bc } ``` 2. 内存使用率计算(替代free) ```bash function get_mem_usage() { mem_total=$(awk '/MemTotal/ {print $2}' /proc/meminfo) mem_avail=$(awk '/MemAvailable/ {print $2}' /proc/meminfo) echo "scale=2; 100 * ($mem_total - $mem_avail) / $mem_total" | bc } ``` ━━━━━━━━━━━━━━━━━━━━ MSYS2环境特殊注意事项 ━━━━━━━━━━━━━━━━━━━━ 1. 可用性差异 ├─ 完整进程树受限:`/proc/[PID]`信息不完整 ├─ 硬件信息过滤:部分敏感硬件数据被屏蔽 └─ 统计粒度调整:某些统计项合并处理 2. 兼容性验证方法 ```bash # 检查关键文件存在性 ls -l /proc/{cpuinfo,meminfo,stat} # 验证数据可读性 head -n5 /proc/meminfo | grep -E 'MemTotal|MemAvailable' ``` ━━━━━━━━━━━━━━━━━━━━ 高级应用场景 ━━━━━━━━━━━━━━━━━━━━ 1. 实时监控单个进程 ```bash pid=$(pgrep -f your_process) cat /proc/$pid/status | grep -E 'VmRSS|Threads' # 内存占用/线程数 ``` 2. 调整内核参数(需管理员权限) ```bash # 临时修改最大进程数 echo 120000 > /proc/sys/kernel/pid_max # 查看当前值 sysctl kernel.pid_max ``` 3. 硬件拓扑分析 ```bash cat /proc/cpuinfo | grep 'model name' # CPU型号 ls /proc/acpi/ # 电源管理信息 ``` ━━━━━━━━━━━━━━━━━━━━ 性能监控对比 ━━━━━━━━━━━━━━━━━━━━ | 指标 | /proc方案优势 | 传统命令方案劣势 | |------------|------------------------------|-------------------------| | CPU使用率 | 无额外依赖,精度高 | 需安装sysstat包 | | 内存统计 | 直接获取原始数据 | free显示单位固定 | | 扩展性 | 自由组合需要的数据 | 输出格式受限 | | 系统负载 | 可自定义负载算法 | 依赖特定命令输出 | 建议在MSYS2环境中优先使用/proc方案,但需注意:Windows子系统对某些统计项(如精确的I/O等待时间)的支持可能与原生Linux存在差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值