linux操作系统之进程组及会话

(1)进程组(作业):代表一个或多个进程的集合。

          1)父进程创建子进程时,默认子进程与父进程属于同一进程组,进程组id==第一个进程id(组长id,父进程id)

          2)使用kill -SIGKILL -进程组id(负数)  将整个进程组杀死。

          3)只有进程组中还有进程存在,进程组就一直存在,与组长进程是否终止无关。

          4)进程组生存周期为进程组中最后一个进程存活时间。

          5)一个进程可以为自己或子进程设置进程组id(setpgid)

(2)进程组操作函数

         1)获取当前进程的进程组id:getpgrp

                     pid_t  getpgrp(void);           //返回调用者的进程组ID

         2)获取指定进程的进程组id:getpgid

                    pid_t  getpgid(pid_t pid);   //成功返回0,失败返回-1

                         pid=0时,该函数效果和getpgrp作用相同

        3)改变进程组默认所属进程组:setpgid(通常用来加入一个现有的进程组或创建一个新进程组)

                   int  setpgid(pid_t pid ,pid_t pgid);  成功:0 失败:-1

                      功能:将pid加入到pgid中

              注意事项:1>如果想要把子进程设置为新的组,应把setpgid放在fork函数之后,exec函数(执行完后不返回了)之前。

                                        2>改变进程组只有在符合自己权限的情况下才能改变。

(3)会话:一个或多个进程组的集合

          1)创建会话

                  1>创建会话的进程不能使进程组的组长,如果是组长进程,则会出错

                  2>创建会话的进程会成为新进程组的组长进程

                  3>一般linux需要root权限(ubuntu不需要)

                  4>新会话会舍弃原有的控制终端,该会话没有控制终端

                  5>建立新会话的顺序,先调用fork,父进程终止,子进程调用setsid函数创建会话,称为进程组组长和会话的会长。

          2)会话操作函数

                1>获取进程组所属会话id:getsid

                      pid_t getsid(pid_t pid)  成功:返回调用进程的会话id  失败:-1

                           pid=0    查看当前进程的会话id

                   ps ajx   参数j代表与控制作业相关的信息,参数a代表所有用户的进程,参数x代表所有控制终端和无控制终端的进程。

               2>创建一个新会话,并将自己的id设置为进程组id和新会话id:setsid

                    pid_t setsid(void)  成功:返回调用进程的会话id  失败:-1

                         

        3)会话的作用:创建守护(daemon精灵)进程

               1>守护进程的定义:linux后台服务进程,通常独立与控制终端并且周期性地执行某种任务或等待处理某些发生的事情,一般采用以d结尾的名字。

               2>守护进程的特点:没有控制终端,不能直接和用户交互,不受用户登录、注销的影响,一直运行着。

               3>创建守护进程的流程:

                                   1》创建子进程,父进程退出,所有工作都在子进程中进行形式上体力子控制终端。

                                   2》在子进程中创建新会话(setsid函数),使子进程完全独立出来,脱离控制。

                                   3》改变当前目录为根目录(chdir函数),防止占用可卸载的文件系统(如挂载在/mnt下的U盘中的程序,就属于可卸载)

                                   4》重设文件权限掩码(umask函数),防止继承的文件创建某些屏蔽字拒绝某些权限,增加守护进程的灵活性。

                                  5》关闭文件描述符,继续的打开文件(0/1/2)不会用到,浪费系统资源,无法卸载,可以重定向到/dev/null文件下。 

                                   6》开始执行守护进程核心工作,守护进程退出处理程序模型。

          4>创建守护进程例子

                    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382320.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux操作系统之线程同步及互斥量

(1)线程同步 1)线程同步:指一个线程发出某一个功能运行时,在运行还没有结束的时候,该调用不返回。同时其它线程为保证数据的一致性,不能调用该功能。 2)多个控制流共同操作一个共享资…

linux操作系统之读写锁

(1)读写锁:只有一把锁,但是有两种状态(读,写) 1)读写锁的三种状态:读锁,写锁,不加锁 2)读写锁特性(12字)&…

linux操作系统之条件变量

(1)条件变量 条件变量本身不是锁,但它可以造成线程阻塞,通常与互斥锁配合使用。 (2)条件锁相关函数 pthread_cond_t类型,用于定义条件变量 1)初始化一个条件变量:pthrea…

linux操作系统之信号量、互斥量在进程间的同步、文件锁

(1)信号量:进化版的互斥量 多个线程间对某个对象的部分数据进行共享,使用互斥锁是没有办法实现的,只能将整个数据对象锁住。这样虽然达到了多线程操作数据共享的目的,却导致线程并发性下降。 信号量&#x…

linux网络编程之网络应用设计模式、分层模型、通信过程

(1)网络协议 可以理解为规则,其中包含着数据传输和数据的解释。 典型的协议:传输层:tcp/udp协议,应用层:http/ftp协议,网络层:ip协议,网路接口:ar…

linux网络编程之通信协议格式

