• Linux系统优化之进程优化


    进程优化实验

    Coding:     

    图1 Coding

    图2 shell输出

     

    图3 进程文件maps输出信息

     

    图4 cat smaps相关内存信息 

    图5 cat statm相关信息显示

    分析:

             /proc 文件系统是一种内核和内核模块用来向进程发送信息的机制(所以叫/proc)。这个伪文件系统让你可以和内核内部数据结构进行交互,获取有关进程的有用信息,在运行中改变设置(通过改变内核参数)。与其他文件系统不同,/proc 存在于内存之中而不是硬盘上。

             /proc 由内核控制,没有承载/proc的设备。因为/proc主要存放由控制的状态信息,所以大部分这些信息的逻辑位置位于内核控制的内存。对/proc进行一个 ‘ls -l’可以看到大部分文件都是0字节大的;但是查看这些文件的时候,确实可以看到一些信息。因为/proc文件系统和其他常规的文件系统一样把自己注册到虚拟文件系统层(VFS)了。然而,知道当VFS调用他,请求文件、目录的i-node的时候,/proc文件根据内核中的信息建立相应的文件和目录。

             如图5所示,很简单地返回7组数字,每一个单位都是一页也就是4KB

             他们分别是:

             Size:任务虚拟地址空间大小

             Resident:应用程序正在使用的物理内存大小

             Shared:共享页数

             Trs:程序所拥有的可执行虚拟内存大小

             Lrs:被映像到任务的虚拟内存空间的库的大小

             Drs:程序数据段和用户态的栈的大小

             dt: 脏页数量

    如图1所示在char *p = (char *)malloc(20),只是分配了虚拟内存,内核不会分配物理页面给进程,在strcpy(p , “123”);进程需要使用这块内存了,内核会产生了一个页故障,从而为系统分配了一个物理页面。

    如图3所示查看进程的maps文件可以看到进程的内存情况stack 也就是函数的栈大小系统固定的分配了84KB的大小,而堆大小132KB。在我们的代码中只申请了20个字节,而系统却为其分配了132KB的虚拟内存。

    (0Xbffd7000 – 0X00110000 ) / (1024)D / (1024)D / (1024)D = 2.998806 约等于 3G的大小。即Linux下执行一个小应用程序,系统就会自动给用户分配最低3G大小的虚拟空间。

    每个进程通过系统调用访问内核,Linux内核空间由系统内的所有进程共享。从进程的角度来看,每个进程拥有4G的虚拟地址空间。其中0~3GB为各个进程的私有用户空间,这个空间对系统中的其他进程是可见的,最高的1G内核空间则为所有进程以及内核所共享。

  • 相关阅读:
    Python Pandas基本操作
    自监督 论文 Self-supervised Visual Feature Learning with Deep Neural Networks
    KDD 论文 Multimodal Attentional Neural Networks for Diagnosis Prediction
    实例分割 论文 Multi-scale Cell Instance Segmentation with Keypoint Graph Based Bounding Boxes
    Torchtext使用教程 文本数据处理
    KDD 论文 Measuring Patient Similarities via a Deep Architecture with Medical Concept Embedding
    Python 进阶知识点
    Python 多进程和多线程
    Memcached服务端以及Memcached API部署
    Linux-Dockerfile指令详解
  • 原文地址:https://www.cnblogs.com/wanghuaijun/p/15885700.html
Copyright © 2020-2023  润新知