linux 线程存活状态监控,不存在就重启

2024-05-30 15:08

本文主要是介绍linux 线程存活状态监控,不存在就重启,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直接上代码

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <sys/time.h>
#include <string.h>
#include<unistd.h>
#include <signal.h>
#include <errno.h>/*线程变量*/
pthread_t thread[3];
pthread_mutex_t mut;void *thread1()
{/*线程互斥锁*///pthread_mutex_lock(&mut);//pthread_mutex_unlock(&mut);int i = 0;while(i++ < 10) {printf("111\n");sleep(1);}pthread_exit(NULL);
}/*定时函数*/
void sigalrm_func(int sig)
{alarm(2); /*改为定时2s*/printf("222\n");
}void *thread2()
{/*定时1s,处理函数为*/signal(SIGALRM, sigalrm_func);alarm(1);while(1);/*线程互斥锁*///pthread_mutex_lock(&mut);//pthread_mutex_unlock(&mut);pthread_exit(NULL);
}void thread_wait(int i)
{/*等待线程结束*/if(thread[i] != 0) {pthread_join(thread[i],NULL);}
}/*pthread_kill的返回值:成功(0) 线程不存在(ESRCH) 信号不合法(EINVAL)*/
void test_pthread(int i) 
{int pthread_kill_err;pthread_kill_err = pthread_kill(thread[i],0);if(pthread_kill_err == ESRCH) {printf("pthread[%d] no existence or withdrawal.\n", i);pthread_join(thread[i],NULL);sleep(10);if((pthread_create(&thread[i], NULL, switch_control_thread, NULL)) != 0) {printf("[sqlite] -- switch_control_thread create error!\n");}}else if(pthread_kill_err == EINVAL)printf("unlawful transmission of signals.\n");elseprintf("pthread[%d] still alive.\n", i);
}/*检测所有线程的存活状态*/
void *thread3()
{while(1) {sleep(3);test_pthread(0);test_pthread(1);test_pthread(2);}pthread_exit(NULL);
}void thread_create(void)
{int temp;memset(&thread, 0, sizeof(thread));/*创建线程*/if((temp = pthread_create(&thread[0], NULL, thread1, NULL)) != 0) {printf("[sqlite] -- switch_control_thread create error!\n");}if((temp = pthread_create(&thread[1], NULL, thread2, NULL)) != 0) {printf("[sqlite] -- data_control_thread create error!\n");}if((temp = pthread_create(&thread[2], NULL, thread3, NULL)) != 0) {printf("[sqlite] -- data_control_thread create error!\n");}
}int main()
{/*用默认属性初始化互斥锁*/pthread_mutex_init(&mut,NULL);thread_create();while(1);return 0;
}

编译:gcc main.c -o main -lpthread

运行:./main

运行结果:


这篇关于linux 线程存活状态监控,不存在就重启的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016423

相关文章

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

linux解压缩 xxx.jar文件进行内部操作过程

《linux解压缩xxx.jar文件进行内部操作过程》:本文主要介绍linux解压缩xxx.jar文件进行内部操作,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、解压文件二、压缩文件总结一、解压文件1、把 xxx.jar 文件放在服务器上,并进入当前目录#