声明:如需引用或者摘抄本博文源码或者其文章的,请在显著处注明,来源于本博文/作者,以示尊重劳动成果,助力开源精神。也欢迎大家一起探讨,交流,以共同进步~ 0.0

1.Linux虚拟文件系统

  首先要明白,这到底是干啥的。[以下,引用博文linux 计算内存使用率http://blog.csdn.net/u010807846/article/details/40919393的原话,可以作为参考性理解]

  proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。用户和应用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。由于系统的信息,如进程,是动态改变的,所以用户或应用程序读取proc文件时,proc文件系统是动态从系统内核读出所需信息并提交的采集流程图。

  其访问目录:/proc/*

2.深入概述
  PROC:(/proc)读取proc文件系统,获取系统各种性能参数           
  CPU:
    使用率:/proc/stat 或者 /proc/cpuinfo
      用户模式(user),低优先级用户模式(nice),内核模式(system)和空闲的处理器时间(idle)
    计算方法:
      100*( user + nice + system / user + nice + system + idle)    
      备注:多核情况下某一进程cpu使用率是按cpu个数*100%计算的
    总的cpu时间
      totalCpuTime = user + nice + system + idle + iowait + irq + softirq + stealstolen  +  guest                
    单位:
      jiffies
      jiffies是内核中的一个全局变量,用来记录自系统启动一来产生的节拍数.(C中clock_t和CLOCKS_PER_SEC与此有关)
        在linux中,一个节拍大致可理解为操作系统进程调度的最小时间片,不同linux内核可能值有不同,通常在1ms到10ms之间
      例子:
        user (38082)    从系统启动开始累计到当前时刻,处于用户态的运行时间,不包含 nice值为负进程。
        nice (627)      从系统启动开始累计到当前时刻,nice值为负的进程所占用的CPU时间
        system (27594)  从系统启动开始累计到当前时刻,处于核心态的运行时间
        idle (893908)   从系统启动开始累计到当前时刻,除IO等待时间以外的其它等待时间iowait (12256) 从系统启动开始累计到当前时刻,IO等待时间(since 2.5.41)
        irq (581)           从系统启动开始累计到当前时刻,硬中断时间(since 2.6.0-test4)
        softirq (895)      从系统启动开始累计到当前时刻,软中断时间(since 2.6.0-test4)stealstolen(0)  
  内存:
    使用情况:/proc/meminfo
    当前内存使用量(cmem),内存总量(amem)
    计算方法:100*(cmem / amem)

    详情见博主另一博文:

      Linux之计算内存利用率与辨析 :http://www.cnblogs.com/johnnyzen/p/8011309.html
  网络负载:
    使用情况:/proc/net/dev
    从本机输出的数据包数(output),流入本机的数据包数(input)
    计算方法:(output + input)/2

    详情见博主另一博文:

      Linux之读取计算机网络数据[/proc/net/dev] :http://www.cnblogs.com/johnnyzen/p/8007577.html

      Linux之网络实时检测功能[C编程] :http://www.cnblogs.com/johnnyzen/p/8009053.html
  其他(内核等):
    /proc/sys
      存放所有可读的文件的目录
    /proc/sys/kernel
      包含反通用内核行为的信息
    /proc/sys/net
      修改机器/网络的网络属性
  实例:
    允许IP转发:/proc/sys/net/ipv4/ip_forward
    禁止ping:/proc/sys/net/ipv4/icmp_echo_ignore_all【1:实现配置;0:取消配置】

3.参考文献:

   [操作系统课程设计]:https://max.book118.com/html/2017/0104/79942647.shtm
        [操作系统课程设计报告]:https://wenku.baidu.com/view/1c083c4dc77da26924c5b0c7.html      
        [Linux平台Cpu使用率的计算]:http://www.blogjava.net/fjzag/articles/317773.html
        [Linux系统下输出某进程内存占用信息的c程序实现]:https://www.cnblogs.com/bozhicheng/p/6216667.html
        [关于proc和CPU计算与原理]:https://wenku.baidu.com/view/375b7311f01dc281e53af0c6.html   

[C++]Linux之虚拟文件系统[/proc]中关于CPU/内存/网络/内核等的一些概要性说明的更多相关文章

  1. linux的虚拟文件系统VFS

    虚拟文件系统(virtual file system),别名虚拟文件系统开关,是linux中的一个软件层,向用户空间提供文件系统操作接口. VFS包含的系统调用包括open(2).stat(2).re ...

  2. Linux 的虚拟文件系统(强烈推荐)

    1 引言 Linux 中允许众多不同的文件系统共存,如 ext2, ext3, vfat 等.通过使用同一套文件 I/O 系统 调用即可对 Linux 中的任意文件进行操作而无需考虑其所在的具体文件系 ...

  3. 从文件 I/O 看 Linux 的虚拟文件系统

    1 引言 Linux 中允许众多不同的文件系统共存,如 ext2, ext3, vfat 等.通过使用同一套文件 I/O 系统 调用即可对 Linux 中的任意文件进行操作而无需考虑其所在的具体文件系 ...

  4. Linux -- 如何减少IO过程中的CPU copy

    四种I/O方式的对比 1. Buffered I/O read(file, tmp_buf, len); write(socket, tmp_buf, len); 上下文切换:4次 CPU copy: ...

  5. linux 查看CPU内存 网络 流量 磁盘 IO

    使用vmstat命令来察看系统资源情况 在命令行方式下,如何查看CPU.内存的使用情况,网络流量和磁盘I/O? Q: 在命令行方式下,如何查看CPU.内存的使用情况,网络流量和磁盘I/O? A: 在命 ...

  6. jmeter监控linux cpu 内存 网络 IO

    下载地址:http://jmeter-plugins.org/downloads/all/ PerfMon: 用来监控Server的CPU.I/O.Memory等情况 ServerAgent-2.2. ...

  7. 使用psutil库监控linux的系统资源和自定义进程的cpu 内存占用。

    #coding=utf8 import time import psutil from pprint import pprint from logger_until import LoggerUnti ...

  8. 使用 /proc 文件系统来访问 linux操作系统 内核的内容 && 虚拟文件系统vfs及proc详解

    http://blog.163.com/he_junwei/blog/static/19793764620152743325659/ http://www.01yun.com/other/201304 ...

  9. Linux虚拟文件系统

    从文件 I/O 看 Linux 的虚拟文件系统 1 引言 Linux 中允许众多不同的文件系统共存,如 ext2, ext3, vfat 等.通过使用同一套文件 I/O 系统 调用即可对 Linux ...

随机推荐

  1. LinkedList(JDK1.8)源码分析

    双向循环链表 双向循环链表和双向链表的不同在于,第一个节点的pre指向最后一个节点,最后一个节点的next指向第一个节点,也形成一个"环".而LinkedList就是基于双向循环链 ...

  2. 小R的树(权限题)

    解:考场上爆0了...... 回想怎么求两个排列的最长公共子序列. 回想怎么求1~n每个数恰出现两次的两个序列的最长公共子序列.就是每个数替换为它在另一个序列里的出现位置,降序. 所以我们可以把这每个 ...

  3. Linux批量修改(删除)文件名某些字符(rename命令)

    假设在路径C:/下存在多个类似以下的文件名 file_nall_abc1.txt file_nall_abc2.txt file_nall_abc3.txt file_nall_abc4.txt fi ...

  4. ElasticSearch6.5.0 【script_lang not supported】

    执行代码:[就是想根据条件更新]把品牌为LiNing的都改成Cat. UpdateByQueryRequestBuilder updateByQuery = UpdateByQueryAction.I ...

  5. angularjs的一些问题

    1.如果页面报不支持写法的错,请查看是否引用了跨js定义的常量.逐步排错. 2.后台返回json要导入如下依赖: <dependency> <groupId>net.sf.js ...

  6. springmvc上传图片《2》

    创建springboot项目 编写配置 server: port: 8082 spring: application: name: upload-service servlet: multipart: ...

  7. Kafka技术内幕 读书笔记之(三) 生产者——消费者:高级API和低级API——基础知识

    1. 使用消费组实现消息队列的两种模式 分布式的消息系统Kafka支持多个生产者和多个消费者,生产者可以将消息发布到集群中不同节点的不同分区上:消费者也可以消费集群中多个节点的多个分区上的消息 . 写 ...

  8. Linux记录-HDFS副本机制

    1. 副本策略 NameNode具有RackAware机架感知功能,这个可以配置. 若client为DataNode节点,那存储block时,规则为:副本1,同client的节点上:副本2,不同机架节 ...

  9. 异常来自 HRESULT:0x80070057 (E_INVALIDARG)(转)

    莫名其妙的编译总会报错 异常来自 HRESULT:0x80070057 (E_INVALIDARG) 未能加载程序集....... 几次删除引用然后重新引用程序集还是报错 奔溃中.... 网上搜索还真 ...

  10. linux 内核模块makefile通用模板

    ifneq ($(KERNELRELEASE),)# 在 mylist 后面添加需要编译的模块数量 mylist=hello.o a.o# 为每一个模块添加所需的文件 hello-objs := ma ...