信号实现任务管理

2021-03-11  本文已影响0人  一路向后

1.源码实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
#include <syslog.h>
#include <signal.h>

static short skip = 0;

void skipwork(int dunno)
{
    skip = 1;
}

void cwork(int dunno)
{
    skip = 0;
}

int sub_work1(short skip)
{
    time_t now = 0;
    time(&now);

    if(!skip)
    {
        syslog(LOG_USER|LOG_INFO,"do work 1: \t%s\t\t\n",ctime(&now));
        sleep(1);
        return 0;
    }

    syslog(LOG_USER|LOG_INFO,"skip work 1: \t%s\t\t\n",ctime(&now));

    return -1;
}

int sub_work2(short skip)
{
    time_t now = 0;
    time(&now);

    if(!skip)
    {
        syslog(LOG_USER|LOG_INFO,"do work 2: \t%s\t\t\n",ctime(&now));
        sleep(1);
        return 0;
    }

    syslog(LOG_USER|LOG_INFO,"skip work 2: \t%s\t\t\n",ctime(&now));

    return -1;
}

int sub_work3(short skip)
{
    time_t now = 0;
    time(&now);

    if(!skip)
    {
        syslog(LOG_USER|LOG_INFO,"do work 3: \t%s\t\t\n",ctime(&now));
        sleep(1);
        return 0;
    }

    syslog(LOG_USER|LOG_INFO,"skip work 3: \t%s\t\t\n",ctime(&now));

    return -1;
}

int sub_work4(short skip)
{
    time_t now = 0;
    time(&now);

    if(!skip)
    {
        syslog(LOG_USER|LOG_INFO,"do work 4: \t%s\t\t\n",ctime(&now));
        sleep(1);
        return 0;
    }

    syslog(LOG_USER|LOG_INFO,"skip work 4: \t%s\t\t\n",ctime(&now));

    return -1;
}

int sub_work5(short skip)
{
    time_t now = 0;
    time(&now);

    if(!skip)
    {
        syslog(LOG_USER|LOG_INFO,"do work 5: \t%s\t\t\n",ctime(&now));
        sleep(1);
        return 0;
    }

    syslog(LOG_USER|LOG_INFO,"skip work 5: \t%s\t\t\n",ctime(&now));

    return -1;
}

int work()
{
    sub_work1(skip);
    sub_work2(skip);
    sub_work3(skip);
    sub_work4(skip);
    sub_work5(skip);

    return 0;
}

int main()
{
    time_t now = 0;

    daemon(1, 0);

    signal(SIGCONT, cwork);
    signal(SIGTTOU, skipwork);

    while(1)
    { 
        sleep(1);
        work();
    }

    return 0;
}

2.编译源码

$ gcc -o work work.c

3.运行程序

$ ./work

4.查看日志/var/log/message

Mar  9 05:00:52 bogon work: do work 1: #011Tue Mar  9 05:00:52 2021#012#011#011
Mar  9 05:00:53 bogon work: do work 2: #011Tue Mar  9 05:00:53 2021#012#011#011
Mar  9 05:00:54 bogon work: do work 3: #011Tue Mar  9 05:00:54 2021#012#011#011
Mar  9 05:00:55 bogon work: do work 4: #011Tue Mar  9 05:00:55 2021#012#011#011
Mar  9 05:00:56 bogon work: do work 5: #011Tue Mar  9 05:00:56 2021#012#011#011
Mar  9 05:00:58 bogon work: do work 1: #011Tue Mar  9 05:00:58 2021#012#011#011
Mar  9 05:00:59 bogon work: do work 2: #011Tue Mar  9 05:00:59 2021#012#011#011
Mar  9 05:01:00 bogon work: do work 3: #011Tue Mar  9 05:01:00 2021#012#011#011
Mar  9 05:01:01 bogon work: do work 4: #011Tue Mar  9 05:01:01 2021#012#011#011
Mar  9 05:01:02 bogon work: do work 5: #011Tue Mar  9 05:01:02 2021#012#011#011

5.跳过任务

$ kill -SIGTTOU 2331

6.查看日志

Mar  9 05:01:39 bogon work: skip work 1: #011Tue Mar  9 05:01:39 2021#012#011#011
Mar  9 05:01:39 bogon work: skip work 2: #011Tue Mar  9 05:01:39 2021#012#011#011
Mar  9 05:01:39 bogon work: skip work 3: #011Tue Mar  9 05:01:39 2021#012#011#011
Mar  9 05:01:39 bogon work: skip work 4: #011Tue Mar  9 05:01:39 2021#012#011#011
Mar  9 05:01:39 bogon work: skip work 5: #011Tue Mar  9 05:01:39 2021#012#011#011
Mar  9 05:01:40 bogon work: skip work 1: #011Tue Mar  9 05:01:40 2021#012#011#011
Mar  9 05:01:40 bogon work: skip work 2: #011Tue Mar  9 05:01:40 2021#012#011#011
Mar  9 05:01:40 bogon work: skip work 3: #011Tue Mar  9 05:01:40 2021#012#011#011
Mar  9 05:01:40 bogon work: skip work 4: #011Tue Mar  9 05:01:40 2021#012#011#011
Mar  9 05:01:40 bogon work: skip work 5: #011Tue Mar  9 05:01:40 2021#012#011#011

7.继续任务

$ kill -SIGCONT 2331
上一篇 下一篇

猜你喜欢

热点阅读