量化交易之linux高级篇 - 守护进程的写法

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>

#include <sys/stat.h>
#include <fcntl.h>


// 创建守护进程
int ngx_daemon() {

    int fd;

    switch(fork()) {
    case -1:
        // 创建子进程失败, 这里可以写日志...
        return -1;
    case 0:
        // 子进程, 走到这里直接break
        break;
    default:
        // 父进程, 直接退出
        exit(0);
    }

    // 只有子进程流程才能走到这里
    if (setsid() == -1) { // 脱离终端, 终端关闭将与此子进程无关
        // 记录错误日志...
        return -1;
    }
    umask(0); // 设置为0, 不要让它来限制文件权限, 以免引起混乱

    fd = open("/dev/null", O_RDWR); // 打开黑洞设备 (以读写方式打开)
    if (fd == -1) {
        // 记录错误日志...
        return -1;
    }

    if (dup2(fd, STDIN_FILENO) == -1) { // 先关闭 STDIN_FILENO (这是规矩, 已经打开的描述符, 改动之前先关闭), 类似于指针指向null, 让/dev/null成为标准输入
        // 记录错误日志...
        return -1;
    }

    if (dup2(fd, STDOUT_FILENO) == -1) { // 先关闭 STDOUT_FILENO, 类似于指针指向 null, 让 /dev/null 成为标准输出
        // 记录错误日志...
        return -1;
    }

    if (fd > STDERR_FILENO) { // fd 应该是 3, 这里应该成立
        if (close(fd) == -1) { // 释放资源, 这样这个文件描述符就可以被复用; 不然这个数字(文件描述符)会被一直占用
            // 记录错误日志...
            return -1;
        }
    }

    return 1;
}

int main(int argc, char *argv[]) {

    if (ngx_daemon() != 1) {
        // 创建守护进程失败, 可以做失败后的处理(如 写日志等);
        return 1;
    } else {
        // 创建守护进程成功, 执行守护进程中要做的工作

        for (;;) {
            printf("sleep 1s, process id: %d!\n", getpid()); // 即使打印也没用, 现在标准输出指向黑洞(/dev/null), 打印不出任何结果(不显示任何结果)
            sleep(1);
        }
    }

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值