zoukankan      html  css  js  c++  java
  • android点滴(7) Linux Proc虚拟文件系统—Android CPU、内存、网络流量获取

    Linux  Proc虚拟文件系统—Android CPU、内存、网络流量获取

     

    绿水本无忧,因风皱面;青山原不老,为雪白头。

     

    "proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。用户和应用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。"

     

          这里将介绍如何从/proc文件系统中获取与防火墙相关的一些性能参数,以及如何通过/proc文件系统修改内核的相关配置。

     

    1、从/proc文件系统获取相关的性能参数

    cpu使用率:/proc/stat

    内存使用情况:  /proc/meminfo

    网络负载信息:/proc/net/dev

     

    相应的计算方法:

    1   处理器使用率

    2   内存使用率

    3   流入流出数据包

    4   整体网络负载

     

    这些数据分别要从/proc/stat/proc/net/dev/proc/meminfo三个文件中提取。

     

    (1)     处理器使用率

     

    这里要从/proc/stat中提取四个数据:用户模式(user)、低优先级的用户模式(nice)、内核模式(system)以及空闲的处理器时间(idle)。它们均位于/proc/stat文件的第一行。

     

    这个是通过cat命令获取的AndroidCUP信息。

    以上数据对应的意义为:

    (User)5215 (nice)170 (System)3640 (Idle)5001 (iowait)63 (Irq)5 (sotfirq)18 0 0

     

    CPU利用率   =   100   *user   +   nice   +   system/user   +   nice   +   system   +   idle

    (2)     内存使用率

     

    这里需要从/proc/meminfo文件中提取两个数据,当前内存的使用量(cmem)以及内存总量(amem)

     

          内存使用百分比   =   100   *   (cmem   /   umem)

     

    (3)     网络利用率

     

    为了得到网络利用率的相关数据,需要从/proc/net/dev文件中获得两个数据:从本机输出的数据包数,流入本机的数据包数。它们都位于这个文件的第四行。

     

    性能收集程序开始记录下这两个数据的初始值,以后每次获得这个值后均减去这个初始值即为从集群启动开始从本节点通过的数据包。

     

          利用上述数据计算出网络的平均负载,方法如下:

     

          平均网络负载   =   (输出的数据包+流入的数据包)   /   2

     

    2. 通过/proc文件系统调整相关的内核配置

     

    允许ip转发   /proc/sys/net/ipv4/ip_forward

    禁止ping/proc/sys/net/ipv4/icmp_echo_ignore_all

     

          可以在命令行下直接往上述两个文件里头写入"1"来实现相关配置,如果写入"0"将取消相关配置。不过在系统重启以后,这些配置将恢复默认设置,所以,如果想让这些修改生效,可以把下面的配置直接写入/etc/profile文件,或者其他随系统启动而执行的程序文件中。

     

    1. echo 1 > /proc/sys/net/ipv4/ip_forward  

    2. echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all  

          如果需要获取其他的性能参数,或者需要对内核进行更多的配置,可以参考proc文件系统介绍,也可以直接通过man proc查看相关的信息。

     

                这些也同样适合Android系统,如果要获取Android系统的Cpu、内存、网络的利用情况,就可以通过读取proc文件系统中的文件。

     

    2011/9/29

  • 相关阅读:
    DOM增删改替换
    DRF框架之序列化器serializers组件详解
    DRF基础操作流程
    DRF框架基础知识储备
    selectors模块
    并发编程——IO模型详解
    高性能web服务器——nginx
    Django中的ORM如何通过数据库中的表格信息自动化生成Model 模型类?
    使用cors完成跨域请求处理
    Flask基础
  • 原文地址:https://www.cnblogs.com/cody1988/p/2195717.html
Copyright © 2011-2022 走看看