linux定时器在linux环境中,如何实现多线程中使用多个定时器,POSIX定时器可以吗,如何用?

linux定时器  时间:2021-06-19  阅读:()

linux 定时任务的方法有哪些

如果我们需要定时执行一些周期性重复性的任务,我们就会用到定时执行任务功能来帮我们自动执行每天、每周等周期性重复性的任务而不需要人为干预即可实现。

我们通过crontab –e来创建自己的定时任务,下图中的5个*的含义是,第一个*是分,第二个*是小时,第三个*是日,第4个*是月,第5个*是周,第6列是命令,下图的意思是给所有人发警告信息Hello,每隔一分钟就发送一次Hello信息。

我们可以通过crontab –l来查看当前的已创建的定时任务,可以发现当前有一个定时任务,通过crontab –r删除当前的定时任务,再次通过crontab –l去查看是否还有定时任务,发现已经成功删除了。

进入/etc目录,查看首字母为cron的目录,cron*,*在这里是通配符,匹配任意个字符,通过查看/etc目录下所有与定时任务相关的目录和文件。

通过cat crontab查看定时任务的故事,包括shell的位置、路径、默认邮件发给root账户、以及定时任务的格式,5个*的含义及第6列是写具体的命令。

我们可以看看系统里面的定时任务,有每小时执行的cron.hourly、每日执行的cron.daily、每月执行的cron.monthly、每周执行的cron.weekly.我们通过命令ll cron.daily可以看到里面有很多可执行文件,这些都是系统每天自动执行的定时任务。

我们可以把自己建立的定时文件放在系统已有的目录下,比如每天的定时任务放在cron.daily下面。

系统常用的每天执行的定时任务,tmpwatch定时任务会去/tmp、/var/tmp临时目录下找超过10天的文件并删除,logrotate日志文件回滚,默认是一周回滚一次,1个月回滚4次,也就是日志只保存1个月,logwatch把当天最敏感的日志找出来形成一个电子邮件默认发给超级用户。

linux 加硬件定时器 timer 可否实时

一. Linux的硬件时间 PC机中的时间有三种硬件时钟实现,这三种都是基于晶振产生的方波信号输入。

这三种时钟为:(1)实时时钟RTC ( Real Time Clock)

我在网上搜了一个Linux下的c++定时器,但是不会用。不知道时间在哪设置,定时触发的程序添加到哪请教一下

这里是利用了一个简单定时器…… alarm的参数为秒数,在经过指定秒数后,alarm会发出一个SIGALRM信号 singal函数用来绑定信号处理器函数,这里绑定的是timer,被绑定的函数必须固定为返回值void、参数int。

只需要alarm(时间)就设置了,可能由于getchar需要进入中断导致信号被挂起所以没反应吧,可以试试把getchar换成别的东西来延时看看

在linux环境中,如何实现多线程中使用多个定时器,POSIX定时器可以吗,如何用?

个人解决了,以下是一个实现: #include #include #include #include #include #include #include #if 1 pthread_attr_t attr; timer_t hard_timer, software_timer; struct sigevent hard_evp, software_evp; static void watchdog_hard_timeout(union sigval v) { time_t t; char p[32]; timer_t *q; struct itimerspec ts; int ret; time(&t); strftime(p, sizeof(p), "%T", localtime(&t)); printf("watchdog hard timeout! "); printf("%s thread %d, val = %u, signal captured. ", p, (unsigned int)pthread_self(), v.sival_int); q = (timer_t *)(v.sival_ptr); printf("hard timer_t:%d add:%p, q:%p! ", (int)hard_timer, &hard_timer, q); ts.it__sec = 0; ts.it__nsec = 0; ts.it__sec = 6; ts.it__nsec = 0; ret = timer_settime(*q, CLOCK_REALTIME, &ts, NULL); if (ret != 0) { printf("settime err(%d)! ", ret); } } static void watchdog_software_timeout(union sigval v) { time_t t; char p[32]; timer_t *q; struct itimerspec ts; int ret; time(&t); strftime(p, sizeof(p), "%T", localtime(&t)); printf("watchdog software timeout! "); printf("%s thread %d, val = %u, signal captured. ", p, (unsigned int)pthread_self(), v.sival_int); q = (timer_t *)(v.sival_ptr); printf("hard timer_t:%d add:%p, q:%p! ", (int)hard_timer, &hard_timer, q); ts.it__sec = 0; ts.it__nsec = 0; ts.it__sec = 10; ts.it__nsec = 0; ret = timer_settime(*q, CLOCK_REALTIME, &ts, NULL); if (ret != 0) { printf("settime err(%d)! ", ret); } } static void dcmi_sol_pthread_attr_destroy(pthread_attr_t *attr) { pthread_attr_destroy(attr); } static int dcmi_sol_pthread_attr_init(pthread_attr_t *attr) { int ret; if ((ret = pthread_attr_init(attr) != 0)) { goto err; } if ((ret = pthread_attr_setdetachstate(attr, PTHREAD_CREATE_DETACHED)) != 0) { dcmi_sol_pthread_attr_destroy(attr); goto err; } /* 设置线程的栈大小,失败则用系统默认值 */ pthread_attr_setstacksize(attr, 128 * 1024); return 0; err: printf("set ptread attr failed(ret:%d)! ", ret); return -1; } int main(void) { struct itimerspec ts; int ret; ret = dcmi_sol_pthread_attr_init(&attr); if (ret != 0) { printf("init pthread attributes fail(%d)! ", ret); exit(-1); } memset(&hard_evp, 0, sizeof(struct sigevent)); hard_evp.sigev_value.sival_ptr = &hard_timer; hard_evp.sigev_notify = SIGEV_THREAD; hard_evp.sigev_notify_function = watchdog_hard_timeout; hard_evp.sigev_notify_attributes = NULL;//&attr; memset(&software_evp, 0, sizeof(struct sigevent)); software_evp.sigev_value.sival_ptr = &software_timer; software_evp.sigev_notify = SIGEV_THREAD; software_evp.sigev_notify_function = watchdog_software_timeout; software_evp.sigev_notify_attributes = NULL;//&attr; ret = timer_create(CLOCK_REALTIME, &hard_evp, &hard_timer); if(ret != 0) { perror("hard timer_create fail!"); exit(-1); } ret = timer_create(CLOCK_REALTIME, &software_evp, &software_timer); if (ret != 0) { timer_delete(hard_timer); perror("software timer_create fail!"); exit(-1); } ts.it__sec = 0; ts.it__nsec = 0; ts.it__sec = 6; ts.it__nsec = 0; ret = timer_settime(hard_timer, CLOCK_REALTIME, &ts, NULL); if(ret != 0) { perror("hard timer_settime fail!"); timer_delete(hard_timer); timer_delete(software_timer); exit(-1); } ts.it__sec = 10; ret = timer_settime(software_timer, CLOCK_REALTIME, &ts, NULL); if(ret != 0) { perror("hard timer_settime fail!"); timer_delete(hard_timer); timer_delete(software_timer); exit(-1); } while(1) { printf("main ready sleep! "); sleep(15); printf("main sleep finish! "); } return 0; } #endif

