【项目 进程14】2.30 守护进程(1) 2.31 守护进程(2)

news/2025/2/12 4:05:49/

文章目录

    • 2.30 守护进程(1)
    • 终端
    • 进程组
    • 会话
    • 进程组、会话、控制终端之间的关系
    • 进程组、会话操作函数
    • 守护进程
    • 2.31 守护进程(2)
    • 守护进程的创建步骤
    • 写一个守护进程,每隔2s获取一下系统时间,将这个时间写入到磁盘文件中


2.30 守护进程(1)

终端

echo $$//查看当前终端的的pid
tty//查看当前终端设备

控制终端可以操作某一个进程。

在这里插入图片描述所以如果是一个后台进程,是没有控制终端的。是不能通过终端给进程发送信号的

进程组

在这里插入图片描述

会话

在这里插入图片描述

进程组、会话、控制终端之间的关系

在这里插入图片描述
find/2 查看2 重定向到 dev/null设备上,|管道(创建子进程),wc -l统计 &在后台运行,为一个新的进程组
PGID为进程组ID(G:group),SID为会话ID
执行一个命令,默认是在前台执行,除非加上&号。同一时刻,只能有一个前台进程组,只有前台进程组才能享有控制终端的操作权力。
在这里插入图片描述控制终端默认是后端进程。一打开这个终端,就创建了一个进程。于是会话组号和进程组号就定下来了。在这个进程下执行其他命令相当于是终端的子进程。在子进程中再创建子进程,就变成进程组。wx和uniq的ppid都是400是因为他们都是用execlp函数直接调用了其他进程来取代子进程。这些命令的父进程都是控制终端400

进程组、会话操作函数

在这里插入图片描述
getpgrp:get process group 获得当前进程组id
getpgid:获得指定进程的进程组id
setpgid:把哪个进程设置进哪个进程组
getsid:获取某个进程的会话id
setsid:设置会话id

守护进程

在这里插入图片描述

2.31 守护进程(2)

守护进程的创建步骤

在这里插入图片描述
若当前进程创建会话,当前进程产生进程组,进程组的组长不能和会话组长为同一进程。创建会话的进程不能为进程的组长,不能为进程的首进程
父进程死后会有shell提示符,如下:
在这里插入图片描述

(1)执行一个fork(),之后父进程退出,子进程继续后台执行的原因:防止父进程在被杀死时产生shell提示符。且确保子进程不会成为进程组的首进程。
(2)子进程调用setsid()开启一个新会话,原因:(很模糊)
id 100的进程调用setid()去开启一个会话,会执行下面两个步骤:
100的进程放在一个进程组中,进程组id为100,100也为会话的id。原先进程100所在的会话id为80,现在新创建出一个会话。新创建出来的会话只要和控制终端没有建立连接,那么就没有控制终端。目的:脱离控制终端(为什么调用setsid()?)。
为什么在子进程中调用?
若父进程id为100,进程组id为100。id100创建一个新会话,新会话中有进程组id100,进程id100,与原先会话冲突。若使用子进程id101创建新会话,则新会话中的进程组id为101,进程id为101,不会产生冲突

守护进程是后台(不受控制终端控制)服务(长期)进程。

写一个守护进程,每隔2s获取一下系统时间,将这个时间写入到磁盘文件中

#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/time.h>
#include <signal.h>
#include <time.h>
#include <stdlib.h>
#include <string.h>void work(int num) {// 捕捉到信号之后,获取系统时间,写入磁盘文件time_t tm = time(NULL);//将time_t类型时间转换为本地时间struct tm * loc = localtime(&tm);// char buf[1024];// sprintf(buf, "%d-%d-%d %d:%d:%d\n",loc->tm_year,loc->tm_mon// ,loc->tm_mday, loc->tm_hour, loc->tm_min, loc->tm_sec);//脱离控制终端,这种方式不输出,且使用while循环,不让设置完定时器后程序即结束// printf("%s\n", buf);//asctime()系统调用char * str = asctime(loc);int fd = open("time.txt", O_RDWR | O_CREAT | O_APPEND, 0664);write(fd ,str, strlen(str));close(fd);
}int main() {// 1.创建子进程pid_t pid = fork();//退出父进程if(pid > 0) {exit(0);}// 2.将子进程重新创建一个会话setsid();// 3.设置掩码umask(022);// 4.更改工作目录为跟目录://守护进程会在系统启动的时候被创建并一直运行直至系统被关闭。//如工作目录为U盘,那么U盘一直不能卸载系统文件,而跟目录一直不会卸载工作目录chdir("/home/nowcoder/");// 5. 关闭、重定向文件描述符//重定向:后台程序不往终端输出信息int fd = open("/dev/null", O_RDWR);dup2(fd, STDIN_FILENO);dup2(fd, STDOUT_FILENO);dup2(fd, STDERR_FILENO);// 6.业务逻辑// 捕捉定时信号struct sigaction act;act.sa_flags = 0;act.sa_handler = work;//函数指针sigemptyset(&act.sa_mask);sigaction(SIGALRM, &act, NULL);struct itimerval val;val.it_value.tv_sec = 2;val.it_value.tv_usec = 0;val.it_interval.tv_sec = 2;val.it_interval.tv_usec = 0;// 创建定时器setitimer(ITIMER_REAL, &val, NULL);// 不让进程结束while(1) {sleep(10);}return 0;
}

