每天学五分钟 Liunx 0101 | 服务篇:创建进程
创建子进程
[root@lianhua process]$ cat exec.sh
#!/bin/bash
ps -lf
echo $BASHPID
exec ls [root@lianhua process]$ /bin/bash exec.sh
F S UID PID PPID C PRI NI ADDR SZ WCHAN STIME TTY TIME CMD
4 S root 36259 36250 0 80 0 - 28754 do_wai 13:45 pts/15 00:00:00 -bash
0 S root 53778 36259 0 80 0 - 28296 do_wai 17:29 pts/15 00:00:00 /bin/bash exec.sh
0 R root 53779 53778 0 80 0 - 38356 - 17:29 pts/15 00:00:00 ps -lf
53778
exec.sh
fork
[root@lianhua process]$ cat process1.cpp
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <unistd.h> int main()
{
pid_t pid;
pid = fork();
if (pid < 0)
{
perror("fork error:");
exit(1);
}
if (pid == 0)
{
printf("I am the child process.\n");
printf("pid: %d\tppid:%d\n",getpid(),getppid());
printf("I will sleep five seconds.\n");
sleep(5);
printf("pid: %d\tppid:%d\n",getpid(),getppid());
printf("child process is exited.\n");
}
else
{
printf("I am father process.\n");
printf("father process is exited.\n");
}
return 0;
} [root@lianhua process]$ ./process1.out
I am father process.
pid: 2365 ppid:36259
father process is exited.
I am the child process.
pid: 2366 ppid:2365
I will sleep five seconds.
[root@lianhua process]$ ps -lf
F S UID PID PPID C PRI NI ADDR SZ WCHAN STIME TTY TIME CMD
1 S root 2366 1 0 80 0 - 1056 hrtime 20:53 pts/15 00:00:00 ./process1.out
0 R root 3799 36259 0 80 0 - 38356 - 20:53 pts/15 00:00:00 ps -lf
4 S root 36259 36250 0 80 0 - 28754 do_wai 13:45 pts/15 00:00:00 -bash
[root@lianhua process]$ pid: 2366 ppid:1
child process is exited.
while(getppid() != 1)
sleep(1);
僵尸进程
[root@lianhua process]$ cat process3.cpp
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h> int main()
{
pid_t pid;
while(1)
{
pid = fork();
if (pid < 0)
{
perror("fork error:");
exit(1);
}
else if (pid == 0)
{
printf("I am a child process PID=%d, PPID=%d.\nI am exiting.\n", getpid(), getppid());
exit(0);
}
else
{
printf("pid: %d\tppid:%d\n",getpid(),getppid());
sleep(5);
continue;
}
}
return 0;
} [root@lianhua process]$ ./process3.out
pid: 6345 ppid:36259
I am a child process PID=6346, PPID=6345.
I am exiting.
pid: 6345 ppid:36259
I am a child process PID=6367, PPID=6345.
I am exiting.
pid: 6345 ppid:36259
I am a child process PID=6535, PPID=6345.
I am exiting.
^C [root@lianhua ~]$ ps -lA | grep defunct
1 Z 0 6346 6345 0 80 0 - 0 do_exi pts/15 00:00:00 process3.out <defunct>
1 Z 0 6367 6345 0 80 0 - 0 do_exi pts/15 00:00:00 process3.out <defunct>
1 Z 0 6535 6345 0 80 0 - 0 do_exi pts/15 00:00:00 process3.out <defunct>
[root@lianhua ~]$ kill -9 6345
[root@lianhua process]$ ./process3.out
...
pid: 6345 ppid:36259
I am a child process PID=6656, PPID=6345.
I am exiting.
Killed
[root@lianhua process]$
1. 调用信号处理函数
- 如果所有子进程运行,则阻塞;
- 如果一个子进程终止,正等待父进程获取其终止状态,则取得该子进程的终止状态并立即返回;
- 如果没有任何子进程,则立即出错返回;
[root@lianhua process]$ cat process3.1.cpp
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <wait.h> int main()
{
pid_t pid;
while(1)
{
pid = fork();
if (pid < 0)
{
perror("fork error:");
exit(1);
}
else if (pid == 0)
{
printf("I am a child process PID=%d, PPID=%d.\nI am exiting.\n", getpid(), getppid());
exit(0);
}
else
{
printf("pid: %d\tppid:%d\n",getpid(),getppid());
wait(NULL);
sleep(5);
continue;
}
}
return 0;
} [root@lianhua process]$ ./process3.1.out
pid: 9207 ppid:36259
I am a child process PID=9208, PPID=9207.
I am exiting.
pid: 9207 ppid:36259
I am a child process PID=9297, PPID=9207.
I am exiting.
pid: 9207 ppid:36259
I am a child process PID=9306, PPID=9207.
I am exiting.
^C [root@lianhua ~]$ ps -lA | grep defunct
[root@lianhua ~]$ ps -lA | grep defunct
2. fork 两次
[root@lianhua process]$ cat process5.cpp
#include <unistd.h>
#include <stdio.h> int main(void)
{
int i=0;
printf("i child/father ppid pid fpid\n");
for(i=0; i<2; i++)
{
pid_t fpid=fork();
if(fpid == 0)
printf("%d child %4d %4d %4d\n", i, getppid(), getpid(), fpid);
else
printf("%d father %4d %4d %4d\n", i, getppid(), getpid(), fpid);
}
return 0;
} [root@lianhua process]$ ./process5.out
i child/father ppid pid fpid
0 father 36259 45119 45120
0 child 45119 45120 0
1 father 36259 45119 45121
1 father 45119 45120 45122
1 child 45120 45122 0
1 child 1 45121 0
[root@lianhua process]$ cat process5.cpp
#include <unistd.h>
#include <stdio.h> int main(void)
{
int i=0;
printf("i child/father ppid pid fpid\n");
for(i=0; i<2; i++)
{
pid_t fpid=fork();
if(fpid == 0)
printf("%d child %4d %4d %4d\n", i, getppid(), getpid(), fpid);
else
{
printf("%d father %4d %4d %4d\n", i, getppid(), getpid(), fpid);
sleep(20);
}
}
return 0;
} [root@lianhua process]$ ./process5.out
i child/father ppid pid fpid
0 father 36259 10739 10740
0 child 10739 10740 0
1 father 10739 10740 10741
1 child 10740 10741 0
1 father 36259 10739 10764
1 child 10739 10764 0 [root@lianhua ~]$ ps -lA | grep defunct
0 Z 0 10500 1720 0 80 0 - 0 do_exi ? 00:00:00 fluentd-report <defunct>
1 Z 0 10740 10739 0 80 0 - 0 do_exi pts/15 00:00:00 process5.out <defunct>
1 Z 0 10764 10739 0 80 0 - 0 do_exi pts/15 00:00:00 process5.out <defunct>
[root@lianhua ~]$ ps -lA | grep defunct
0 Z 0 10500 1720 0 80 0 - 0 do_exi ? 00:00:00 fluentd-report <defunct>
每天学五分钟 Liunx 0101 | 服务篇:创建进程的更多相关文章
- c++ 网络编程(八) LINUX-epoll/windows-IOCP下 socket opoll函数用法 优于select方法的epoll 以及windows下IOCP 解决多进程服务端创建进程资源浪费问题
原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9622548.html 锲子:关于并发服务器中的I/O复用实现方式,前面在网络编程系列四还是五来 ...
- c++ 网络编程(四) LINUX/windows下 socket 基于I/O复用的服务器端代码 解决多进程服务端创建进程资源浪费问题
原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9613861.html 好了,继上一篇说到多进程服务端也是有缺点的,每创建一个进程就代表大量的运 ...
- 五分钟学Java:如何才能学好Java Web里这么多的技术
原创声明 本文作者:黄小斜 转载请务必在文章开头注明出处和作者. 系列文章介绍 本文是<五分钟学Java>系列文章的一篇 本系列文章主要围绕Java程序员必须掌握的核心技能,结合我个人三年 ...
- 如何从40亿整数中找到不存在的一个 webservice Asp.Net Core 轻松学-10分钟使用EFCore连接MSSQL数据库 WPF实战案例-打印 RabbitMQ与.net core(五) topic类型 与 headers类型 的Exchange
如何从40亿整数中找到不存在的一个 前言 给定一个最多包含40亿个随机排列的32位的顺序整数的顺序文件,找出一个不在文件中的32位整数.(在文件中至少确实一个这样的数-为什么?).在具有足够内存的情况 ...
- 零元学Expression Blend 4 - Chapter 42 五分钟快速完成扇形变圆形动画
原文:零元学Expression Blend 4 - Chapter 42 五分钟快速完成扇形变圆形动画 零元学Expression Blend 4 - Chapter 42 五分钟快速完成扇形变圆形 ...
- 五分钟给你的 gRPC服务 加上 HTTP 接口
gRPC 服务要加 HTTP 接口? go-zero 给大家带来极简的 RESTful 和 gRPC 服务开发体验的同时,社区又给我们提出了新的期望: 我想只写一次代码 既要 gRPC 接口 也要 H ...
- [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)
[分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例) 踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-35 ...
- 《sed的流艺术之一》-linux命令五分钟系列之二十一
本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...
- GC算法精解(五分钟让你彻底明白标记/清除算法)
GC算法精解(五分钟让你彻底明白标记/清除算法) 相信不少猿友看到标题就认为LZ是标题党了,不过既然您已经被LZ忽悠进来了,那就好好的享受一顿算法大餐吧.不过LZ丑话说前面哦,这篇文章应该能让各位彻底 ...
- zookeeper-架构设计与角色分工-《每日五分钟搞定大数据》
本篇文章阅读时间5分钟左右 点击看<每日五分钟搞定大数据>完整思维导图 zookeeper作为一个分布式协调系统,很多组件都会依赖它,那么此时它的可用性就非常重要了,那么保证可用性的同 ...
随机推荐
- Python 潮流周刊第一季完结(1~30)
你好,我是猫哥.庆祝 Python 潮流周刊在几天前顺利更新到了第 30 期! 我觉得这是一个很有意义的时间节点,不太短也不漫长,很适合作一个小小的总结. 我打算今后每 30 期作为一季,都给大家做一 ...
- SpringBoot测试用例的一些小技巧~
场景一:不想因为测试而对数据库产生脏数据 @Test public void testInsert() { User user = new User(); user.setUsername(" ...
- vulnhub - Nagini - writeup
信息收集 基础信息 目标只开放了22和88: root@Lockly tmp/nagini » arp-scan -I eth1 -l Interface: eth1, type: EN10MB, M ...
- wasm+pygbag让你在网页上也能运行Python代码:【贪吃蛇游戏】
引言 最近小伙伴告诉我一种新的方法,可以使用wasm来使浏览器网页能够运行Python代码.这一下子激起了我的兴趣,因为这意味着用户无需安装Python环境就能直接运行我的demo,这真是太方便了.所 ...
- 现代 CMake 模块化项目管理指南
现代 CMake 模块化项目管理指南 参考小彭老师的视频教程整理笔记,学习同时方便快速查阅,视频链接如下 [公开课]现代 CMake 模块化项目管理指南[C/C++] 对应课程 PPT 和源码见 ht ...
- PowerDotNet平台化软件架构设计与实现系列(17):PCRM个人用户管理平台
个人用户管理是业务系统中非常基础且重要的一个公共服务系统,我们写的绝大多数应用都和个人用户或会员有关,用户(会员)数据安全无小事,必须有一个完备的用户管理平台系统. 因为不同公司的主业务不同,个人用户 ...
- java中使用对象储存OSS
首先获取 ACCESS_KEYSECRET 与 ACCESS_KEYID 获取 ENDPOINT 与 ALI_DOMAIN 与 BUCKET_NAME(存储空间名称) 依赖 <!-- 图片 ...
- LeetCode DP篇-求子序列问题(1143、300、53、72)
1143. 最长公共子序列 给定两个字符串 text1 和 text2,返回这两个字符串的最长公共子序列的长度. 一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情 ...
- 案例解析丨 Spark Hive 自定义函数应用
摘要:Spark目前支持UDF,UDTF,UDAF三种类型的自定义函数. 1. 简介 Spark目前支持UDF,UDTF,UDAF三种类型的自定义函数.UDF使用场景:输入一行,返回一个结果,一对一, ...
- 从标准到开发,解读基于MOF的应用模型管理
摘要:为了打破技术与业务的壁垒,搭建技术与业务的桥梁,因此基于如下流程实现应用业务模型管理 ROMA ABM. 在数字经济时代,数据正在成为企业极其重要的战略性资产.在政府方面,数据第一次作为新型生产 ...