下面是安装两个信号的例子:
信号例子:
进程A:安装信号SIGUSR1,SIGUSR2
收到SIGUSR1:启动火车票系统(这里可以是任一一个程序);
收到SIGUSR2:重启系统(打印自己的PID);
进程B:接收用户键盘输入
输入:
start: 发送SIGUSR1给进程A
restart:发送SIGUSR2给进程A
bye:退出进程
提示:
1、用2个不相关的进程,不用父子进程,也就是说打开2个终端,分别
运行进程A和进程B。发送的时候先打开A打印A的PID,然后B发送kill填写A的PID,
或者可以把A的PID写到文件,B从文件中去读取A的PID
2、杀死进程提示:
char cmd[100]={0};
sprintf(cmd,"kill %d",pid);//杀死火车票系统PID
system(cmd);//此处的kill与发送信号的kill不一样,用ps pid可以查看是否杀死pid
3、用之前学过的execl启动另外一个程序
这个信号例子需要写两个函数,一个发送,一个接受;
send.c
#include <string.h>
#include <stdlib.h>
int main()
{
char buf[1024] ={0};
int pid =0;
int fd = open("rcv_pid.ini",O_RDONLY);
int ret = read(fd,&pid,4);
REPEAT:
printf("start/restart\n");
scanf("%s",buf);
if(strcmp(buf,"start")==0)
{
printf("sent to pid=%d SIGUSR1\n",pid);
kill(pid,SIGUSR1);
}
else if(strcmp(buf,"restart")==0)
{
printf("sent to pid=%d SIGUSR2\n",pid);
kill(pid,SIGUSR2);
}
goto REPEAT;
}
receive.c
#include <stdio.h>
#include <signal.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
int g_stu_pid = 0;
void interrupt_service_rountine(int signo)
{
switch(signo)
{
case SIGUSR1://start
{
int pid = 0;
pid = fork();
if(pid == 0)
{
//g_stu_pid = getpid();//%%%%%
execl("/root/Desktop/logs/train/install","install",NULL);
}
else if(pid >0)
{
g_stu_pid = pid;
}
}
break;
case SIGUSR2://restart
{
char cmd[100]={0};
sprintf(cmd,"kill %d",g_stu_pid);
system(cmd);//kill stu's pid
int pid = 0;
pid = fork();
if(pid == 0)
{
//g_stu_pid = getpid();//%%%%%自己启动程序的路径
execl("/root/Desktop/logs/train/install","install",NULL);
}
else if(pid >0)
{
g_stu_pid = pid;
}
}
break;
}
}
int main()
{
signal(SIGUSR1,interrupt_service_rountine);
signal(SIGUSR2,interrupt_service_rountine);
int pid = getpid();
int fd = 0;
fd = open("rcv_pid.ini",O_CREAT|O_WRONLY|O_TRUNC,0777);
write(fd,&pid,4);
printf("rcv pid is %d\n",pid);
close(fd);
while(1)
{
sleep(10);
}
}
输入send终端输入start时,会执行程序如图所示:
接收端会出现火车票订票系统的程序启动,
当输入restart时,会关掉该程序再重新启动,
用户可以用ps pid命令查看是否杀死该进程。