http://www.ppmy.cn/news/1004194.html

相关文章

Jmeter 压测工具使用手册[详细]

1. jemter 简介 jmeter 是 apache 公司基于 java 开发的一款开源压力测试工具&#xff0c;体积小&#xff0c;功能全&#xff0c;使用方便&#xff0c;是一个比较轻量级的测试工具&#xff0c;使用起来非常简 单。因为 jmeter 是 java 开发的&#xff0c;所以运行的时候必须先…

Unity 编辑器选择器工具类Selection 常用函数和用法

Unity 编辑器选择器工具类Selection 常用函数和用法 点击封面跳转下载页面 简介 在Unity中&#xff0c;Selection类是一个非常有用的工具类&#xff0c;它提供了许多函数和属性&#xff0c;用于操作和管理编辑器中的选择对象。本文将介绍Selection类的常用函数和用法&#xff…

【数据结构练习题】单链表问题解决(虚拟头节点法,递归,快慢指针法)

目录 1.删除单链表中的元素1.1 删除排序链表中的重复元素1.2 删除排序链表中的重复元素Ⅱ1.3 移除链表元素 2.反转链表2.1 反转链表2.2 反转链表Ⅱ 3.查找链表中结点3.1 链表的中间结点3.2 链表中倒数第k个节点 4.回文链表5.相交链表6.合并链表 知识补充&#xff1a; 递归三要素…

AR远程专家指导在汽车改装上的应用有哪些?

随着科技的不断发展&#xff0c;AR增强现实技术逐渐走进了我们的生活。加上商贸国际化&#xff0c;远程协同纵深到制造生产的更多环节&#xff0c;研发协同、工艺优化等场景复杂、跨层级、需要频繁沟通确认的流程正通过AR应用实现全面远程化的过渡&#xff0c;在汽车行业&#…

【设计模式——学习笔记】23种设计模式——迭代器模式Iterator(原理讲解+应用场景介绍+案例介绍+Java代码实现)

文章目录 案例引入介绍基础介绍应用场景登场角色 案例实现案例一实现 案例二实现 迭代器模式在JDK源码中的应用总结文章说明 案例引入 编写程序展示一个学校院系结构: 需求是这样&#xff0c;要在一个页面中展示出学校的院系组成&#xff0c;一个学校有多个学院&#xff0c;一…

排序进行曲-v4.0

文章目录 小程一言快速排序步骤详细解释具体步骤 举例总结 复杂度分析时间复杂度分析&#xff1a;空间复杂度分析&#xff1a;注意 应用场景总结 实际举例结果总结 代码实现结果解释 小程一言 这篇文章是在排序进行曲3.0之后的续讲&#xff0c; 这篇文章主要是对快速排序进行细…

线上Zookeeper问题解决记录

zookeeper问题: 日志目录: /home/cmccdata/app/zookeeper/logs dataDir/home/cmccdata/app/zookeeper/data/zoodata dataLogDir/home/cmccdata/app/zookeeper/data/zoolog 问题0: 2023-08-03 17:15:43,139 [myid:1] - WARN [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:2181:…

分布式异步任务处理组件(五)

节点上线和下线的逻辑-- 节点下线分为两种--心跳失败主动或被动和主节点断开连接&#xff0c;但是节点本身没有发生重启&#xff1b;第二种就是节点宕机重启--其实这两中情况下处理逻辑都是一样的&#xff0c;只是节点本身如果还能消费到kafka的时候可以继续执行任务但是不能从…