13.Linux 高性能服务器编程 --- 多进程编程

1.fork()
	每次调用返回两次,在父进程中返回的是子进程的PID,在子进程中返回的是0.
	fork 函数复制当前进程,在内核进程表中创建一个新的进程表项。
	子进程的代码与父进程完全相同,同时它还会复制父进程的数据(堆,栈,静态数据),采用写时复制。
	只有任一进程(父进程或子进程)对数据进行了写操作时,
	复制才会发送(先是缺页中断,然后操作系统给子进程分配内存并复制父进程的数据)。
	创建子进程后,父进程中打开的文件描述符默认在子进程中也是打开的,且文件描述符的引用技术加1.
	不仅如此,父进程的用户根目录,当前工作目录等变量的引用技术均会加1.

2.exec系统调用
	exec 函数不会关闭原程序打开的文件描述符,除非该文件描述符被设置了类似 SOCK_CLOEXEC 的属性

3.僵尸进程
	  对于多进程而言,父进程一般需要跟踪子进程的退出状态。因此,当子进程结束运行时,内核不会立即释放
	 该进程的进程表项,以满足父进程后续对该子进程退出信息的查询。在子进程结束之后,父进程读取其退出状态之前,
	 我们称该子进程处于僵尸状态。
	  父进程结束或者异常终止,而子进程继续运行。此时子进程的PPID被设置为1,即init进程。init进程接管了该子进程,
	 并等待它结束。在父进程退出之后,子进程退出之前,该子进程处于僵尸态。

4.管道
	管道能在父,子进程间传递数据,利用的是 fork 调用之后两个管道文件描述符(fd[0],fd[1])都保持打开。
	socketpair 全双工管道

5.信号量
	semget();
	semop();
	semctl();

6.共享内存
	是最高效的 IPC 机制,因为它不涉及进程之间的任何数据传输。必须使用其他辅助手段来同步进程对共享内存的访问。
	shmget();
	shmat();
	shmdt();
	shmctl();

	共享内存的 POSIX 方法:
	shm_open();
	shm_unlink();

7.消息队列
	消息队列是在两个进程之间传递二进制块数据的一种简单有效方式。每个数据块都有一个特定的类型。
	msgget();
	msgsnd();
	msgrcv();
	msgctl();

8.IPC 命令

9.在进程间传递文件描述法
	传递一个文件描述符,并不是传递一个文件描述符的值。是需要在接收进程中创建一个新的文件描述符,
	并且该文件描述符和发送进程中被传递的文件描述符指向内核中的文件表项。
	父子进程用 fork();
	不相干的两个进程,unix socket 

 

 

13.1 fork 系统调用

 

13.2 exec 系列系统调用

 

13.3 处理僵尸进程

 

13.4 管道

 

13.5 信号量

 

13.6 共享内存

 

 

 

 

13.7 消息队列

13.8 IPC 命令

 

13.9 在进程间传递文件描述符

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值