#多进程

进程间通信之信号量

信号量(semaphore)与已经介绍过的IPC机构(管道、FIFO以及消息队列)不同。它是一个计数器,用于多进程对共享数据对象的访问。为了获得共享资源,进程需要执行下列操作:(1)测试控制该资源的信号量。(2)若此信号量的值为正,则进程可以使用该资源。进程将信号量值减1,表示它使用了一个资源单位。(3)若此信号量的值...
代码星球 ·2021-02-21

进程间通信之消息队列

消息队列是消息的链接表,存放在内核中并由消息队列标识符标识。在本节中,我们把消息队列简称为队列(queue),其标识符为队列ID(queueID)。msgget用于创建一个新队列或打开一个现存的队列。msgsnd将新消息添加到队列尾端。每个消息包含一个正长整型类型字段,一个非负长度以及实际数据字节(对应于长度),所有这...
代码星球 ·2021-02-21

进程间通信之XSI IPC

XSIIPC源自于系统V的IPC功能。有三种IPC我们称作XSIIPC,即消息队列、信号量以及共享存储器,它们之间有很多相似之处。1、标识符和键每个内核中的IPC结构(消息队列、信号量或共享存储段)都用一个非负整数的标识符(identifier)加以引用。例如,为了对一个消息队列发送或取消息,只需要知道其队列标识符。与...
代码星球 ·2021-02-21

进程间通信之FIFO

FIFO有时被称为命名管道。管道只能由相关进程使用,这些相关进程的共同祖先进程创建了管道。但是,通过FIFO,不相关的进程也能交换数据。FIFO是一种文件类型(参考http://www.cnblogs.com/nufangrensheng/p/3501533.html)。stat结构(http://www.cnblog...
代码星球 ·2021-02-21

进程间通信之协同进程

UNIX系统过滤程序从标准输入读取数据,对其进行适当处理后写到标准输出。几个过滤程序通常在shell管道命令行中线性地连接。当一个程序产生某个过滤程序的输入,同时又读取该过滤程序的输出时,则该过滤程序就成为协同进程(coprocess)。Kornshell提供了协同进程。Bourneshell、Bourne-again...
代码星球 ·2021-02-21

进程间通信之popen和pclose函数

常见的操作是创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose。这两个函数实现的操作是:创建一个管道,调用fork产生一个子进程,关闭管道的不使用端,执行一个shell以运行命令,然后等待命令终止。#include<stdio.h>FIL...

进程间通信之管道

管道是UNIX系统IPC的最古老的形式,并且所有UNIX系统都提供此种通信机制。管道有下面两种局限性:(1)历史上,它们是半双工的(即数据只能在一个方向上流动)。现在,某些系统提供全双工管道,但是为了最佳的可移植性,我们决不应预先假定系统使用此特性。(2)它们只能在具有公共祖先的进程之间使用。通常,一个管道由一个进程创...
代码星球 ·2021-02-21

进程间通信

进程之间相互通信的技术——IPC(InterPorcessCommunication)。UNIX系统IPC类型细分有以下9种:半双工管道FIFO全双工管道命名全双工管道消息队列信号量共享存储套接字STREAMS前7种(蓝色字体)IPC通常限于同一台主机的各个进程间的IPC。最后两种(粉红色字体)IPC,即套接字和STR...
代码星球 ·2021-02-21

用于守护进程的出错处理函数

/**Errorroutinesforprogramsthatcanrunasadaemon.*/#include"apue.h"#include<errno.h>/*fordefinitionoferrno*/#include<stdarg.h>/*ISOCvariablearguments*...

守护进程之客户进程-服务器进程模型

守护进程常常用作服务器进程。一般而言,服务器是等待客户进程与其联系的一个进程,客户进程向它提出某种类型的服务要求。...

守护进程之守护进程的惯例

在UNIX系统中,守护进程遵循下列公共惯例:若守护进程使用锁文件,那么该文件通常存放在/var/run目录中。注意,守护进程可能需要具有超级用户权限才能在此目录下创建文件。锁文件的名字通常是name.pid,其中,name是该守护进程或服务的名字。例如cron守护进程锁文件的名字是/var/run/crond.pid。...
代码星球 ·2021-02-21

守护进程之单实例守护进程

为了正常运行,某些守护进程实现为单实例的,也就是在任一时刻只运行该守护进程的一个副本。例如,该守护进程可能需要排它地访问一个设备。在cron守护进程情况下,如果同时有多个实例运行,那么每个副本都可能试图开始某个预定的操作,于是造成该操作的重复执行,这很可能导致出错。如果守护进程需要访问一设备,而该设备驱动程序将阻止多次...
代码星球 ·2021-02-21

守护进程之出错记录

与守护进程有关的一个问题是如何处理出错消息。因为它没有控制终端,所以不能只是简单地写到标准出错上。在很多工作站上,控制台设备运行一个窗口系统,所以我们不希望所有守护进程都写到控制台设备上。我们也不希望每个守护进程将它自己的出错消息写到一个单独的文件中。对系统管理人员而言,如果要关心哪一个守护进程写到哪一个记录文件中,并...
代码星球 ·2021-02-21

守护进程之编程规则

在编写守护进程时需遵循一些基本规则,以便防止产生并不需要的交互作用。下面先说明这些规则,然后给出一个按照这些规则编写的函数daemonize。(1)首先要做的是调用umask将文件模式创建屏蔽字设置为0。由继承得来的文件模式创建屏蔽字可能会拒绝设置某些权限。例如,若守护进程要创建一个组可读、写的文件,而继承的文件模式创...
代码星球 ·2021-02-21

守护进程之守护进程的特征

先来看一些常用的系统守护进程,以及它们怎样和http://www.cnblogs.com/nufangrensheng/p/3513323.html、http://www.cnblogs.com/nufangrensheng/p/3513400.html、http://www.cnblogs.com/nufangren...
代码星球 ·2021-02-21
首页上一页...678910...下一页尾页