Unix系统中的syslogd守护进程通常由某个系统初始化脚本启动,而且在系统工作期间一直运行。

源自Berkeley的syslogd实现在启动时执行以下步骤。

(1)读取配置文件。通常为/etc/syslog.conf的配置文件指定本守护进程可能收取的各种日志消息,应该如何处理。

(2)创建一个Unix域数据报套接字,给它捆绑路径名/var/run/log

(3)创建一个UDP套接字,给它捆绑端口514。

(4)打开路径名/dev/klog。

一、syslog函数

#include <syslog.h>

void syslog(int prioriry, const char *message, ...);
priority:级别level和设施facility两者的组合
message参数类似printf的格式串,不过增加了%m,它将被替换成与当前errno值对应的出错消息。

日志消息的level可以是0~7,他们按从高到低的顺序排列的。如果发送者未指定level值,那就默认为LOG_NOTICE。

日志消息包含一个用于标识消息发送进程类型的facility。默认LOG_USER

举例来说,当rename意外失败时,守护进程可以执行以下调用:

syslog(LOG_INFO|LOG_LOCAL2, "rename(%s, %s):%m", file1, file2);

#include <syslog.h>

void openlog(cosnt char *ident, int options, int facility);
void closelog(void);
ident:有syslog关于每个日志消息之前的字符串。通常的值是程序名
options:一个或多个常值的逻辑或构成
facility:

options的参数

二、守护进程

下面有一个daemon_init函数,调用它可使一个进程变成守护进程。

 #include "unp.h"
#include <syslog.h> #define MAXFD 64 extern int daemon_proc; /* defined in error.c */ int
daemon_init(const char *pname, int facility)
{
int i;
pid_t pid; if((pid = Fork()) < )
return(-);
else if(pid)
_exit(); /* parent terminates */
/* child 1 continues ... */
if(setsid() < ) /* become session leader */
return(-);
Signal(SIGHUP, SIG_IGN);
if((pid = Fork()) < )
return(-);
else if(pid)
_exit(); /* child 1 terminates */
/* child 2 continues ... */
daemon_proc = ; /* for err_XXX() functions */
chdir("/"); /* change working directory */
/* close off file descriptors */
for(i=;i<MAXFD;i++)
close(i);
/* redirect stdin, stdout, and stderr to /dev/null */
open("/dev/null", O_RDONLY);
open("/dev/null", O_RDWR);
open("/dev/null", O_RDWR);
openlog(pname, LOG_PID, facility);
return();
}
  • 首先调用fork,然后终止父进程,留下子进程继续运行。如果进程是以shell命令方式从前台启动,当父进程终止时,shell就认为命令已完成。这可以使子进程运行在后台。子进程继承了父进程的进程组号,但它拥有自己的进程号。这就保证了这个子进程不是进程组头。
  • setsid创建一个新的登录会话。这个进程变成新会话的会话头和新进程组的组长,不再有控制终端。
  • 忽略SIGHUP信号并再次调用fork,再次调用fork的目的是确保本守护进程将来即使打开了一个终端设备,也不会自动获得控制终端。
  • 为错误处理函数设置标识
  • 改变工作目录
  • 关闭所有打开的文件描述符
  • 将stdin、stdout、stderr重定向到/dev/null
  • 使用syslog处理错误

三、inetd守护进程

inetd守护进程的工作流程

  1. 启动时读/etc/inetd.conf文件并给文件中指定的所有服务创建一个响应类型的套接口。inetd能处理的服务器的数目依赖于它最多能创建的描述字的数目。每个新创建的套接口都被加入到select调用所用到的描述字集中。
  2. 为每个套接口调用bind,给它们捆绑服务器的众所周知端口和通配地址。它们的TCP或UDP端口号时通过调用getservbyname获得的,其中使用了配置文件中的service-name和protocol作为参数。
  3. 对TCP套接口调用listen,以接受外来的连接请求。对数据报套接口则不做这一步。
  4. 所有套接口建立后,调用select等待这些套接口变为可读。当在TCP套接口上到来一个新的连接请求或UDP套接口上到来一个数据报时他们会变成可读。inetd在大部分时间里阻塞在select调用上,等待有一个套接口变成可读。
  5. select返回一个可读的套接口后,如果是一个TCP套接口,就调用accept接受这个新的连接。
  6. inetd守护进程fork,由子进程处理服务请求。

