×

僵死进程 进程 僵尸进程

Linux里面什么是僵尸进程?进程间通信方式有哪些各自有哪些优缺点

admin admin 发表于2022-05-08 11:57:15 浏览140 评论0

抢沙发发表评论

Linux里面什么是僵尸进程

一个已经终止,但是其父进程尚未对其进行善后处理(获取终止子进程的有关信息、释放它仍占用的资源)的进程被称为僵死进程(Zombie Process)。

相关处理办法:

在Linux中可以用  ps auwx  发现僵尸进程

a all w/ tty,including other users 所有窗口和终端,包括其他用户的进程

u user-oriented 面向用户(用户友好)

-w,w wide output 宽格式输出

x processes w/o controlling ttys  在僵尸进程后面 会标注

ps axf  看进程树,以树形方式现实进程列表

ps axm  会把线程列出来,在linux下进程和线程是统一的,是轻量级进程的两种方式。

ps axu  显示进程的详细状态

===========================================

killall  kill -15  kill -9  一般都不能杀掉 defunct进程

用了kill -15,kill -9以后 之后反而会多出更多的僵尸进程

kill -kill pid  fuser -k pid  可以考虑杀死他的parent process,

kill -9 他的parent process

参见:网页链接

进程间通信方式有哪些各自有哪些优缺点

您好,进程间通信方式有管道、信号量、信号、消息队列、共享内存、套接字六种。(1)管道分为有名管道和无名管道,其中无名管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用,一般用于两个不同进程之间的通信。有名管道也是一种半双工的通信方式,但它允许无亲缘关系进程间的通信。(2)信号量是一个计数器,可以用来控制多个线程对共享资源的访问,它不是用于交换大批数据,而用于多线程之间的同步。他常作为一种锁机制。因此,主要作为进程间以及同一个进程内不同线程之间的同步手段。(3)信号是一种比较复杂的通信方式,用于通知接收进程某个时间已经发生。(4)消息队列是消息的链表,存放在内核中并由消息队列标识符标识,消息队列克服了信号传递信息少,管道只能承载无格式字节流以及缓冲区大小受限等特点。(5)共享内存就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。他往往与其他通信机制,如信号量配合使用,来实现进程间的同步和通信。(6)套接字可用于不同及其间的进程通信。

线程和进程的区别

根本区别:进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位在开销方面:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。