论坛首页 综合技术论坛

Erlang定时任务server (仿crontab语法)

浏览 2697 次
精华帖 (0) :: 良好帖 (11) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-09-23   最后修改:2009-09-23

好久不写blog了,看到yufeng老大那么活跃,我也“耐不住寂寞”啊。

前不久写一个小东西,其中涉及很多定时执行的任务,如数据清理,数据导入,定时计算等等。

涉及到这个东西,就想起了linux下的cron,多么贴身的服务啊。

但是在我的erlang代码里,却缺少这样一个东西。没有关系,自己动手!

 

首先是crontab.cfg配置文件,其语法与linux下的crontab一致,可以 man crontab 进行参考。

但是许要注意,我们使用Erlang Term的语法定义每条任务:

{{m, h, dom, mon, dow}, {M, F, A}}.

m, h, dom ,mon, dow,为integer,如果包含*,或者step信息,则许要使用 "" 双引号包围,使其为string。MFA,毫无疑问就是我们要定期执行的函数,其会在一个spawn的process中执行.

 

主要包含2个module,一个用来解析crontab.cfg,一个定期检测crontab.cfg,判断是否符合条件,如果符合则执行MFA函数。这个module还比较粗糙,采用list遍历,效率也不是很高。但是已经可以使用了 :)

 

你可以修改crontab.cfg,增添定时任务,cron server通过检测文件的last modified time来判断是否许要重新加载.

 

压缩包中,有一个run.sh,你可以运行:

./run.sh
 

启动cron server, 等待约1分钟,会执行crontab.cfg中的MFA,产生屏幕输出:

run the routine by cron server:1
hello

   发表时间:2009-09-24  
很实用的东西。
0 请登录后投票
论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics