用Linux守护进程检测某个程序是否运行2
本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明.
环境:
主机:Fedora12
目标板:SC6410
目标板LINUX内核版本:2.6.36
说明:
第一版程序(参考http://blog.csdn.net/jdh99/article/details/7300641)已经可以正常工作,不过在运行一个月后发现有两台平板出现不能启动的问题,检查后发现是nand flash坏块很多,导致系统不能启动。究其原因,因该是对flash频繁的写操作造成的。上一版本的守护程序每分钟会写操作一次,这样一天的写操作就达千次。在这一版本中,判断需要守护的进程是否存在,是通过读取/proc/pid目录来判断的。参考链接:http://kb.cnblogs.com/a/2360817/
驱动源代码:
daemon_service.c:
//守护进程,守护AlarmInterface进程
//作者:jdh
//时间:2012-4-27
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <syslog.h>
#include <dirent.h>
//程序名字
#define NAME "AlarmInterface"
//要运行的程序
#define RUN_NAME "DuiJiang &"
#define READ_BUF_SIZE 1024
int daemon(int nochdir,int noclose)
{
pid_t pid;
//让init进程成为新产生进程的父进程
pid = fork();
//如果创建进程失败
if (pid < 0)
{
perror("fork");
return -1;
}
//父进程退出运行
if (pid != 0)
{
exit(0);
}
//创建新的会话
pid = setsid();
if (pid < -1)
{
perror("set sid");
return -1;
}
//更改当前工作目录,将工作目录修改成根目录
if (!nochdir)
{
chdir("/");
}
//关闭文件描述符,并重定向标准输入,输出合错误输出
//将标准输入输出重定向到空设备
if (!noclose)
{
int fd;
fd = open("/dev/null",O_RDWR,0);
if (fd != -1)
{
dup2(fd,STDIN_FILENO);
dup2(fd,STDOUT_FILENO);
dup2(fd,STDERR_FILENO);
if (fd > 2)
{
close(fd);
}
}
}
//设置守护进程的文件权限创建掩码
umask(0027);
return 0;
}
//存在返回1,不存在返回0
int judge_pid_exist(char* pidName)
{
DIR *dir;
struct dirent *next;
int i = 0;
FILE *status;
char buffer[READ_BUF_SIZE];
char name[READ_BUF_SIZE];
///proc中包括当前的进程信息,读取该目录
dir = opendir("/proc");
if (!dir)
{
printf("Cannot open /proc\n");
return 0;
}
//遍历
while ((next = readdir(dir)) != NULL)
{
//跳过"."和".."两个文件名
if ((strcmp(next->d_name, "..") == 0) || (strcmp(next->d_name, ".") == 0))
{
continue;
}
//如果文件名不是数字则跳过
if (!isdigit(*next->d_name))
{
continue;
}
//判断是否能打开状态文件
sprintf(buffer,"/proc/%s/status",next->d_name);
if (!(status = fopen(buffer,"r")))
{
continue;
}
//读取状态文件
if (fgets(buffer,READ_BUF_SIZE,status) == NULL)
{
fclose(status);
continue;
}
fclose(status);
//读取PID对应的程序名,格式为Name: 程序名
sscanf(buffer,"%*s %s",name);
//判断程序名是否符合预期
if (strcmp(name,pidName) == 0)
{
//符合
closedir(dir);
return 1;
}
}
closedir(dir);
return 0;
}
int main(int argc,char *argv[])
{
int fd = 0;
char buf[100];
//开启守护进程
daemon(0,0);
while (1)
{
//打开日志
openlog(argv[0],LOG_CONS|LOG_PID,LOG_USER);
//判断是否有程序文件运行
if (judge_pid_exist(NAME))
{
syslog(LOG_INFO,"jdh success:)!!!!!!!!!!");
//printf("hello,jdh,exist\n");
}
else
{
syslog(LOG_INFO,"jdh fail:(!!!!!!!!!!");
//运行程序
system(RUN_NAME);
//printf("hello,jdh,oh,no\n");
}
//休眠
sleep(60);
}
//关闭日志
closelog();
return 0;
}
分享到:
相关推荐
2. **检测程序是否运行**: 可以通过检查进程是否存在来判断目标程序是否运行。在Linux中,可以使用`system()`函数或者`popen()`来执行命令行操作,例如`pgrep`命令来查找指定的进程。 ```cpp #include #include ...
Linux守护进程是Linux系统中的一种特殊进程,它们在系统启动后独立运行,通常与用户的交互较少,负责执行长期持续的任务,如网络服务、系统监控、定时任务等。这些守护进程在后台持续工作,确保系统的正常运行和服务...
如果某个程序意外崩溃或被非正常终止,进程守护工具会自动检测到并重新启动该程序,保证服务的连续性。这在运行关键业务应用或服务的环境中是必不可少的。进程守护可能包含在系统服务中,或者可以通过第三方应用程序...
2. **java.nio.channels.FileLock**:Java新I/O(NIO)中的类,允许对文件进行加锁操作,用于检测某个文件是否正被另一个进程占用,从而判断程序状态。 3. **ProcessBuilder与Process**:这两个类允许Java程序调用...
守护进程的主要职责是在后台持续运行并监控某个应用程序或服务的状态,一旦检测到该应用程序出现异常退出的情况,守护进程能够自动重启它,从而确保关键业务的连续性和稳定性。 #### 关键概念解释 1. **批处理脚本...
本篇文章将深入探讨一个经典的Linux ARP解析程序的实现,包括守护进程的编写和ARP处理。 首先,我们需要了解ARP的工作原理。当主机需要向某个IP地址发送数据时,如果目标IP不在本地缓存中,主机就会广播一个ARP请求...
在Linux环境中,使用PHP进行程序运行状态的判断是常见的需求,尤其在自动化脚本和守护进程管理中。这里介绍的两种方法可以帮助我们有效地检查某个PHP程序是否已经在运行,避免资源的浪费和冲突。 方法一:利用Linux...
在Linux中,使用`cron`守护进程来调度计划任务。`cron`配置文件中的格式为“分钟 小时 日 月 周命令”。因此,要在每周日的下午四点十五分自动执行任务,应设置为`15 16 * * 0`。因此,正确答案是`d、15 16 0 * *`。...
对于守护进程而言,此信号可用于触发重新读取配置文件的操作。 - **默认行为**:终止进程。 - **示例**:`wget` 程序能够捕获并忽略此信号,从而实现即使用户退出登录也能继续下载的功能。 **2) SIGINT - 中断信号*...
6. **RedFlag HA Daemon (Service)**:HA守护进程,负责处理集群的核心功能,如心跳检测、故障切换等。 7. **RedFlag HA Monitor Daemon (Service)**:监控守护进程,用于实时监控系统状态。 8. **Agent Scripts**...
4. **性能分析**:监控程序运行时的文件访问,以了解程序的行为和优化潜在点。 5. **安全监控**:监视系统关键文件的变更,及时发现并处理异常活动。 综上所述,`inwatch` 是一个强大的工具,利用 inotify 机制...
- **启动服务**:根据`/etc/inittab`文件和`/etc/rc.d/rc目录中的脚本,`init`进程会启动各种服务,这些服务包括系统守护进程、网络服务等。 - **打开控制台**:系统会打开字符控制台(如tty1至tty6)和图形控制台...
在Linux系统中,遇到CPU使用率达到异常高的情况,如700%,这通常是由于某个或某些进程在执行过程中过度消耗CPU资源导致的。在这种情况下,解决问题的第一步是识别出问题进程,并尝试理解其行为和来源。 1. **定位...
当系统检测到某个应用程序崩溃时,`debuggerd`会自动启动并尝试捕捉崩溃时的信息,以便进行调试分析。这个过程通常包括保存崩溃时的内存快照、调用堆栈信息等数据。这对于定位问题根源、修复bug具有重要意义。 ####...
由于驱动程序运行在内核空间,其调试方法与用户空间的应用程序有所不同。本文旨在介绍如何在Linux内核中启用调试选项,并探讨几种常用的调试技术。 #### 二、在内核中开启调试选项 ##### 2.1 配置内核编译选项 ...