转载请注明出处:http://blog.csdn.net/cywosp/article/details/38968011

1. 概述

众所周知,进程(process)是一个可运行程序的实例,可是在Linux中进程能够又一次改写为。进程是由内核定义的抽象的实体,并为该实体分配用以运行程序的各项系统资源。

从内核的角度看。进程由用户内存空间(user-space memory)和一系列内核数据结构组成。当中用户内存空间包括了程序代码及代码所使用的变量,而内核数据结构则用于维护进程状态信息。

记录在内核数据结构中的信息包括很多与进程相关的标识号(IDs)、虚拟内存表、打开文件的描写叙述符表、信号传递及处理的有关信息、进程资源使用及限制、当前工作文件夹及大量其它信息。


2. 进程描写叙述符
    每个进程都有一个进程号(PID),进程号是一个正数,用以唯一标识系统中的某个进程。

对各种系统调用而言,进程号有时能够作为传入參数,有时能够作为返回值。比方。系统调用kill(()同意调用者向拥有特定进程号的进程发送一个信号。当须要创建一个对某进程而言唯一标识符时。进程号就会派上用场。常见的样例是将进程号作为与进程相关文件名称的一部分(日志文件名称)。

在分布式系统中能够使用ip:port:start_time:pid来区分整个集群中的进程。这样能够全然保证唯一性。也能够在出问题后能高速定位。

    系统调用getpid()返回调用进程的进程号,声明例如以下:
    #include<unistd.h>
    // Always successfully returns process ID of caller
    pid_t getpid(void);

3. 进程描写叙述符的系统限定
    Linux内核限制进程号须要小于等于32767。新进程创建时,内核会按顺序将下一个可用的进程号分配给其使用。每当进程号到达32767的限制时,内核将重置进程号计数器,以便从小整数又一次開始分配。

该分配方式详细例如以下:

    一旦进程号到达32767。内核会将进程号计数器重置为300。而不是1。之所以如此。是由于低数值的进程号为系统进程和守护进程长期占用,在此范围内搜索尚未使用的进程号仅仅会是浪费时间。
    在Linux 2.4版本号及更早版本号中,进程号的上限是32767,由内核常量PID_MAX所定义。在Linux 2.6版本号中。情况有所改变。虽然进程号的默认上限仍是32767。可是能够通过Linux系统特有的/proc/sys/kernel/pid_max文件来进行调整(其值=最大进程+1)。在32位平台中,pid_max文件的最大值为32767,可是在64位平台中。该文件的最大值能够高达2^22次方(约400万),系统可容纳的进程数量会很庞大。

4. 父进程号
    每一个进程都有一个创建自己的父进程。

使用系统调用getppid()能够获取父进程的进程号。该函数声明例如以下:

    #include<unistd.h>
    // Always successfully returns ID of parent of caller
    pid_t getppid(void)
    实际上,每一个进程的父进程号属性反映了系统上全部进程间的树状关系。每一个父进程的父进程又有自己的父进程,以此类推。回溯到1号进程——init进程。即全部进程的始祖。

使用pstree命令能够查看这一树状关系。

    假设子进程的父进程终止了,则子进程会变成“孤儿”,init进程随即将收养该进程,子进程兴许对getppid()的调用将返回进程号1。通过查看由Linux系统所特有的/proc/PID/status文件所提供的PPid字段,能够获知每一个进程的父进程。




每天进步一点点——再次了解Linux进程ID的更多相关文章

  1. Linux进程ID号--Linux进程的管理与调度(三)【转】

    Linux 内核使用 task_struct 数据结构来关联所有与进程有关的数据和结构,Linux 内核所有涉及到进程和程序的所有算法都是围绕该数据结构建立的,是内核中最重要的数据结构之一. 该数据结 ...

  2. Linux进程ID号--Linux进程的管理与调度(三)

    转自:http://blog.csdn.net/gatieme/article/category/6225543 日期 内核版本 架构 作者 GitHub CSDN 2016-05-12 Linux- ...

  3. Linux进程退出详解(do_exit)--Linux进程的管理与调度(十四)

    Linux进程的退出 linux下进程退出的方式 正常退出 从main函数返回return 调用exit 调用_exit 异常退出 调用abort 由信号终止 _exit, exit和_Exit的区别 ...

  4. Linux进程管理与调度-之-目录导航【转】

    转自:http://blog.csdn.net/gatieme/article/details/51456569 版权声明:本文为博主原创文章 && 转载请著名出处 @ http:// ...

  5. Linux 内核进程管理之进程ID

    Linux 内核使用 task_struct 数据结构来关联所有与进程有关的数据和结构,Linux 内核所有涉及到进程和程序的所有算法都是围绕该数据结构建立的,是内核中最重要的数据结构之一.该数据结构 ...

  6. linux 进程管理相关内容

    简介 当我们运行程序时,Linux会为程序创建一个特殊的环境,该环境包含程序运行需要的所有资源,以保证程序能够独立运行,不受其他程序的干扰.这个特殊的环境就称为进程. 每个 Linux 命令都与系统中 ...

  7. Linux进程切换代码分析

    朱宇轲 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 这次我们来分析L ...

  8. linux进程及进程控制

    Linux进程控制   程序是一组可执行的静态指令集,而进程(process)是一个执行中的程序实例.利用分时技术,在Linux操作系统上同时可以运行多个进程.分时技术的基本原理是把CPU的运行时间划 ...

  9. Linux 进程

    Linux 进程 在用户空间,进程是由进程标识符(PID)表示的.从用户的角度来看,一个 PID 是一个数字值,可惟一标识一个进程.一个 PID 在进程的整个生命期间不会更改,但 PID 可以在进程销 ...

随机推荐

  1. c语言实现动态指针数组Dynamic arrays

    c语言实现动态数组.其它c的数据结构实现,hashTable參考点击打开链接 treeStruct參考点击打开链接 基本原理:事先准备好一个固定长度的数组. 假设长度不够的时候.realloc一块区域 ...

  2. [Xcode]some little skill

    Date:2014-1-2 Summary: 自己在使用Xcode的一些小习惯,记录下来,我是这么用的,你呢? Contents:1.使用#warning 在工作中,难免需要做一些test,但是又怕忘 ...

  3. pinyin4j的使用

    pinyin4j的使用   pinyin4j是一个功能强悍的汉语拼音工具包,主要是从汉语获取各种格式和需求的拼音,功能强悍,下面看看如何使用pinyin4j.     import net.sourc ...

  4. 破解phpjm.net加密,解密程序,全部公布

    原文:破解phpjm.net加密,解密程序,全部公布 2014-05-23更新: 很久没人找我解密了,看来这加密已过时,现公布我这边最新的解密工具. 若有解不出的可联系qq: 267014855 (不 ...

  5. CCEditBox/CCEditBoxImplIOS

    #ifndef __CCEditBoxIMPLIOS_H__ #define __CCEditBoxIMPLIOS_H__ #include "cocos2d.h" #if (CC ...

  6. nagios二次开发(五岁以下儿童)---nagios和nagiosql关系

    基于nagios和nagiosql理解.这将是这两个梳理比较粗糙的简单关系,有关详细信息,请参阅下面的图如:      从上面的关系图中能够看出,nagios与nagiosql共享了主机.主机组.服务 ...

  7. undefined reference to `sin&#39;问题解决

    作者:zhanhailiang 日期:2014-10-25 使用gcc编译例如以下代码时报"undefined reference to `sin'": #include < ...

  8. poj 2166 构造

    一个看了解题报告才能想明白的题目,第一点比较容易想明白,就是每次把1交换到堆顶之后如果能够换到最后面的位置那么一定是最优的,但是怎么实现这个没有想明白. 题解的那种构建方法,及从2开始插入,是可以保证 ...

  9. 基于Cocos2dx开发卡牌游戏Demo_放开那三国 2.0

    PS:下载地址在最以下 1.登录 2.副本选择 3.地图 4. 选择敌人 5. 战斗 6. 战斗结算 7. 地图拓展 8. 武将拓展 9. 下载地址: 点击打开链接

  10. hbase基本概念和hbase shell经常使用命令使用方法

    HBase是一个分布式的.面向列的开源数据库,源于google的一篇论文<bigtable:一个结构化数据的分布式存储系统>.HBase是Google Bigtable的开源实现,它利用H ...