热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux进程管理linux守护进程深入理解

一常用命令ps参数讲解使用ps命令查看进程的当前状态,其中STAT列的含义如下:D不可中断的休眠。通常是IO。R运行。正在运行或者在运行队列中等待。S

一 常用命令 ps 参数讲解

使用ps命令查看进程的当前状态&#xff0c;其中STAT列的含义如下&#xff1a;D 不可中断的休眠。通常是IO。R 运行。正在运行或者在运行队列中等待。S 休眠。在等待某个事件&#xff0c;信号。T 停止。进程接收到信息SIGSTOP&#xff0c;SIGSTP&#xff0c;SIGTIN&#xff0c;SIGTOU信号。W paging&#xff0c;在2.6之后不用。X 死掉的进程&#xff0c;不应该出现。Z 僵死进程。通常还会跟随如下字母表示更详细的状态。<高优先级N 低优先级L 有pages在内存中locked。用于实时或者自定义IO。s 进程领导者&#xff0c;其有子进程。l 多线程&#43; 位于前台进程组。还有一些其他不常见的状态。


二 理论 

原文&#xff1a;http://blog.163.com/yungang_z/blog/static/175153133201232462140622/

      守护进程&#xff08;Daemon&#xff09;是运行在后台的一种特殊进程。它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件。守护进程是一种很有用的进 程。Linux的大多数服务器就是用守护进程实现的。比如&#xff0c;Internet服务器inetd&#xff0c;Web服务器httpd等。同时&#xff0c;守护进程完成许多系统任务。 比如&#xff0c;作业规划进程crond&#xff0c;打印进程lpd等。

        守护进程的编程本身并不复杂&#xff0c;复杂的是各种版本的Unix的实现机制不尽相同&#xff0c;造成不同 Unix环境下守护进程的编程规则并不一致。需要注意&#xff0c;照搬某些书上的规则&#xff08;特别是BSD4.3和低版本的System V&#xff09;到Linux会出现错误的。下面将给出Linux下守护进程的编程要点和详细实例。

一&#xff0e; 守护进程及其特性

        守护进程最重要的特性是后台运行。在这一点上DOS下的常驻内存程序TSR与之相似。其次&#xff0c;守护进程必须与其运行前的环境隔离开来。这些环 境包括未关闭的文件描述符&#xff0c;控制终端&#xff0c;会话和进程组&#xff0c;工作目录以及文件创建掩模等。这些环境通常是守护进程从执行它的父进程&#xff08;特别是shell&#xff09;中继承下 来的。最后&#xff0c;守护进程的启动方式有其特殊之处。它可以在Linux系统启动时从启动脚本/etc/rc.d中启动&#xff0c;可以由作业规划进程crond启动&#xff0c;还可以由用户终端&#xff08;通常是 shell&#xff09;执行。

        总之&#xff0c;除开这些特殊性以外&#xff0c;守护进程与普通进程基本上没有什么区别。因此&#xff0c;编写守护进程实际上是把一个普通进程按照上述的守护进程的特性改造成为守护进程。如果对进程有比较深入的认识就更容易理解和编程了。

二&#xff0e; 守护进程的编程要点

        不同Unix环境下守护进程的编程规则并不一致。所幸的是守护进程的编程原则其实都一样&#xff0c;区别在于具体的实现细节不同。这个原则 就是要满足守护进程的特性。同时&#xff0c;Linux是基于Syetem V的SVR4并遵循Posix标准&#xff0c;实现起来与BSD4相比更方便。编程要点如下&#xff1b;

