【Linux、C】服务程序的调度

这篇具有很好参考价值的文章主要介绍了【Linux、C】服务程序的调度。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这一节中用到的技术点有:信号、多进程、exec函数 

exec函数族

【Linux、C】服务程序的调度,C++气象数据中心,linux,运维,服务器

exec的本质

exec是用参数中指定的程序替换了当前进程的正文段、数据段、堆和栈

如果调用失败会继续运行当前进程文章来源地址https://www.toymoban.com/news/detail-811707.html

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>

int main(int argc, char *argv[])
{
    if (argc < 3)
    {
        printf("Using:./procctl timetvl program argv ...\n");
        printf("Example:~/project/tools2/c/procctl 60 ~/project/idc2/c/crtsurfdata5 ~/project/idc2/init/stcode.ini ~/tmp/surfdata/ ~/log/idc/crtsurfdata5.log xml,json,csv \n\n");

        printf("本程序是服务程序的调度程序,周期性启动服务程序或shell脚本。\n");
        printf("timetvl 运行周期,单位:秒。被调度的程序运行结束后,在timetvl秒后会被procctl重新启动。\n");
        printf("program 被调度的程序名,必须使用全路径。\n");
        printf("argvs   被调度的程序的参数。\n");
        printf("注意,本程序不会被kill杀死,但可以用kill -9强行杀死。\n\n\n");

        return -1;
    }

    // 关闭信号和IO,本程序不希望被打扰。
    for (int i = 0; i < 64; i++)
    {
        signal(i, SIG_IGN);
        close(i);
    }

    // 生成子进程,父进程退出,让程序运行在后台,由系统1号进程托管。
    if (fork() != 0)
        exit(0);

    // 启用SIGCHLD信号,让父进程可以wait子进程退出的状态。
    signal(SIGCHLD, SIG_DFL);

    char *pargv[argc];
    for (int i = 2; i < argc; i++)
        pargv[i - 2] = argv[i];

    pargv[argc - 2] = NULL;
    while (true)
    {
        if (fork() == 0)
        {
            execv(argv[2], pargv);
            exit(0);
        }
        else
        {
            int status;
            wait(&status);
            sleep(atoi(argv[1]));
        }
    }
}

到了这里,关于【Linux、C】服务程序的调度的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包