`
litaocheng
  • 浏览: 333302 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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

阅读更多

好久不写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

分享到:
评论
2 楼 TAODIZHIYING 2013-03-13  
刚好碰到定时的问题,请问如何在项目中应用?
1 楼 mryufeng 2009-09-24  
很实用的东西。

相关推荐

Global site tag (gtag.js) - Google Analytics