首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux系统进程编程之回收进程(三)

“僵尸进程”是一个早已死亡的进程,而且“僵尸子进程”已经放弃了几乎所有的内存空间,没有任何可执行代码,也不能被调度,但在进程表(processs table)中仍占了一个位置(slot),记载该进程的退出状态信息供其他进程收集...但是由于进程表的容量是有限的,所以,僵尸进程还是占用一定系统的内存资源,影响系统的性能,而且如果其数目太多,还会导致系统瘫痪(举一个非常不恰当的例子,这就好比一部丧尸电影,里面的正常人,因为得了某种病毒...那么说了这么多,我们该怎么样来回收Linux系统的僵尸进程呢?...来,让我们下面细说: 一、第一招:使用wait()函数来回收: 1、我们先来看这个函数的原型和它所包含的头文件(在Linux系统下,使用man 手册来查看它的具体用法:man 2 wait):...,回收同时还可以得知被回收进程的(ID和退出状态)。

3.3K20

linux进程内存布局

BSS段属于静态内存分配。 数据段:在采用段式内存管理的架构中,数据段(data segment)通常是指用来存放程序中已初始化的全局变量的一块内存区域。数据段属于静态内存分配。...代码段:在采用段式内存管理的架构中,代码段(text segment)通常是指用来存放程序执行代码的一块内存区域。这部分区域的大小在程序运行前就已经确定,并且内存区域属于只读。...堆(heap):堆是用于存放进程运行中被动态分配的内存段,它的大小并不固定,可动态扩张或缩减。...当进程调用malloc等函数分配内存时,新分配的内存就被动态添加到堆上(堆被扩张);当利用free等函数释放内存时,被释放的内存从堆中被剔除(堆被缩减) 栈 (stack):栈又称堆栈, 是用户存放程序临时创建的局部变量...除此以外,在函数被调用时,其参数也会被压入发起调用的进程栈中,并且待到调用结束后,函数的返回值也会被存放回栈中。由于栈的先进先出特点,所以 栈特别方便用来保存/恢复调用现场。

3.1K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux内存回收和交换

    Linux内存管理是一套非常复杂的系统,而swap只是其中一个很小的处理逻辑。希望本文能让读者了解Linux对swap的使用大概是什么样子。...这两种内存回收的触发路径不同,一个是由内核进程kswapd直接调用内存回收的逻辑进行内存回收(参见mm/vmscan.c中的kswapd()主逻辑),另一个是内存申请的时候进入slow path的内存申请逻辑进行回收...那么kswapd进程在周期检查的时候触发回收的条件是什么呢?还是从设计角度来看,kswapd进程要周期对内存进行检测,达到一定阈值的时候开始进行内存回收。...但是会增加节点之间的隔离性,其他节点的相关进程运行将不会因为另一个节点上的内存回收导致性能下降。...kswapd进程什么时候开始内存回收?kswapd根据内存水位标记决定是否开始回收内存,如果标记达到low就开始回收回收到剩余内存达到high标记为止。 如何查看当前系统的内存水位标记?

    4.7K52

    Linux进程控制】五、wait()函数——子进程回收

    僵尸进程与孤儿进程 孤儿进程:父进程结束,子进程被init进程收养。 僵尸进程:子进程结束,父进程没有回收进程的资源(PCB),这个资源必须要由父进程回收,否则就形成僵尸进程。...2. wait()函数与waitpid()函数 2.1 wait()函数 一个进程在终止的时候会关闭所有的文件描述符,释放在用户空间分配的内存,但是它的PID还保留着,内核在其中保存了一些信息:如果进程是正常终止则保存进程退出状态...回收一个组的子进程,使用时把组ID(一般是父进程ID)传给pid参数,就可以使用waitpid()回收这个进程组的所有子进程。...回收所有,任何子进程,这是最常用的取值,把所有子进程回收。...回收多个子进程 上面使用wait()函数和waitpid()函数举的例子都是回收一个子进程,有时候我们可能需要回收多个子进程,下面介绍回收多个子进程的方法。

    7610

    图解 | Linux内存回收之LRU算法

    如下图所示: 但内存资源是有限的,随着系统中运行的进程越来越多,系统中可用的内存就会越来越少。那么,当可用内存不足时,Linux 内核是怎么处理的呢?...本文将会介绍,当可用内存不足时,Linux 内核的处理方式。 一、内存不足的处理方式 我们思考一下,当系统的可用内存不足时,进程继续申请内存会发生什么事情?...当系统的可用内存不足时,内核为了保证进程有足够的内存可用,将会对内存进行回收工作。...下面主要介绍当系统内存不足时,内核是怎样将进程的 匿名内存页 写入到 交换分区 中,并且回收这些 匿名内存页 的。 1....LRU算法状态流转 我们最后以一张状态流转图来描述 LRU 算法的过程: 三、总结 本文主要介绍了 Linux 内核内存回收过程中使用的 LRU 算法的原理,在下一篇文章中,我们将会介绍 Linux

    3.3K20

    Linux进程内存管理

    mm_struct结构描述了一个进程的整个虚拟地址空间,vm_area_truct描述了虚拟地址空间的一个区间(简称虚拟区)。...下图就是我们所说的由task_struct到mm_struct,进程的地址空间的分布。 ? 每一个进程都会有自己独立的mm_struct,这样每一个进程都会有自己独立的地址空间,这样才能互不干扰。...当进程之间的地址空间被共享的时候,我们可以理解为这个时候是多个进程使用一份地址空间,这就是线程。...arg_start,结束arg_end,环境段的开始env_start,结束env_end unsigned long saved_auxv[AT_VECTOR_SIZE]; struct linux_binfmt...vm_area_struct 数据结构来管理,包括虚拟内存的起始和结束地址,以及内存的访问权限等,通常命名为vma;vm_area_struct 数据结构的定义如下: ?

    3.3K21

    Linux进程通信--共享内存

    概述 共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间,这些进程间数据传递不再涉及到内核,换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据。...本地通信方案:system V IPC: 共享内存 消息队列 信号量 共享内存基本原理 每一个进程有自己的地址空间,经过页表转化,找到物理内存,由于进程具有独立性,每个进程有自己的代码和数据,内核数据结构独立...如何实现共享内存呢? 假设目前有两个进程进程A和进程B。...我们将这种用地址空间进行映射让进程A和进程B可以看到同一段共享内存,称之为共享内存。 上述操作都是操作系统来完成,操作系统可以提供上述的系统调用,让进程A和进程B进行调用。...此时如果进程C、进程D、进程E、进程F等进程也需要通信,但是不使用进程进程B的共享内存,因此共享内存在系统中可以同时存在多份,让不同个数、不同进程进行通信。

    9810

    聊聊Linux内核的内存回收上篇

    内核对所有用户态进程消耗的RAW内存总量不做严格的约束,当系统负载相对较低的时候,内存大部分被磁盘高速缓存使用,随着系统负载增大,系统进程使用的内存越来越多,磁盘的高速缓存占用的内存就会被缩小,内存页帧的回收必须在消耗所有空闲页帧之前进行...如果内核尝试回收后仍然无法获得物理页帧,内核会执行find_bad_process找到一个进程并且执行OOM Kill释放这个进程占用的物理页帧。...slab分配器在频繁申请和释放的情况下效率比较高 基于LRU页帧链表 内存页帧是有映射的,映射到一个或者多个进程的虚拟空间。内核一般用内存页帧的引用次数来表示页帧的活跃程度。...页帧回收会按照几个原则来进行内存页帧的回收,第一是回收高速磁盘缓存的页帧;第二回收睡眠时间较长的进程中的页帧;第三是回收共享页帧的引用全部清除;第四回收LRU链表中未使用的 页帧回收的过程页分为直接回收和定期回收...定期回收则是内核的守护进程定期发起,尽量回收,保留足够的空闲空间。

    1.8K30

    内存回收

    前言: 前文《内存映射技术分析》描述了虚拟内存的管理、内存映射;《物理内存管理》介绍了物理内存管理。 本篇介绍一下内存回收内存回收应该是整个Linux内存管理上最难理解的部分了。...系统中内存实在回收不到的时候,最差情况就是OOM,kernel开始杀用户进程(选择杀哪个,是kernel根据很多参数计算出来的)。...对于一个page,首先需要判断它是否可以被 回收,比如说kernel被load进的内存,是不能回收的,用户进程使用mlock来lock住的内存,也是不能回收的。...只是说,如果内存不够了,linux会尝试回收,尽量满足。 回收的时候,如果实在回收不到了,linux会选择最差的策略---杀掉一部分进程。...后记: 虚拟内存的管理,内存映射,物理内存管理,内存回收,差不多就是Linux内存管理的主要功能了。 Good Luck~

    3.3K100

    linux进程进程间通信_linux共享内存进程间通信

    内存共享最新整理: Linux进程间通信-共享内存 – 码到城攻共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式 https://www.codecomeon.com/posts...两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。 进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。...二、相关函数: 与信号量一样,在Linux中也提供了一组函数接口用于使用共享内存,而且使用共享共存的接口还与信号量的非常相似,而且比使用信号量的接口来得简单。...共享内存的权限标志与文件的读写权限一样,举例来说,0644,它表示允许一个进程创建的共享内存内存创建者所拥有的进程向共享内存读取和写入数据,同时其他用户创建的进程只能读取共 享内存。...,已经很好了,我也就不在班门弄斧了: Linux共享内存编程实例_分享美好的专栏-CSDN博客_linux共享内存实例 赐教!

    4.5K30

    Linux进程通信之共享内存

    Linux进程通信之共享存储 概念: 共享内存指 (shared memory)在多处理器的计算机系统中,可以被不同中央处理器(CPU)访问的大容量内存。...共享内存是 Unix下的多进程之间的通信方法 ,这种方法通常用于一个程序的多进程间通信,实际上多个程序间也可以通过共享内存来传递信息。...PHP中的封装: php中封装了shm开头的函数和shmop开头的函数,实际效果是一样的,具体使用方式请查看官方手册 ,下面我们以shm开头的为例演示 特点: 共享内存是将内存映射到其他进程的地址空间中...,所以说共享内存也是最快的IPC进程通信方式 前提: 在使用IPC进程通信时,也就是信号量、消息队列、共享存储时,首先要先确定自己的PHP扩展是否已经开启,使用php -m 查看 编写代码 父子进程...fprintf(STDOUT,"recv data=%s\n",$data); exit(0); } //写入数据 shm_put_var($shmId,1,'test'); //回收进程

    4.8K31

    Linux进程内存分析pmap命令

    名称:        pmap - report memory map of a process(查看进程内存映像信息)pmap命令用于报告进程内存映射关系,是Linux调试及运维一个很好的工具。...映像支持文件,[anon]为已分配内存 [stack]为程序堆栈         Offset:  offset into the file  文件偏移         Device:  device...,也就是该进程预先分配的虚拟内存大小,即ps出的vsz writeable/private  表示进程所占用的私有地址空间大小,也就是该进程实际使用的内存大小       shared 表示进程和其他进程共享的内存大小...查看进程1的设备格式,不显示头尾行 [root@C44 ~]#  pmap -d -q 1 1:   init [5]                     00934000     ...00000   [ stack ] ffffe000       4 ----- 0000000000000000 000:00000   [ anon ] [root@C44 ~]#   查看进程

    4K10

    Linux进程间通信【共享内存

    V 标准,所以 System V 中的消息队列、信号量绝大部分接口的风格也与之差不多 2.1、共享内存的数据结构 共享内存不止用于两个进程间通信,所以共享内存必须确保能持续存在,这也就意味着共享内存的生命周期不随进程...,实际中会使用函数进行自动释放,因为手动释放比较麻烦 2.4、进程关联 shmat 共享内存在被成功创建后,进程还不 “认识” 它,只有让待通信进程都 “认识” 同一个共享内存后,才能进行正常通信,让进程...id 参数2 const void *shmaddr 共享内存关联至进程共享区的地址,可以不用管 参数3 int shmflg 关联后,进程对共享内存的读写属性 当进程与共享内存关联后,返回的就是共享内存映射至共享区的起始地址...: 进程 A 直接将数据写入共享内存进程 B 直接从共享内存中读取数据 显然,使用共享内存只需要经过 2 次 IO 所以共享内存的秘籍是 减少拷贝(IO)次数 得益于共享内存的这种特性,可以让进程通信的时候...》 ---- 总结 以上就是本次关于 Linux 进程间通信之 共享内存 的全部内容了,共享内存 是所有 IPC 中最快的一种,因为它省去了很多不必要的 IO 操作,进程直接对话进程,效率极高,不过在狂飙的后果就是不安全

    32600

    Linux进程内存消耗指标解读

    了解系统的内存消耗是运维最基本的技能,但是Linux中关于内存消耗的指标很容易让人混淆,本文尝试把诸多概念解释清楚 概念 物理内存和虚拟内存 物理内存:不解释 虚拟内存进程独享,由操作系统通过地址映射的方式...在32位Linux机器上,每个进程的虚拟内存都是4G。...(这里的虚拟内存与操作系统使用中过程常见的虚拟内存概念不同,不要混淆了,如Linux中swap) 内存耗用指标 VSS – Virtual Set Size 虚拟耗用内存(包含共享库占用的内存) RSS...(进程地址空间),包括数据、代码、堆、共享库、内存映射文件等,可以使用pmap命令查看详情。...Linux 查看进程消耗内存情况总结 Java 进程占用 VIRT 虚拟内存超高的问题 Virtual Memory Usage from Java under Linux, too much memory

    6K40
    领券