总控节点防瘫痪

来源:互联网 发布:盛田屋豆腐面膜知乎 编辑:程序博客网 时间:2024/05/17 08:40

初学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服务进程。



原创粉丝点击