好文参考:《网路传输的三张表:MAC地址表,ARP缓存表和路由表》http://www.cnblogs.com/clovn/p/4911212.html (1)数据包封装 传输层及其一下的机制由内核决定,主要负责通讯的具体细节;应用层由用…

linux网络编程之Socket编程

(1)socket套接字 1)在linux环境下,socket用于表示进程间网络通信的特殊文件类型,其本质是内核借助缓冲区形成的伪文件(不占磁盘空间,除此之外还有二进制文件,管道,字符文…

Linux操作系统之简易实现server/client

1.首先将出错处理封装成函数,具体封装思想:是在底层函数的基础上将首字母大写(方便在编程中查找函数文件的manpage,而不需要使用命令,直接用shiftk),然后调用底层库函数并考虑出错处理,具体函数如下&#x…

linux网络编程之TCP三次握手和四次挥手

1.在TCP连接的过程中,有三个阶段,分别是建立连接,传递数据和断开连接,通讯时序图如下所示: 2.结合TCP数据报格式分析建立连接的三次握手 1)首先客户端发送一个带有SYN标志的TCP报文给服务器端,询问服务器端…

linux网路编程之多进程并发服务器

1)使用多进程并发服务器考虑的因素: (1)父进程描述最大文件描述符的个数(父进程需要关闭accept返回的新文件描述符) (2)系统内可创建进程的个数(与内存大小相关&#xff…

linux网路编程之多线程并发服务器

1)在使用进程模型开发服务器过程中考虑以下问题 (1)调整进程内最大文件描述符上限 (2)线程如有共享,考虑线程同步 (3)客户端线程退出时,做退出处理(线程分离&…

linux网路编程之TCP状态转换及端口复用

(1)TCP状态转换图 其中图中分为三种状态:实线代表的主动发起连接,虚线代表的被动发起连接,细实线代表的可以双向发起连接的状态。 主动发起连接方状态变化:1)主动发起连接的一方发送SYN标志位&…

linux网络编程之多路I/o转接服务器select

(1)多路IO转接服务器也叫做多任务IO服务器,其主要思想是不再由程序自己监听客户端连接,取而代之的是由内核替应用程序监视文件,具体实现模型如图所示: 当客户端请求和服务器连接时,内核接收到连接指令,告诉…

linux网络编程之多路I/O转接服务器poll函数

&#xff08;1&#xff09;poll函数 头文件&#xff1a;#include<poll.h> int poll(struct pollfd*fds, nfds_t nfds,int timeout); struct pollffd{ int fd;//文件描述符 short events;//监控的事件 short revents;//监控事件中满足条件返回的事情 }&#xff1…

《C++ Primer 第五版》第二章(1-4小节)------基本内置类型,初始化和赋值及声明和定义,指针和引用,const和constexpr

C Primer第二章的内容主要介绍了变量和基础类型&#xff0c;包括C语言定义的基础内置类型、变量的定义及声明、符合类型如指针及引用的介绍和const及常量表达式constexpr的介绍&#xff0c;本次博客也从这四个方面进行系统的介绍&#xff0c;如果有不足之处&#xff0c;还望其他…

793. 阶乘函数后K个零 golang

Me(AC 33 / 44 个通过测试用例) func preimageSizeFZF(K int) int {count : 0for i : 0; i < 1000000; i {if trailingZeroes(i) K {count}}fmt.Println(count)//fmt.Println(trailingZeroes(25))return count}func trailingZeroes(n int) int {if n 0 {return 0}return …

小程序radio单选框回显

话不多说&#xff0c;效果图如下&#xff1a; 具体代码如下&#xff1a; <radio-group name"radio" bindchange"getSex"><label><radio value"1" checked"{{xingbie1}}" />男</label><label><radio…

《C++ Primer 第五版》(第4.11节类型转换) ————关于无符号数和有符号数的运算探究

1.关于无符号数和有符号数的运算 关于无符号数和有符号数的运算&#xff0c;在我看来一直是觉得只要有无符号数和有符号数的运算&#xff0c;有符号数就转化为无符号数&#xff0c;但是在《C Primer 第五版》的p142介绍&#xff0c;关于无符号数和有符号数的运算如下规定的&…

543. 二叉树的直径 golang

文章目录543. 二叉树的直径example正确解法question代码&#xff08;wrong)543. 二叉树的直径 概要: 借鉴了这个题的代码。可是有一个测试用例过不去 https://blog.csdn.net/csdn_kou/article/details/104122067 example 给定一棵二叉树&#xff0c;你需要计算它的直径长度。一…

《C++ Primer 第五版》(第4.11-4.12节)——static_cast,const_cast和reinterpret_cast类型转换, 运算符优先级表

1.static_cast,const_cast和reinterpret_cast类型转换 static_cast:强制的类型转换(不能用于底层的const转换),以前C语言中的强制类型转换都可以使用static_cast来完成。如&#xff1a;int i3; double jstatic_cast<double>(i); const_cast&#xff1a;改变底层const(指针…