原创 在Unix/Linux下防止二重启动(C语言)
2009-02-09 15:23
316 查看
在Unix/Linux下为了保证在同一时间内某个程序只有一个实例在运行,
即防止二重启动的发生,采用的方法除了用锁定文件之外,还可以用该程
序在系统运行时,在进程表中的信息来进行控制(ps命令看到的内容)。
方法有两种:
第一种是:用进程的command字符串进行防止二重启动的控制
实现步骤:
(1)定义应用程序的名的字符串变量
char EXE_NAME[255]=" app ";
(2)可以用exec或popen去执行ps命令,我这里用popen为例
为了使用popen需要引入#include <unistd.h>;
char PS_CMD[256];
char str[256];
FILE fd;
int bRun = 0;
strcpy(PS_CMD, "ps -ef|grep ");
strcat(PS_CMD, EXE_NAME);
if((fd = popen(PS_CMD, "r")) == NULL) {
printf("call popen failed/n");
return;
} else {
while(fgets(str, 255, fd) != NULL) {
printf("%s/n",str);
bRun = 1;
break;
}
}
if( bRun == 1) {
/* 已经有一个实例在运行 */
exit(0);
}
/* 执行程序的功能 */
这种方法的缺点:
(1)如果其他程序的主执行文件名和要执行的程序相同,并正在执行,那么
本来要执行的程序可以被执行,但却不能执行;
(2)如果本程序是用全路径,或程序名比较长,用ps命令时,输出结果可能会被截短,这样可能会在grep时,被能匹配到要执行文件名,而错误判断这个程序还没有运行,但实际上已经运行了;
第二种是:用进行的PID进行防止二重启动的控制
(1)定一个放置本程序执行的PID的文件
char PID_FILE[255] = "APP.PID";
(2)如果APP.PID文件不存在,则本程序没有运行,创建该文件,并把当前运行程序的PID写入该文件
pid_t pid = -1;
pid = getpid();
/* 把pid写入APP.PID文件 */
/* 执行程序的功能 */
执行(4)
(3)如果APP.PID文件存在,则从APP.PID文件中读取PID值和系统进程表中正在运行进程的PID进行比较,
[
/* 从APP.PID文件中读取PID值,放到PID_Value中 */
strcpy(PS_CMD, "ps -ef|awk '{print $2}'|grep ");
strcat(PS_CMD, PID_Value);
/* 在进程表中查找PID_Value值 */
if((fd = popen(PS_CMD, "r")) == NULL) {
printf("call popen failed/n");
return;
} else {
while(fgets(str, 255, fd) != NULL) {
printf("%s/n",str);
bRun = 1;
break;
}
}
]
如果在进程表中不存在,则表示本程序未被运行,执行(2);
如果在进程表中存在,则执行(4)
(4)退出程序。
我认为第二种方法比较好,这也是一些服务程序用来控制多次启动的常用方法。
即防止二重启动的发生,采用的方法除了用锁定文件之外,还可以用该程
序在系统运行时,在进程表中的信息来进行控制(ps命令看到的内容)。
方法有两种:
第一种是:用进程的command字符串进行防止二重启动的控制
实现步骤:
(1)定义应用程序的名的字符串变量
char EXE_NAME[255]=" app ";
(2)可以用exec或popen去执行ps命令,我这里用popen为例
为了使用popen需要引入#include <unistd.h>;
char PS_CMD[256];
char str[256];
FILE fd;
int bRun = 0;
strcpy(PS_CMD, "ps -ef|grep ");
strcat(PS_CMD, EXE_NAME);
if((fd = popen(PS_CMD, "r")) == NULL) {
printf("call popen failed/n");
return;
} else {
while(fgets(str, 255, fd) != NULL) {
printf("%s/n",str);
bRun = 1;
break;
}
}
if( bRun == 1) {
/* 已经有一个实例在运行 */
exit(0);
}
/* 执行程序的功能 */
这种方法的缺点:
(1)如果其他程序的主执行文件名和要执行的程序相同,并正在执行,那么
本来要执行的程序可以被执行,但却不能执行;
(2)如果本程序是用全路径,或程序名比较长,用ps命令时,输出结果可能会被截短,这样可能会在grep时,被能匹配到要执行文件名,而错误判断这个程序还没有运行,但实际上已经运行了;
第二种是:用进行的PID进行防止二重启动的控制
(1)定一个放置本程序执行的PID的文件
char PID_FILE[255] = "APP.PID";
(2)如果APP.PID文件不存在,则本程序没有运行,创建该文件,并把当前运行程序的PID写入该文件
pid_t pid = -1;
pid = getpid();
/* 把pid写入APP.PID文件 */
/* 执行程序的功能 */
执行(4)
(3)如果APP.PID文件存在,则从APP.PID文件中读取PID值和系统进程表中正在运行进程的PID进行比较,
[
/* 从APP.PID文件中读取PID值,放到PID_Value中 */
strcpy(PS_CMD, "ps -ef|awk '{print $2}'|grep ");
strcat(PS_CMD, PID_Value);
/* 在进程表中查找PID_Value值 */
if((fd = popen(PS_CMD, "r")) == NULL) {
printf("call popen failed/n");
return;
} else {
while(fgets(str, 255, fd) != NULL) {
printf("%s/n",str);
bRun = 1;
break;
}
}
]
如果在进程表中不存在,则表示本程序未被运行,执行(2);
如果在进程表中存在,则执行(4)
(4)退出程序。
我认为第二种方法比较好,这也是一些服务程序用来控制多次启动的常用方法。
相关文章推荐
- 在Unix/Linux下防止二重启动(C语言)
- 在Unix/Linux下防止二重启动(C语言)
- 教你配置Linux/Unix开发环境,防止公司源代码泄漏外泄
- c语言代码格式化工具(unix/linux)
- 详解C语言开发unix/Linux下安全套接字(SSL)的TCP服务端程序
- Linux下Tomcat开机自动启动 原创 2014年07月18日 12:32:49 标签:Linux /tomcat /shell /启动 22095 Linux下tomcat开机自动启动有两种方法
- 【原创】C语言处理文件数据(3) 分类: Linux --- C 2014-11-04 10:13 74人阅读 评论(0) 收藏
- 新手看招 Unix和Linux下C语言学习指南
- 【mysql】linux下启动mysql服务报错: Another MySQL daemon already running with the same unix socket.
- Linux内核源码分析--内核启动之(3)Image内核启动(C语言部分)(Linux-3.0 ARMv7)
- 新手看招 Unix和Linux下C语言学习指南
- UNIX高级环境编程: 终端登录过程-远程登录-进程组-Session-Linux启动过程-dup与重定向-守护进程
- Unix和Linux下C语言学习指南
- linux启动优化:mdev -s自从创建节点,启动时间比较长(大概5-6s)解决办法(原创)
- UNIX-LINUX编程实践教程->第八章->实例代码注解->写一个简单的shell->在shell中启动另一个程序
- [原创]Linux实现服务延迟启动
- Linux启动过程的C语言代码分析
- 定制android启动界面(转http://linux.chinaunix.net/techdoc/install/2009/05/25/1114496.shtml)
- Weblogic在Linux和Unix下后台启动脚本
- [原创]Linux系统启动过程分析