LINUX系统编程 由REDIS的持久化机制联想到的子进程退出的相关问题
19:22:01 2014-08-27
引言:
以前对wait waitpid 以及exit这几个函数只是大致上了解,但是看REDIS的AOF和RDB 2种持久化时 均要处理子进程运行完成退出和父进程需要做的什么事情,所以特定看了UNIX环境编程和LINUX系统编程这2本书 重新梳理下整个要点。
内容:
一般而言: 如果程序类似于下面的情况:
if((pid=fork())==0)
{
dochildtthing();
exit(0);
}
else if(pid>0)
{
dofathertthing();
}
子进程就会调用了我们进程退出系统调用exit()分为2种状态 0: 成功 非0:失败
exit需要做以下事情:
1: 关闭所有打开的IO流
2 删除所有的临时文件
1 2是传说中用户态需要完成的事情 接下来就调用_exit() 【这个函数在用户态下 是被exit()封装起来的函数】触发内核来完成进程退出的相关工作
接下来就是清空所有的子进程所需要的资源哦 最后完成了 就会发送一个进程退出状态【信号】给父进程 父进程做什么处理就是编程人员完成的。
子进程发送的信号是SIGCHLD 一般而言就像REDIS fork()了一个进程之后 子进程完成了相应的持久化动作之后,父进程需要了解子进程一些状态来做相应的处理工作,所以在LINUX系统中,这个子进程退出后 还有一个标记位 我们称作zombie进程。父进程必须来取子进程的相应zombie的相应标记信息 不然是不会消除的。
所以对于父进程而言,必须调用相应的函数【首先是注册了SIGCHLD】处理这些标记位哦 wait/waitpid就是干这种事情。我们来看看这系列的调用所要做的事情:
#include <unistd.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <stdlib.h> int main()
{
int status;
pid_t pid;
if(fork()==)
{
abort();
}
pid=wait(&status);
printf("pid=%d\n",pid);
if(WIFEXITED(status))
printf("正常退出\n");
if(WIFSIGNALED(status))
printf("killed by signal\n");
return ;
}
wait等待子进程挂 结果可以读出子进程是被信号量终止了 所以说 读出子进程的状态还是非常有实际意义的~!
接下来看看wait/waitpid函数的区别:
如果有多个子进程 我该怎么办 要么选择多个wait 但是同时到达 可能就会处理一个子进程 而其他进程状态没有被处理 造成了很多zombie进程 这是不行的 这样就有了waitpid函数:
waitpid(pid_t pid,int *status,int options)
pid=-1 等待任意一子进程
>0 要传入的那个子进程
参数:
WNOHANG: 不会阻塞 立刻返回。 其他参数暂时不去研究了
这样如果有这种 while(waitpid(-1,&stat,WNOHANG)>0);
这样就能接受到所有的子进程的SIGCHLD了。 wait只执行一次 而Linux信号不排队 同时到达 也只会处罚一次哦 这个必须要了解 这样通过waitpid循环来解决掉,但是如果不指定WNOHANG的话 又比较麻烦 主进程会阻塞 这不是我们所想要的哦 所以必须解阻塞。
LINUX系统编程 由REDIS的持久化机制联想到的子进程退出的相关问题的更多相关文章
- linux系统编程之文件与IO(八):文件描述符相关操作-dup,dup2,fcntl
本节目标: 1,文件共享 打开文件内核数据结构 一个进程两次打开同一个文件 两个进程打开同一个文件 2,复制文件描述符(dup.dup2.fcntl) 一,文件共享 1,一个进程打开两个文件内核数据结 ...
- Linux系统编程@进程通信(一)
进程间通信概述 需要进程通信的原因: 数据传输 资源共享 通知事件 进程控制 Linux进程间通信(IPC)发展由来 Unix进程间通信 基于System V进程间通信(System V:UNIX系统 ...
- Linux系统编程温故知新系列 --- 01
1.大端法与小端法 大端法:按照从最高有效字节到最低有效字节的顺序存储,称为大端法 小端法:按照从最低有效字节到最高有效字节的顺序存储,称为小端法 网际协议使用大端字节序来传送TCP分节中的多字节整数 ...
- Linux系统编程-setitimer函数
功能:linux系统编程中,setitimer是一个经常被使用的函数,可用来实现延时和定时的功能. 头文件:sys/time.h 函数原型: int setitimer(int which, cons ...
- Linux 系统编程
简介和主要概念 Linux 系统编程最突出的特点是要求系统程序员对它们工作的的系统的硬件和操作系统有深入和全面的了解,当然它们还有库和系统调用上的区别. 系统编程分为:驱动编程.用户空间编程和网络编程 ...
- 读书笔记之Linux系统编程与深入理解Linux内核
前言 本人再看深入理解Linux内核的时候发现比较难懂,看了Linux系统编程一说后,觉得Linux系统编程还是简单易懂些,并且两本书都是讲Linux比较底层的东西,只不过侧重点不同,本文就以Linu ...
- Linux系统编程【转】
转自:https://blog.csdn.net/majiakun1/article/details/8558308 一.Linux系统编程概论 1.1 系统编程基石 syscall: libc:标准 ...
- 《Linux系统编程(第2版)》
<Linux系统编程(第2版)> 基本信息 作者: (美)Robert Love 译者: 祝洪凯 李妹芳 付途 出版社:人民邮电出版社 ISBN:9787115346353 上架时间:20 ...
- Redis数据持久化机制AOF原理分析一---转
http://blog.csdn.net/acceptedxukai/article/details/18136903 http://blog.csdn.net/acceptedxukai/artic ...
随机推荐
- 登录锁定状态下Win7关机技巧总结
登录锁定状态下Win7关机技巧总结 一般在锁定状态都是有个关闭电脑的图标的.但是如果你的系统没有,那么怎么样关机呢,所谓的锁定状态通常是指电脑在登录界面,具体的实现如下,感兴趣的朋友可以参考下 现在大 ...
- 【Unity基础知识之三】Unity Assets目录下的特殊文件夹名称
Unity3D的特殊目录名称 Unity预留了一些目录名称,这些目录有着特殊的含义.比较重要的有: Resources这个目录下的所有文件都会被打包到发布版本中,程序可以通过文件路径来访问它们.这 ...
- 发布网站详细步骤(.Net)
(i)打开需要发布的网站 右键需要发布的项目 点击下拉框新建配置文件,输入配置文件名称,点击确定,下一步 发布方法选文件系统,目标位置:项目的根目录 配置选Release 点击发布 (ii) 打开ii ...
- 深入浅出设计模式——桥接模式(Bridge Pattern)
模式动机设想如果要绘制矩形.圆形.椭圆.正方形,我们至少需要4个形状类,但是如果绘制的图形需要具有不同的颜色,如红色.绿色.蓝色等,此时至少有如下两种设计方案: 第一种设计方案是为每一种形状都提供一套 ...
- mysql的初识--DOS下的简单命令
DOS下进入 1.通过程序中的mySQL的:MySQL 5.6 Command Line Client直接进入mySQL的命令行: 2.或者通过WIn+R-->输入cmd,然后C:等一层一层找到 ...
- AngularJS事件绑定的使用详解
本文和大家分享的主要是AngularJS中事件绑定相关知识点,希望通过本文的分享,对大家学习和使用AngularJS有所帮助. 1.绑定事件:表达式.事件方法名: 2.绑定点击事件实例:显示.隐藏页面 ...
- 各种效果的tab选项卡
;(function($){ $.fn.tabso=function( options ){ var opts=$.extend({},$.fn.tabso.defaults,options ); r ...
- linux 安装 apache2.2.31
Linux下安装和配置Apache 概要:本文介绍在CentOS5.4 Linux中安装和配置Apache2.2.14,并且实现Apache和Tomcat6的整合.文章分为三部分,分别是删除系统自带的 ...
- Excel 2013中单元格添加下拉列表的方法
使用Excel录入数据的时候我们通常使用下拉列表来限定输入的数据,这样录入数据就很少发生错误了.Excel 2013较以前的版本发生了很大的变化,那么在Excel 2013是如何添加下拉列表的呢? 下 ...
- SiteFactory简单配制
进入后台管理: 指向节点,有点节点ID,这个节点ID就是siteFactory根据规则能生成的页面,页面更新网址: http://www.elexcon.com/Category_节点ID/Index ...