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

月神科技-美国CERA 5折半价倒计时,上新华中100G高防云59起!

官方网站:点击访问月神科技官网优惠码:美国优惠方案:CPU:E5-2696V2,机房:国人热衷的优质 CeraNetworks机房,优惠码:3wuZD43F 【过期时间:5.31,季付年付均可用】活动方案:1、美国机房:洛杉矶CN2-GIA,100%高性能核心:2核CPU内存:2GB硬盘:50GB流量:Unmilited端口:10Mbps架构:KVM折后价:15元/月、150元/年传送:购买链接洛...

MineServer:香港CMI/洛杉矶GIA VPS,2核/2GB内存/20GB NVME/3.5TB流量/200Mbps/KVM,288元/年

mineserver怎么样?mineserver是一家国人商家,主要提供香港CN2 KVM VPS、香港CMI KVM VPS、日本CN2 KVM VPS、洛杉矶cn2 gia端口转发等服务,云服务器网(yuntue.com)介绍过几次,最近比较活跃。现在新推出了3款特价KVM VPS,性价比高,香港CMI/洛杉矶GIA VPS,2核/2GB内存/20GB NVME/3.5TB流量/200Mbps...

wordpress专业外贸建站主题 WordPress专业外贸企业网站搭建模版

WordPress专业外贸企业网站搭建模版,特色专业外贸企业风格 + 自适应网站开发设计 通用流行的外贸企业网站模块 + 更好的SEO搜索优化和收录 自定义多模块的产品展示功能 + 高效实用的后台自定义模块设置!采用标准的HTML5+CSS3语言开发,兼容当下的各种主流浏览器: IE 6+(以及类似360、遨游等基于IE内核的)、Firefox、Google Chrome、Safari、Opera...

linux定时器为你推荐
免费图片上传怎样免费把图片上传到淘宝上 ?windowsmedia电脑的大部分软件打开方式变为了Windows media centergps数据格式GPS数据如何输入及导出视频托管我想做一些游戏教学视频,放到网上收费该可以吗?素数算法什么是素数算法怎么用电脑发短信怎样用电脑给别人的手机发短信?pat是什么格式pat 格式的文件用什么软件打开?broadcast播播……拼音netbios协议NetBIOS协议起什么作用?netbios协议tcp/ip、ipx/spx、netbios这三个通信协议的区别
国内免备案主机 便宜建站 20g硬盘 名片模板psd idc资讯 可外链相册 免费测手机号 国外免费asp空间 1元域名 ebay注册 东莞服务器托管 supercache hostease 网站防护 脚本大全 沈阳idc phpinfo 阿里云宕机故障 以下 linux命令vi 更多