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

来源:互联网 发布:中国网速和外国网络 编辑:程序博客网 时间:2024/06/06 04:42

好久不写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,你可以运行:

Java代码  收藏代码
  1. ./run.sh  
 

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

run the routine by cron server:1
hello




http://erlangdisplay.iteye.com/blog/475283

1 0
原创粉丝点击