A2Hosting三年付$1.99/月,庆祝18周年/WordPress共享主机最高优惠81%/100GB SSD空间/无限流量

A2Hosting主机,A2Hosting怎么样?A2Hosting是UK2集团下属公司,成立于2003年的老牌国外主机商,产品包括虚拟主机、VPS和独立服务器等,数据中心提供包括美国、新加坡softlayer和荷兰三个地区机房。A2Hosting在国外是一家非常大非常有名气的终合型主机商,拥有几百万的客户,非常值得信赖,国外主机论坛对它家的虚拟主机评价非常不错,当前,A2Hosting主机庆祝1...

旅途云(¥48 / 月),雅安高防4核4G、洛阳BGP 2核2G

公司成立于2007年,是国内领先的互联网业务平台服务提供商。公司专注为用户提供低价高性能云计算产品,致力于云计算应用的易用性开发,并引导云计算在国内普及。目前,旅途云公司研发以及运营云服务基础设施服务平台(IaaS),面向全球客户提供基于云计算的IT解决方案与客户服务,拥有丰富的国内BGP、双线高防、香港等优质的IDC资源。点击进入:旅途云官方网商家LOGO优惠方案:CPU内存硬盘带宽/流量/防御...

CloudCone,美国洛杉矶独立服务器特价优惠,美国洛杉矶MC机房,100Mbps带宽不限流量,可选G口,E3-1270 v2处理器32G内存1Gbps带宽,69美元/月

今天CloudCone发布了最新的消息,推送了几款特价独立服务器/杜甫产品,美国洛杉矶MC机房,分配100Mbps带宽不限流量,可以选择G口限制流量计划方案,存储分配的比较大,选择HDD硬盘的话2TB起,MC机房到大陆地区线路还不错,有需要美国特价独立服务器的朋友可以关注一下。CloudCone怎么样?CloudCone服务器好不好?CloudCone值不值得购买?CloudCone是一家成立于2...

linux定时器为你推荐
win7中文语言包windows7怎样汉化instagram电脑版iOS 有哪些优秀的照片处理软件averagesPoisson-Arrivals-See-Time-Averages是什么意思腾讯合作伙伴大会如何成为腾讯渠道合作伙伴?在线沟通网络沟通的问题有哪些backupexecBackup Exec 2014怎么备份Exchangevaliddate怎样解决oracle报错is not a valid date and timeibooks支持什么格式ibooks支持什么格式的电子书data什么意思data是什么文件夹可以删除吗camel是什么意思Camel骆驼究竟是哪个国家品牌?
域名备案信息查询 网易域名邮箱 buyvm 新加坡主机 wdcp ssh帐号 2017年万圣节 牛人与腾讯客服对话 铁通流量查询 中国智能物流骨干网 促正网秒杀 193邮箱 微信收钱 169邮箱 国外代理服务器软件 绍兴电信 搜索引擎提交入口 vip域名 免费的域名 lamp怎么读 更多