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

香港、美国、日本、韩国、新加坡、越南、泰国、加拿大、英国、德国、法国等VPS,全球独立服务器99元起步 湘南科技

全球独立服务器、站群多IP服务器、VPS(哪个国家都有),香港、美国、日本、韩国、新加坡、越南、泰国、加拿大、英国、德国、法国等等99元起步,湘南科技郴州市湘南科技有限公司官方网址:www.xiangnankeji.cn产品内容:全球独立服务器、站群多IP服务器、VPS(哪个国家都有),香港、美国、日本、韩国、新加坡、越南、泰国、加拿大、英国、德国、法国等等99元起步,湘南科技VPS价格表:独立服...

hostkey俄罗斯、荷兰GPU显卡服务器/免费Windows Server

Hostkey.com成立于2007年的荷兰公司,主要运营服务器出租与托管,其次是VPS、域名、域名证书,各种软件授权等。hostkey当前运作荷兰阿姆斯特丹、俄罗斯莫斯科、美国纽约等数据中心。支持Paypal,信用卡,Webmoney,以及支付宝等付款方式。禁止VPN,代理,Tor,网络诈骗,儿童色情,Spam,网络扫描,俄罗斯色情,俄罗斯电影,俄罗斯MP3,俄罗斯Trackers,以及俄罗斯法...

HostMem,最新优惠促销,全场75折优惠,大硬盘VPS特价优惠,美国洛杉矶QuadraNet机房,KVM虚拟架构,KVM虚拟架构,2核2G内存240GB SSD,100Mbps带宽,27美元/年

HostMem近日发布了最新的优惠消息,全场云服务器产品一律75折优惠,美国洛杉矶QuadraNet机房,基于KVM虚拟架构,2核心2G内存240G SSD固态硬盘100Mbps带宽4TB流量,27美元/年,线路方面电信CN2 GT,联通CU移动CM,有需要美国大硬盘VPS云服务器的朋友可以关注一下。HostMem怎么样?HostMem服务器好不好?HostMem值不值得购买?HostMem是一家...

linux定时器为你推荐
存储区域网络什么是存储局域网?组建它需要哪些内容?视频托管如何把视频上传到自己公司的网站上?求解···素数算法100以内的质数C算法,要步骤说明,谢谢。avc是什么格式XVID/MPEG/AVC都是什么意思啊怎么用电脑发短信谁知道怎样能用电脑给手机发短信pps官网pps官方网站下载pps官方正式版下载网站listviewitemListView具有多种item布局国家法规数据库食品及食用农产品标准法规信息支撑和综合应用平台/食品安全标准与技术法规动态比对数据库如何查询标准shoujiao如何区分是不是颈椎病?泛微协同办公系统泛微OA系统怎么创建新人员
域名注册使用godaddy 如何注册中文域名 老域名全部失效请记好新域名 美元争夺战 老左博客 云全民 微信收钱 七夕促销 卡巴斯基试用版 服务器合租 华为云盘 免费邮件服务器 万网空间管理 贵阳电信测速 工信部网站备案查询 百度云空间 谷歌台湾 godaddyssl windowsserver2008r2 apache启动失败 更多