Linux系统编程(守护进程)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Linux系统编程(守护进程)

前言

本篇文章我们来讲解守护进程,守护进程在进程中是一个比较重要的概念,在笔试面试中也经常考到,这篇文章就带大家来学习一下什么是守护进程。

一、守护进程概念

守护进程(Daemon Process)是在后台运行的一种特殊类型的进程,独立于终端会话,并且通常没有与用户交互的界面。守护进程在操作系统启动时启动,并持续运行,提供某种服务或执行特定的任务。

以下是守护进程的一些特点和作用:

1.后台运行:守护进程在后台运行,与终端会话无关。它不会像前台进程一样与终端交互,也不会受到终端关闭的影响。

2.无用户交互:守护进程通常没有与用户直接交互的界面。它在后台默默地运行,执行特定的任务或提供服务,如网络服务、定时任务等。

3.生命周期控制:守护进程通常由操作系统启动,在操作系统运行期间一直保持活动状态。它可以在操作系统启动时自动启动,并在系统关闭时自动终止。

4.分离与父进程:守护进程通常会从父进程(比如 Shell)中分离,成为一个独立的进程组,没有与终端相关联。这样可以避免与终端的交互和输出。

5.日志和错误处理:守护进程通常会将输出记录到日志文件中,而不是直接向终端输出。这有助于跟踪和排除问题,并提供可靠的错误处理机制。

6.无控制终端:守护进程不会占用、控制或依赖于终端设备,这使得它们可以在系统无人值守时运行。它们可以在系统启动后一直执行,无需用户干预。

守护进程的设计和实现要考虑到一些关键问题,如资源管理、信号处理、错误处理、日志记录、进程间通信等。同时,为了实现守护进程的特性,Linux 中提供了一些守护进程相关的编程技术和系统调用,如 fork()、setsid()、umask()、open()、chdir()、close() 等。

创建和管理守护进程需要谨慎处理,确保守护进程正确启动、运行和终止,同时记录必要的日志信息,以便进行故障排除。通常,各个 Linux 发行版提供了一些工具和约定用于配置和管理守护进程,如 Systemd、Upstart 和 SysVinit 等。

总而言之,守护进程是在后台运行的一种特殊类型的进程,独立于终端会话,并且没有与用户交互的界面。它们提供特定的服务或执行特定的任务,通常在操作系统启动时运行,并持续提供服务。

二、空洞文件

/dev/null 是一个特殊的设备文件,也被称为空洞文件或黑洞文件。

以下是对 /dev/null 空洞文件的一些特点和用途:

数据丢弃:将数据写入 /dev/null 相当于将其永久丢弃,数据不会进行存储,也不会影响其他进程和文件系统。这在某些情况下非常有用,比如不需要关心命令的输出结果或需要忽略某些输出。

输出重定向:可以将命令的输出重定向到 /dev/null,这样输出将会被丢弃,不显示在终端或输出到其他地方。通过将标准输出或标准错误重定向到 /dev/null,可以静默执行命令或过滤掉不需要的输出。

例如,command > /dev/null 将命令的标准输出重定向到 /dev/null,从而使输出被丢弃。

同样,command 2> /dev/null 将命令的标准错误输出重定向到 /dev/null,以丢弃标准错误输出。

虚拟输入:通过从 /dev/null 读取数据,会立即得到一个文件结束符(EOF),即读操作立即返回,不会返回任何实际数据。在一些情况下,当需要一个空的输入源时,可以从 /dev/null 读取数据。

总结来说,/dev/null 空洞文件在 Unix-like 系统中用于丢弃数据、将输出静默化或提供一个空的输入源。它是一种有用的机制,可用于在处理数据和命令输出时,忽略不需要的信息。

请注意,/dev/null 是一个特殊文件,而不是目录。在文件系统中,它位于 /dev 目录下,并且常常被用于 I/O 操作的重定向。

三、创建守护进程

这段代码的守护进程创建过程如下:

父进程创建子进程。

父进程退出,子进程成为孤儿进程,由 init 进程接管。

子进程创建孙子进程。

子进程退出,孙子进程成为孤儿进程,由 init 进程接管。

孙子进程成为新会话的首进程,并失去对控制终端的控制。

孙子进程修改文件权限掩码、切换工作目录、关闭标准输入输出文件描述符、重新打开指定的文件描述符(包括将输出重定向到日志文件)。

孙子进程进入一个无限循环,在每次循环中执行一些操作。

这样创建的守护进程在后台运行,与终端无关,不接收终端输入,并且将输出写入日志文件或丢弃。

#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
int main(void)
{
    pid_t pid = 0;
    int i = 0;
    pid = fork();
    if(pid > 0)
    {
        printf("pid : %d\n", getpid());
        exit(0);
    }
    else if(pid == 0)
    {
        setsid();
        printf("pid : %d\n", getpid());
        if((pid = fork()) > 0)
        {
            printf("child = %d, ppid = %d, pgid = %d, sid = %d\n", getpid(), getppid(), getpgrp(), getsid(getpid()));
            printf("groundson: %d\n", pid);            
            exit(0);
        }
        else
        {
            umask(0);
            chdir("/");
            close(STDIN_FILENO);
            close(STDOUT_FILENO);
            close(STDERR_FILENO);
            i += open("/dev/null", O_RDONLY);  // 0 --> STDIN
            i += open("/home/book/linuxsystem/my.log", O_WRONLY);  // 1 --> STDOUT
            i += open("/dev/null", O_RDWR);    // 2 --> STDERR
            printf("child = %d, ppid = %d, pgid = %d, sid = %d\n", getpid(), getppid(), getpgrp(), getsid(getpid()));
            while( 1 )
            {
                // do something
                printf("i = %d\n", i++);
                sleep(1);
                fflush(stdout);
            }
        }
    }
    return 0;
}

运行效果:

这里可以看出这个守护进程不属于任何一个终端,他会一直在后台运行下去,直到系统退出或者使用kill杀死进程。

总结

本篇文章就讲解到这里。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
25天前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
168 78
|
2天前
|
监控 搜索推荐 开发工具
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
|
28天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
61 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
24天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
94 13
|
1月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
2月前
|
Ubuntu Linux 网络安全
linux系统ubuntu中在命令行中打开图形界面的文件夹
在Ubuntu系统中,通过命令行打开图形界面的文件夹是一个高效且实用的操作。无论是使用Nautilus、Dolphin还是Thunar,都可以根据具体桌面环境选择合适的文件管理器。通过上述命令和方法,可以简化日常工作,提高效率。同时,解决权限问题和图形界面问题也能确保操作的顺利进行。掌握这些技巧,可以使Linux操作更加便捷和灵活。
58 3
|
25天前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
41 0
|
1月前
|
存储 Oracle 安全
服务器数据恢复—LINUX系统删除/格式化的数据恢复流程
Linux操作系统是世界上流行的操作系统之一,被广泛用于服务器、个人电脑、移动设备和嵌入式系统。Linux系统下数据被误删除或者误格式化的问题非常普遍。下面北亚企安数据恢复工程师简单聊一下基于linux的文件系统(EXT2/EXT3/EXT4/Reiserfs/Xfs) 下删除或者格式化的数据恢复流程和可行性。
|
6月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
6月前
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
204 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)