- 浏览: 229266 次
- 性别:
- 来自: 北京
最新评论
-
qq452739204:
如果构造的报文大于mtu值,是否需要分片之后再发送出去列?
Linux内核构造数据包并发送(二)(dev_queue_xmit方式) -
xingzengmou:
你好,我搞的原理跟你差不多,但播放的时候有papapa的声音, ...
AudioRecord和AudioTrack类的使用 -
wenjiefeng:
楼主,你有录制pcm格式和播放pcm格式的录音器的demo吗, ...
AudioRecord和AudioTrack类的使用 -
lovepeakingA:
...
AudioRecord和AudioTrack类的使用 -
ZaneLee007:
假的,不学无术
Android禁用键盘的所有按键
守护进程
守护进程是生存期长的一种进程。它们独立于控制终端并且周期性的执行某种任务或等待处理某些发生的事件。他们常常在系统引导装入时启动,在系统关闭时终止。unix系统有很多守护进程,大多数服务器都是用守护进程实现的。比如,网络服务inetd、Web服务http等。同时,守护进程完成许多系统任务。比如,作业规划进程crond、打印进程lqd等。
这里主要说明守护进程的进程结构,以及如何编写守护进程程序。因为守护进程没有控制终端,所以我们还要介绍在守护进程运行时错误输出的方法。
守护进程及其特性
守护进程最重要的特性是后台运行。在这一点上,DOS下的常驻内存程序TSR与之相似。
其次,守护进程必须与其运行前的环境隔离开来。这些环境包括未关闭的文件描述符、控制终端、会话和进程组、工作目录以及文件创建掩码等。这些环境通常是守护进程从执行它的父进程(特别是shell)中继承下来的。
最后,守护进程的启动方式有其特殊之处。它可以在系统启动时从启动脚本/etc/rc.d中启动,可以由inetd守护进程启动,可以有作业规划进程crond启动,还可以由用户终端(通常是shell)执行。
总之,除开这些特殊性以外,守护进程与普通进程基本上没有什么区别。因此,编写守护进程实际上是把一个普通进程按照上述的守护进程的特性改造成为守护进程。如果大家对进程的认识比较深入,就对守护进程容易理解和编程了。
首先我们来察看一些常用的系统守护进程,看一下他们和几个概念:进程组、控制终端和对话期有什么联系。p s命令打印系统中各个进程的状态。该命令有多个选择项,有关细节请参考系统手册。为了察看所需的信息,执行:
ps –axj
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
0 1 0 0 ? -1 S 0 0:04 init
1 2 1 1 ? -1 SW 0 0:00 [keventd]
1 3 1 1 ? -1 SW 0 0:00 [kapm-idled]
0 4 1 1 ? -1 SWN 0 0:00 [ksoftirqd_CPU0]
0 5 1 1 ? -1 SW 0 0:00 [kswapd]
0 6 1 1 ? -1 SW 0 0:00 [kreclaimd]
0 7 1 1 ? -1 SW 0 0:00 [bdflush]
0 8 1 1 ? -1 SW 0 0:00 [kupdated]
1 9 1 1 ? -1 SW< 0 0:00 [mdrecoveryd]
1 17 1 1 ? -1 SW 0 0:02 [kjournald]
1 92 1 1 ? -1 SW 0 0:00 [khubd]
1 573 573 573 ? -1 S 0 0:03 syslogd -r -x
1 578 578 578 ? -1 S 0 0:00 klogd -2
1 598 598 598 ? -1 S 32 0:00 portmap
进程号为1、2的这些进程非常特殊,存在于系统的整个生命期中。它们没有父进程ID ,没有组进程ID ,也没有对话期ID 。syslogd 守护进程可用于任何为操作人员记录系统消息的程序中。可以在一台实际的控制台上打印这些消息,也可将它们写到一个文件中。sendmail 是标准邮递守护进程。update 程序定期将内核缓存中的内容写到硬盘上(通常是每隔30 秒)。为了做到这一点,该程序每隔30 秒调用sync(2 )函数一次。cron 守护进程在指定的日期和时间执行指定的命令。许多系统管理任务是由cron 定期地使相关程序执行而得以实现的。inetd进程监听系统的网络界面,以输入对各种网络服务器的请求。最后一个守护进程,lpd 处理对系统提出的各个打印请求。
注意,所有守护进程都以超级用户(用户ID为0)的优先权运行。没有一个守护进程具有控制终端,终端名称设置为问号(?)、终端前台进程组ID设置为-1。缺少控制终端是守护进程调用了setsid的结果。除update以外的所有守护进程都是进程组的首进程,对话期的首进程,而且是这些进程组和对话期中的唯一进程。最后,应当引起注意的是所有这些守护进程的父进程都是init进程。
在接触实际编程前,我们来看看编写守护进程要碰到的概念:进程组合会话期。
进程组
每个进程除了有一进程ID之外,还属于一个进程组(在讨论信号时就会涉及进程组)进程组是一个或多个进程的集合。每个进程有一个唯一的进程组ID。进程组ID类似于进程ID——它是一个正整数,并可存放在pid_t数据类型中。
每个进程组有一个组长进程。组长进程的标识是,其进程组ID等于其进程ID,进程组组长可以创建一个进程组,创建该组中的进程,然后终止,只要在某个进程组中有一个进程存在,则该进程就存在,这与其组长进程是否终止无关。从进程组创建开始到其中最后一个进程离开为止的时间区间称为进程组的生命期。某个进程组中的最后一个进程可以终止,也可以参加另一进程组。
前面已经提到进程调用setgid可以参加一个现存的组或者创建一个新进程组(setsid也可以创建一个新的进程组,后面将用到)
会话期
会话期(session)是一个或多个进程组的集合。其中,在一个会话期中有3个进程组,通常是有shell的管道线将几个进程编成一组的。
下面说明有关会话期和进程组的一些特性:
一个会话期可以有一个单独的控制终端(controlling terminal),这一般是我们在其上登录的终端设备(终端登录)或伪终端设备(网络登录),但这个控制终端并不是必需的。
建立与控制终端连接的会话期首进程,被称之为控制进程(contronlling process)。以及一个会话期中的几个进程组可被分为一个前台进程组(foreground process group)以及一个或几个后台进程组(background process group)
如果一个会话期有一个控制终端,则它有一个前台进程组,其他进程组为后台进程组。无论何时键入中断键(常常是delete或ctrl-c)或退出键(通常是ctrl-\),就会造成将中断信号或退出信号送至前途进程组的所有进程。
守护进程的编程规则
在不同Unix环境下,守护进程的具体编程细节并不一致。但所幸的是,守护进程的编程原则其实都一样,区别仅在于具体的实现细节不同,这个原则就是要满足守护进程的特性。编程规则如下:
1、在后台运行
为避免挂起控制终端,要将daemon放入后台执行,其方法是,在进程中调用fork使父进程终止,让daemon在子进程中后台执行。具体就是调用f o r k ,然后使父进程e x i t 。这样做实现了下面几点:
第一,如果该精灵进程是由一条简单s h e l l 命令起动的,那么使父进程终止使得s h e l l 认为这条命令已经执行完成。
第二,子进程继承了父进程的进程组I D ,但具有一个新的进程I D ,这就保证了子进程不是一个进程组的首进程。这对于下面就要做的s e t s i d 调用是必要的前提条件。
2、脱离控制终端,登录会话和进程组
登录会话可以包含多个进程组,这些进程组共享一个控制终端,这个控制终端通常是创建进程的登录终端、控制终端,登录会话和进程组通常是从父进程继承下来的。我们的目的就是要摆脱它们,使之不受它们的影响。
其方法是在第一点的基础上,调用setsid()使进程成为会话组长:
需要说明的是,当进程是会话组长时,setsid()调用会失败,但第一点已经保证进程不是会话组长。setsid()调用成功后,进程成为新的会话组长和新的进程组长,并与原来的登录会话和进程组脱离,由于会话过程对控制终端的独占性,进程同时与控制终端脱离。
具体是操作就是:
(a )成为新对话期的首进程
(b )成为一个新进程组的首进程
(c )没有控制终端。
3、禁止进程重新打开控制终端
现在,进程已经成为无终端的会话组长,但它可以重新申请打开一个控制终端。可以通过使进程不再成为会话组长来禁止进程重新打开控制终端:
4、关闭打开的文件描述符
进程从创建它的父进程那里继承了打开的文件描述符。如不关闭,将会浪费系统资源,造成进程所在地文件系统无法卸下以及无法预料的错误。一般来说,必要的是关闭0、1、2三个文件描述符,即标准输入、标准输出、标准错误。因为我们一般希望守护进程自己有一套信息输出、输入的体系,而不是把所有的东西都发送到终端屏幕上。调用fclose();
5、改变当前工作目录
将当前工作目录更改为根目录。从父进程继承过来的当前工作目录可能在一个装配的文件系统中。因为精灵进程通常在系统再引导之前是一直存在的,所以如果精灵进程的当前工作目录在一个装配文件系统中,那么该文件系统就不能被拆卸。
另外,某些精灵进程可能会把当前工作目录更改到某个指定位置,在此位置做它们的工作。例如,行式打印机假脱机精灵进程常常将其工作目录更改到它们的s p o o l 目录上。
可以调用chdir(“目录”);
6、重设文件创建掩码
将文件方式创建屏蔽字设置为0 。由继承得来的文件方式创建屏蔽字可能会拒绝设置某些许可权。例如,若精灵进程要创建一个组可读、写的文件,而继承的文件方式创建屏蔽字,屏蔽了这两种许可权,则所要求的组可读、写就不能起作用。
7、处理SIGCHLD 信号
处理SIGCHLD信号并不是必需的。但对于某些进程,特别是服务器进程往往在请求到来时生产子进程出来请求。如果父进程不等待子进程结束,子进程将成为僵尸进程,(zombie)而仍占用系统资源。如果父进程等待子进程结束,将增加父进程的负担,影响服务器进程的并发性能。在系统V下可以简单的将 SIGCHLD信号的操作设为SIG-IGN:
signal(SIGCHLD,SIG_IGN);
这样,内核在子进程结束时不会产生僵尸进程,这一点与BSD4不同,在BSD4下必须显示等 待子进程结束才能释放僵尸进程。
守护进程实例
守护进程实例包括两部分:主程序test.c和初始化程序init.c。主程序每隔一分钟向/tmp
目录中的日志test.log 报告运行状态。初始化程序中的init_daemon 函数负责生成守护进程
void make_daemon(void) { pid_t pid; FILE * lockfd; sigset_t sighup; int i; extern pid_t getsid(pid_t); pid = fork();//第一个子进程生成 if (pid < 0) { printinfo("fork error!",INFOERROR); exit(FAILEXIT); }else if (pid > 0) { printinfo("fork 1 ok! ", INFOSCREEN); exit(OKEXIT);//退出父进程,摆脱shell的控制 } pid = getpid();//获得子进程自身的id lockfd = fopen(PIDFILE, "w");//以下是将pid写入文件 if (lockfd != NULL) { fprintf(lockfd, "%d\n", pid); fclose(lockfd); }//写入pid if (getsid(0) != pid) {//创建新的会话期 if (setsid() < 0) { printinfo("backupdaemon setsid error!",INFOERROR); perror("setsid"); } } if(pid=fork()){//再次生成子进程,这时候是孙子进程 exit(0);//退出上一代进程 }else if(pid<0){ exit(1); } close(1);//关闭文件 close(2); chdir(rundir);//改变运行的目录 umask(022);//改变文件权限 }
守护进程的错误输出
守护进程不属于任何终端,所以当需要输出某些信息时,它无法像一般程序那样将信息直接输出到标准输出和标准错误输出中。我们很大时候也不希望每个守护进程将它自己的出错消息写到一个单独的文件中。因为对于系统管理人员而言,要记住哪一个守护进程写到哪一个记录文件中,并定期的检查这些文件,他一定会为此感到头疼的。所以,我们需要有一个集中的守护进程出错记录机制。目前很多系统都引入了syslog记录进程来实现这一目的。
自伯克利开发了BSD syslog并广泛应用以来,BSD syslog 机制被大多数守护进程所使用。我们下面介绍BSD syslog 的用法。有三种方法产生记录消息:
1 内核例程可以调用log函数。任何一个用户进程通过打开和读/dev/klog设备就可以读取这些消息。因为我们无意编写内核中的例程,所以不再进一步说明此函数。
2 大多数用户进程(守护进程)调用syslog函数以产生记录消息。我们将在下面说明其调用序列。这使消息发送至Unix域数据报套接口/dev/log。
3 在此主机上,或通过TCP/IP网络连接到此主机的某一其他主机上的一个用户进程可将记录消息发向UDP端口514。
注意:syslog 函数并不产生这些UDP数据报——它们要求产生此记录消息的进程具有显式的网络编程。
通常,syslog守护进程读取三种格式的记录消息。此守护进程在启动时读一个配置文件。一般来说,其文件名为/etc/syslog.conf,该文件决定了不同种类的消息应送向何处。例如,紧急消息可被送向系统管理员(若已登录),并在控制台上显示,而警告消息则可记录到一个文件中。该机制提供了 syslog函数,其调用格式如下
#include <syslog.h>
void openlog (char*ident,int option ,int facility);
void syslog(int priority,char*format,……)
void closelog();
调用openlog是可选择的。如果不调用openlog,则在第一次调用syslog时,自动调用openlog。调用closelog也是可选择的,它只是关闭被用于与syslog守护进程通信的描述符。调用openlog 使我们可以指定一个ident,以后, 此ident 将被加至每则记录消息中。ident 一般是程序的名称(例如 ,cron ,inetd 等)。option 有4种可能:
LOG_CONS 若日志消息不能通过Unix域数据报发送至syslog,则将该消息写至控制台。
LOG_NDELAY1 立即打开Unix域数据报套接口至syslog守护进程,而不要等到记录第一消息。通常,在记录第一条消息之前,该套接口不打开。
LOG_PERROR 除将日志消息发送给syslog 外,还将它至标准出错。此选项仅由4.3BSDReno及以后版本支持。
LOG_PID 每条消息都包含进程ID。此选项可供对每个请求都fork一个子进程的守护进程使用。
在openlog中设置facility参数的目的是让配置文件可以说明,来自不同设施的消息以不同的方式进行处理。如果不调用openlog,或者以 facility 为0来调用它,那么在调用syslog 时,可将facility作为priority参数的一个部分进行说明。调用syslog产生一个记录消息。其priority参数是facility和 level的组合,它们可选取的值分别列于下面。level值按优先级从高级到最低按序排列。
转自:http://hi.baidu.com/skyeye_zeus/blog/item/89071682f38500ba6d8119d8.html
发表评论
-
Netfilter 地址转换的实现
2011-03-17 23:04 0作者:九贱内核版本:2 ... -
Linux内核构造数据包并发送(二)(dev_queue_xmit方式)
2011-03-03 12:24 8913linux内核太构造数据包 ... -
Linux内核构造数据包并发送(Netfilter方式)
2011-03-03 12:21 5161一、构造数据包简析 这里并不详细介绍如何在内核中构造数据包,下 ... -
iphdr与tcphdr详解(skb_header_pointer函数分析)
2011-03-01 12:25 4716linux 2.6.26 下获取tcp信息: tcph=sk ... -
unp.h文件内容
2010-11-28 15:33 2160/* Our own header. Tabs are se ... -
inet_pton和inet_ntop函数
2010-11-28 15:03 1945Linux下这2个IP地址转换函数,可以在将IP地址在“点分十 ... -
linux类原版电子书589本
2010-10-27 16:13 4223ftp://202.96.64.144/pub/books/( ... -
Linux下线程同步对象——互斥量
2010-10-09 10:47 1623进程是Linux资源分配的对象,Linux会为进程分配虚 ... -
系统信息相关命令
2010-09-27 15:55 837系统 # uname -a ... -
Unix/Linux环境下创建和使用静/动态库
2010-09-27 15:51 1331库的作用 大体上库的存在,有两方面的原因,一是代码 ... -
Linux中实现30分钟无操作自动关机
2010-09-27 15:42 1730这是一个自动关机的小程序。该程序可以守护进程的方式运行, ... -
linux IPC-消息队列
2010-09-27 14:02 2391几乎所有的 Linux 发行版本都包含 ipcs 命 ... -
8)Linux程序设计入门--网络编程(下)
2010-09-26 14:12 1100网络编程(7) 7. TCP/IP协议 你也许听说过T ... -
8)Linux程序设计入门--网络编程 (上)
2010-09-26 14:07 1241Linux系统的一个主要 ... -
7)Linux程序设计入门--线程操作
2010-09-26 13:58 951前言:Linux下线程的创 ... -
6)Linux程序设计入门--消息管理
2010-09-26 13:56 993前言:Linux下的进程通 ... -
5)Linux程序设计入门--信号处理
2010-09-26 13:54 1029Linux下的信号事件 前 ... -
4)程序设计入门--时间概念
2010-09-26 13:50 799前言:Linux下的时间概 ... -
3)Linux程序设计入门--文件操作
2010-09-26 13:48 1011Linux下文件的操作 前言: 我们在这一节将要讨论 ... -
2)Linux程序设计入门--进程介绍
2010-09-26 11:05 931前言: 这篇文章是用 ...
相关推荐
在提供的压缩包文件中,"练成Linux高手.chm"可能是包含教程或指南的CHM格式电子书,而`readme.html`和`readme.txt`通常提供关于压缩包的说明或使用指导。利用这些资源,可以系统地学习和巩固Linux知识。
两者的区别:唯一的区别是判断虚拟机(JVM)何时离开,Daemon 是为其他线程提供服务,如果全部的 User Thread 已经撤离,Daemon 没有可服务的线程,JVM 撤离。 五、为什么使用 Executor 框架? 每次执行任务创建...
首先,“ldpd”通常指的是“Link Discovery Protocol Daemon”,这是一个用于网络设备之间发现和管理链路的协议。在互联网协议栈中,LDPD是LDP(Link Discovery Protocol)的一部分,用于建立和维护MPLS...
在实际操作中,用户可能需要将该教程的光盘映像文件通过虚拟光驱加载,如DAEMON Tools或Alcohol 120%等软件。虚拟光驱可以模拟物理光驱的功能,但无需物理介质,只需将[M超记忆大师(右脑开发工具)].MBR.mds这样的...
Oracle RAC 的集群术语包括 Cluster、Node、Instance、OCR(Oracle Cluster Registry)、Voting Disk、CSSD(Cluster Synchronization Service Daemon)、CRSD(Cluster Ready Service Daemon)等。 Oracle RAC ...
DVD数据的处理需要相应的软件工具,如 Daemon Tools、MagicISO、PowerISO等,这些工具可以读取、刻录或虚拟播放BIN文件。用户可以通过它们将BIN文件装载到虚拟光驱中,就像插入物理DVD一样,或者将其转换为其他格式...
5. **守护线程(Daemon)**:这类线程不会阻止程序的退出,常用于后台服务,如垃圾回收。 在这个训练资源中,你可能会遇到关于线程创建、线程间通信、并发控制以及如何在Applet中运用多线程的实际案例。通过学习和...
用户可能需要使用虚拟光驱软件(如Daemon Tools)或者将ISO文件刻录到物理光盘上,才能查看或访问其中的内容。 对于机器学习而言,处理《北京统计年鉴2009》这样的数据集通常涉及以下步骤: 1. 数据预处理:清洗...
MATLAB 6.5的安装通常包括解压、运行setup文件、输入序列号等一系列操作,而MATLAB 7.0的安装可能需要虚拟光驱软件,如daemon,以协助安装过程。 MATLAB培训不仅仅是关于软件的使用,更包含了如何利用MATLAB解决...
守护进程(Daemon)是计算机操作系统中的一个概念,它通常在后台运行,不与终端直接关联,用于执行特定的系统任务或提供服务。在Linux系统中,守护进程非常常见,如SSH服务、网络服务等。然而,这个话题是关于在...
例如限制Custom Resource Definition (CRD)的最大数量、使用Namespaced scope以控制影响范围、避免MutatingWebhook与资源Update操作的组合、正确使用Informers进行事件监听,以及谨慎使用如DaemonSet这样的高级特性...
在 `/etc/docker/daemon.json` 文件中添加: ```json { "default-runtime": "nvidia", "runtimes": { "nvidia": { "path": "/usr/bin/nvidia-container-runtime", "runtimeArgs": [] } } } ``` 3. 重启...
输入vi /etc/gdm3/daemon.conf 将#AutomaticLoginEnable = True和#AutomaticLogin = root的#删除 如何设定SSH远端登入 输入vi /etc/rc.local 增加/etc/init.d/ssh start 输入vi /etc/ssh/sshd_config 修改...
在Kubernetes环境下,Alluxio可以通过StatefulSet或DaemonSet进行部署,确保数据服务的高可用性和持久性。 具体到实践操作中,例如在阿里云上部署Alluxio,用户可以通过配置yaml文件设置OSS的访问密钥和Alluxio根...
黑客通过Master控制被感染的主机(即僵尸网络),启动Daemon执行攻击指令,Client则负责实际的攻击行为,向目标发送大量的数据包,造成目标网络拥堵或资源耗尽。 ##### 2. 攻击特点 - **资源消耗**:DDoS攻击通过...
大众流 使用 Vowpal Wabbit 作为 Node.js 流进行在线机器学习... Child, Not Daemon:为 Vowpal Wabbit 使用衍生的子进程,以实现更简单的交互和 IPC 管理。 例子 来自: var vw = new VowpalWabbitStream({ learning
对于IBus,使用`ibus-daemon -drx`启动。 6. **切换输入法**:使用快捷键(如`Ctrl+Space`)在不同的输入法之间切换,确保五笔输入法已激活。 7. **学习五笔码表**:五笔输入法依赖于特定的编码规则,需要记忆五笔...
文件通常以ISO格式提供,需要使用虚拟光驱软件(如DAEMON Tools)或直接挂载到操作系统中。 2. 安装前的准备: 关闭所有不必要的应用程序,尤其是杀毒软件和防火墙,以免安装过程中出现冲突。检查系统环境变量,...
对于高阶的DaemonSet,除非必要,否则会谨慎使用,并寻求Kubernetes专家的指导。 总结,蚂蚁金服在Kubernetes调度系统上的实践展示了如何在大规模互联网场景下有效管理和优化资源,以及应对高峰流量的挑战。通过...