1. 在后台运行。

        为避免挂起控制终端将Daemon放入后台执行。方法是在进程中调用fork使父进程终止&#xff0c;让Daemon在子进程中后台执行。

    if(pid&#61;fork())

exit(0); //是父进程&#xff0c;结束父进程&#xff0c;子进程继续

2. 脱离控制终端&#xff0c;登录会话和进程组

        有必要先介绍一下Linux中的进程与控制终端&#xff0c;登录会话和进程组之间的关系&#xff1a;进程属于一个进程组&#xff0c;进程组号&#xff08;GID&#xff09;就是进程组长的进程号&#xff08;PID&#xff09;。登录会话可以包含多个进程组。这些进程组共享一个控制终端。这个控制终端通常是创建进程的登录终端。 控制终端&#xff0c;登录会话和进程组通常是从父进程继承下来的。我们的目的就是要摆脱它们&#xff0c;使之不受它们的影响。方法是在第1点的基础上&#xff0c;调用setsid()使进程成为会话组长&#xff1a;

    setsid(); //设置为会话组长

        说明&#xff1a;当进程是会话组长时setsid()调用失败。但第一点&#xff08;fork()&#xff09;已经保证进程不是会话组长。setsid()调用成功后&#xff0c;进程成为新的会话组长和新的进程组长&#xff0c;并与原来的登录会话和进程组脱离。由于会话过程对控制终端的独占性&#xff0c;进程同时与控制终端脱离。

3. 禁止进程重新打开控制终端

        现在&#xff0c;进程已经成为无终端的会话组长。但它可以重新申请打开一个控制终端。可以通过使进程不再成为会话组长来禁止进程重新打开控制终端&#xff08;再fork一次&#xff09;&#xff1a;

if(pid&#61;fork()) 

    exit(0); //结束第一子进程&#xff0c;第二子进程继续&#xff08;第二子进程不再是会话组长&#xff09;

4. 关闭打开的文件描述符

        进程从创建它的父进程那里继承了打开的文件描述符。如不关闭&#xff0c;将会浪费系统资源&#xff0c;可能会造成进程所占用的文件系统无法卸下以及引起无法预料的错误。按如下方法关闭它们&#xff1a;

for(i&#61;0;i <3; &#43;&#43;i)

close(i); //0&#xff0c; 1&#xff0c; 2 分别表示标准输入、标准输出和标准错误

      当然&#xff0c;此处关闭哪个文件描述符与实际需要相关&#xff0c;也可以关闭以后再重新打开。

5. 改变当前工作目录

        进程活动时&#xff0c;如果该目录是一个挂载的目录&#xff0c;将导致其文件系统不能卸载。一般需要将工作目录改变到根目录&#xff08;chdir("/")&#xff09;。对于需要转储核心&#xff0c;写运行日志的进程将工作目录改变到特定目录如 /tmp

6. 重设文件创建掩模

        进程从创建它的父进程那里继承了文件创建掩模。由继承得来的文件方式创建屏蔽字可能会拒绝设置某些许可权。例如&#xff0c;若daemon进程要创建一个组可读、写的文件&#xff0c;而继承的文件方式创建屏蔽字&#xff0c;屏蔽了这两种许可权&#xff0c;则要求的组可读、写就不能起作用。为防止这一点&#xff0c;将文件创建掩模清除&#xff1a;

umask(0);

7. 处理SIGCHLD信号

        处理SIGCHLD信号并不是必须的。但对于某些进程&#xff0c;特别是服务器进程往往在请求到来时生成子进程处理请求。如果父进程不等待子进程结 束&#xff0c;子进程将成为僵尸进程&#xff08;zombie&#xff09;。如果父进程等待子进程结束&#xff0c;将增加父进程的负担&#xff0c;影响服务器进程的并发性能。在Linux下 可以简单地将 SIGCHLD信号的操作设为SIG_IGN。

signal(SIGCHLD,SIG_IGN);

        这样&#xff0c;内核在子进程结束时不会产生僵尸进程。这一点与BSD4不同&#xff0c;BSD4下必须显式等待子进程结束才能释放僵尸进程。


推荐阅读
  • 本文是Java并发编程系列的开篇之作,将详细解析Java 1.5及以上版本中提供的并发工具。文章假设读者已经具备同步和易失性关键字的基本知识,重点介绍信号量机制的内部工作原理及其在实际开发中的应用。 ... [详细]
  • 从0到1搭建大数据平台
    从0到1搭建大数据平台 ... [详细]
  • 性能测试中的关键监控指标与深入分析
    在软件性能测试中,关键监控指标的选取至关重要。主要目的包括:1. 评估系统的当前性能,确保其符合预期的性能标准;2. 发现软件性能瓶颈,定位潜在问题;3. 优化系统性能,提高用户体验。通过综合分析这些指标,可以全面了解系统的运行状态,为后续的性能改进提供科学依据。 ... [详细]
  • 深入解析CAS机制:全面替代传统锁的底层原理与应用
    本文深入探讨了CAS(Compare-and-Swap)机制,分析了其作为传统锁的替代方案在并发控制中的优势与原理。CAS通过原子操作确保数据的一致性,避免了传统锁带来的性能瓶颈和死锁问题。文章详细解析了CAS的工作机制,并结合实际应用场景,展示了其在高并发环境下的高效性和可靠性。 ... [详细]
  • 数字图书馆近期展出了一批精选的Linux经典著作,这些书籍虽然部分较为陈旧,但依然具有重要的参考价值。如需转载相关内容,请务必注明来源:小文论坛(http://www.xiaowenbbs.com)。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • Java高并发与多线程(二):线程的实现方式详解
    本文将深入探讨Java中线程的三种主要实现方式,包括继承Thread类、实现Runnable接口和实现Callable接口,并分析它们之间的异同及其应用场景。 ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 基于Linux开源VOIP系统LinPhone[四]
    ****************************************************************************************** ... [详细]
  • 在《Cocos2d-x学习笔记:基础概念解析与内存管理机制深入探讨》中,详细介绍了Cocos2d-x的基础概念,并深入分析了其内存管理机制。特别是针对Boost库引入的智能指针管理方法进行了详细的讲解,例如在处理鱼的运动过程中,可以通过编写自定义函数来动态计算角度变化,利用CallFunc回调机制实现高效的游戏逻辑控制。此外,文章还探讨了如何通过智能指针优化资源管理和避免内存泄漏,为开发者提供了实用的编程技巧和最佳实践。 ... [详细]
  • 深入解析 Synchronized 锁的升级机制及其在并发编程中的应用
    深入解析 Synchronized 锁的升级机制及其在并发编程中的应用 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 在2015年1月的MySQL内核报告中,我们详细探讨了性能优化和Group Commit机制的改进。尽管网上已有大量关于Group Commit的资料,本文将简要回顾其发展,并重点分析MySQL 5.6及之前版本中引入的二进制日志(Binlog)对性能的影响。此外,我们还将深入讨论最新的优化措施,如何通过改进Group Commit机制显著提升系统的整体性能和稳定性。 ... [详细]
  • 尽管我们尽最大努力,任何软件开发过程中都难免会出现缺陷。为了更有效地提升对支持部门的协助与支撑,本文探讨了多种策略和最佳实践,旨在通过改进沟通、增强培训和支持流程来减少这些缺陷的影响,并提高整体服务质量和客户满意度。 ... [详细]
author-avatar
快乐的老爷们土豆_534
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有