UNP学习第13章 守护进程和inetd超级服务器的更多相关文章

  1. Unix网络编程代码 第13章 守护进程和inetd超级服务器

    1. 概述 守护进程是在后台运行且不与任何控制终端关联的进程.unix系统通常有很多守护进程在后台运行,执行不同的管理任务.    守护进程没有控制终端通常源于它们由系统初始化脚本启动.然而守护进程也 ...

  2. 《Unix 网络编程》13:守护进程和 inetd 超级服务器

    守护进程和 inetd 超级服务器 ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...

  3. UNP学习笔记(第十三章 守护进程和inetd超级服务器)

    关于守护进程可以查看apue的笔记 http://www.cnblogs.com/runnyu/p/4645046.html daemon_init函数 下面给出名为daemon_init函数,通过调 ...

  4. APUE读书笔记-第13章-守护进程

    第13章 守护进程 13.1 引言 *守护进程也称精灵进程(daemon)是生存期较长的一种进程.它们常常在系统自举时启动,仅在系统关闭时才终止.因为它们没有控制终端,所以说它们是在后台运行的.UNI ...

  5. 守护进程和inetd超级服务器

    守护进程: 1 系统启动时,由系统初始化脚本启动.一般在/etc目录下,或者以/etc/rc开头的目录 2 许多网络服务器由inetd超级服务器启动 3 cron守护进程按规则定期执行一些程序 4 用 ...

  6. UNP第13章——守护进程

    1. 守护进程的启动方法 (1)系统初始化脚本启动,在系统启动阶段,按照如/etc目录或/etc/rc开头的目录中的某些脚本启动,这些守护进程一开始就有超级用户权限.如inetd,cron,Web服务 ...

  7. UNIX环境高级编程 第13章 守护进程

    守护进程daemon是一种生存周期很长的进程.它们通常在系统引导时启动,在系统关闭时终止.守护进程是没有终端的,它们一直在后台运行. 守护进程的特征 在Linux系统中,可以通过命令 ps -efj ...

  8. 《Unix环境高级编程》读书笔记 第13章-守护进程

    1. 引言 守护进程是生存期长的一种进程.它们常常在系统引导装入时启动,仅在系统关闭时才终止.它们没有控制终端,在后台运行. 本章说明守护进程结构.如何编写守护进程程序.守护进程如何报告出错情况. 2 ...

  9. UNP总结 Chapter 12~14 IPv4与IPv6的互操作性、守护进程和inet超级服务器、高级I/O函数

    一.IPv4与IPv6的互操作性 1.IPv4客户与IPv6服务器 拥有双重协议栈的主机的一个基本特性就是:其上运行的IPv6服务器既能应付IPv4客户,又能应付IPv6客户.这是通过使用IPv4映射 ...

随机推荐

  1. mybatis源码分析之06二级缓存

    上一篇整合redis框架作为mybatis的二级缓存, 该篇从源码角度去分析mybatis是如何做到的. 通过上一篇文章知道,整合redis时需要在FemaleMapper.xml中添加如下配置 &l ...

  2. SQL_2008安装教程(完整版)

    Win 7 win xp系统中SQL2008安装注意事项一:SQL2008 镜像下载地址 http://download.microsoft.com/download/4/C/4/4C402E48-0 ...

  3. iview的Affix组件滚动时没有按照预期固定

    业务场景 新建任务的页面,创建和重置按钮,页面没有滚动时,直接跟在内容下面:页面滚动时,固定于页面下方,不随内容进行滚动,以方便按钮的操作.效果如下: 问题以及解决办法 直接使用<Affix : ...

  4. vue中img图片加载中以及加载失败显示默认图片问题

    加载中默认图片:主要是onload事件监听,data中定义变量 imgSrc :require('./default.png'): <div class="per-pic" ...

  5. [CSP-S模拟测试]:Star Way To Heaven(最小生成树Prim)

    题目描述 小$w$伤心的走上了$Star\ way\ to\ heaven$. 到天堂的道路是一个笛卡尔坐标系上一个$n\times m$的长方形通道(顶点在$(0,0)$和$(n,m)$),小$w$ ...

  6. Cent OS (二)常用的命令介绍

    1. 常用的Linux命令   序号 命令 对应英文 作用 01 ls list 查看当前文件夹下的内容 02 pwd print work directory 查看当前所在的文件夹 03 cd [目 ...

  7. bzoj 2242: [SDOI2011]计算器 & BSGS算法笔记

    这题的主要难点在于第三问该如何解决 于是就要知道BSGS是怎样的一种方法了 首先BSGS是meet in the middle的一种(戳下面看) http://m.blog.csdn.net/blog ...

  8. 深入了解JAVA基础(面试)

    I.常用类型与编码类问题:        1.Java中的基本类型有什么?            byte.short.int.long.float.double.chart.boolean这八种,这 ...

  9. ATT&CK实战系列 红队实战(一)————环境搭建

    首先感谢红日安全团队分享的靶机实战环境.红队实战系列,主要以真实企业环境为实例搭建一系列靶场,通过练习.视频教程.博客三位一体学习. 靶机下载地址:http://vulnstack.qiyuanxue ...

  10. vue2.0---最近总结

    1.用脚手架给运维部门搞了个小东西,重新温习了一遍牛逼又方便的vue-cli. webpack的东西不必关心太多,而且webpack最近也是出了最新的4.0版本.还是改变挺多的,对一些代码的格式要求更 ...