总控节点防偏瘫

总控节点防瘫痪

初学linux开发,总结下。若有错误,敬请指正,谢谢。

1.主备模式

配置两个服务进程,一个主,另一个备,主和备都打开服务。客户端把主和备的地址都配上,如果发现往主服务进程发送请求,connect不到,推测主服务进程可能瘫痪,就往备用服务进程发送请求。对于这种方式,笔者尚未实践过。只停留在理论阶段。

缺点需要手动修复主服务进程。

2. fork + waitpid

while (1) {
        pid_t pid;
        if((pid = fork()) < 0) {
            perror("fork:");
        } else if (pid == 0) {
            printf("reboot SysCtrlNode\n");
            execl("./SysCtrlNode", "./SysCtrlNode", "NULL");
            perror("execlv:");
            exit(1);
        } else if (pid > 0) {
            waitpid(pid, NULL, 0);
        }
    }
笔者自己写了个小项目就使用到了此种方式。监控进程作为父进程,一旦wait到子进程结束,立即fork出子进程,execl服务进程。