Forsun高性能高精度定时服务,轻松管理千万级定时任务。
项目地址: https://github.com/snower/forsunmysql
在实际项目中,存在大量须要定时或是延时触发的任务,好比电商中,延时须要检查订单是否支付成功,是否配送成功,定时给用户推送提醒等等,常规作法是用 crontab 每分钟扫码数据看是否到达时间,繁琐且扩展性伸缩性较差。linux
使用 forsun 服务,能够简单的针对每个订单建立一个定时任务,配合异步队列,能够轻松实现扩展性伸缩性,Apache Thrift 的编程接口也能够很容易的和 celery、laravel 配合。 laravel
其余场景下,好比失败延时重试,使用 forsun 定时服务也能够很简单就能够实现。git
使用pip自动安装github
pip install forsun
帮助redis
forsund -h usage: forsund [-h] [--bind BIND_HOST] [--port BIND_PORT] [--demon DEMON] [--log LOG_FILE] [--log-level LOG_LEVEL] [--driver DRIVER] [--driver-mem-store-file STORE_MEM_STORE_FILE] [--driver-redis-host DRIVER_REDIS_HOST] [--driver-redis-port DRIVER_REDIS_PORT] [--driver-redis-db DRIVER_REDIS_DB] [--driver-redis-prefix DRIVER_REDIS_PREFIX] [--driver-redis-server-id DRIVER_REDIS_SERVER_ID] [--extension-path EXTENSION_PATH] [--extension EXTENSIONS] High-performance timing scheduling service optional arguments: -h, --help show this help message and exit --bind BIND_HOST bind host (default: 0.0.0.0) --port BIND_PORT bind port (default: 6458) --demon DEMON run demon mode --log LOG_FILE log file --log-level LOG_LEVEL log level (defaul: INFO) --driver DRIVER store driver mem or redis (defaul: mem) --driver-mem-store-file STORE_MEM_STORE_FILE store mem driver store file (defaul: /tmp/forsun.session) --driver-redis-host DRIVER_REDIS_HOST store reids driver host (defaul: 127.0.0.1) --driver-redis-port DRIVER_REDIS_PORT store reids driver port (defaul: 6379) --driver-redis-db DRIVER_REDIS_DB store reids driver db (defaul: 0) --driver-redis-prefix DRIVER_REDIS_PREFIX store reids driver key prefix (defaul: forsun) --driver-redis-server-id DRIVER_REDIS_SERVER_ID store reids driver server id (defaul: 0) --extension-path EXTENSION_PATH extension path --extension EXTENSIONS extension name
使用内存持久化存储启动:sql
forsund --bind=0.0.0.0 --log=/var/log/forsun.log --log-level=INFO --driver=mem --driver-mem-store-file=/var/lib/fousun/forsun.session --demon
使用redis持久化存储启动:shell
forsund --bind=0.0.0.0 --log=/var/log/forsun.log --log-level=INFO --driver=redis --driver-redis-host=127.0.0.1 --driver-redis-db=1 --demon
注意:使用mem存储时只有进程正常退出时才会序列化任务保存到本地文件,下次启动时可能会丢失任务,建议使用性能更高的redis存储方式。编程
命令行帮助服务器
forsun -h usage: forsun [-h] [--host HOST] [--port PORT] [--exe EXECUTE] [cmd] High-performance timing scheduling service positional arguments: cmd execute cmd (default: ) optional arguments: -h, --help show this help message and exit --host HOST host (default: 127.0.0.1) --port PORT port (default: 6458) --exe EXECUTE execute cmd (default: )
延时运行示例
#每五秒运行redis命令,共运行一次 forsun "set redis */5/1 * * * * * redis 'host=172.16.0.2;command=\'SET b 1 EX 300\'" #每五秒运行shell命令,共运行二次 forsun "set shell */5/2 * * * * * shell 'cmd=ls" #每五秒运行beanstalk命令,共运行一次 forsun "set beanstalk */5/1 * * * * * beanstalk 'host=10.4.14.14;name=etask;body={}'" #每五秒请求thrift接口,重复运行 forsun "set thrift */5/0 * * * * * thrift 'host=10.4.14.14;port=4220" #每五秒请求http接口,共运行一次 forsun "set http */5/1 * * * * * http 'url=\'http://www.baidu.com\''" #每五秒运行mysql命令,共运行一次 forsun "set mysql */5/1 * * * * * mysql 'host=172.16.0.2;user=root;passwd=123456;db=test;sql=\'update test set created_at=now() where id=1\'"
定时运行示例
#于天天16:32:00运行redis命令 forsun "set redis 0 32 16 * * * redis 'host=172.16.0.2;command=\'SET b 1 EX 300\'" #于每小时32:00运行shell命令 forsun "set shell 0 32 * * * * shell 'cmd=ls" #于每分钟1秒时运行beanstalk命令 forsun "set beanstalk 1 * * * * * beanstalk 'host=10.4.14.14;name=etask;body={}'" #于每个月3日16:32:00请求thrift接口 forsun "set thrift 0 32 16 3 * * thrift 'host=10.4.14.14;port=4220" #于天天16:32:00请求http接口 forsun "set http 0 32 16 * * * http 'url=\'http://www.baidu.com\''" #于天天16:32:00运行mysql命令 forsun "set mysql 32 16 * * * mysql 'host=172.16.0.2;user=root;passwd=123456;db=test;sql=\'update test set created_at=now() where id=1\'"
exception ForsunPlanError{ 1:i16 code, 2:string message } struct ForsunPlan { 1: required bool is_time_out, 2: required string key, 3: required i16 second, 4: i16 minute = -1, 5: i16 hour = -1, 6: i16 day = -1, 7: i16 month = -1, 8: i16 week = -1, 9: required i32 next_time, 10: i16 status = 0, 11: i16 count = 0, 12: i16 current_count = 0, 13: i32 last_timeout = 0, 14:string action = "shell", 15:map<string, string> params = {} } service Forsun{ i16 ping(), #建立固定时间运行任务 ForsunPlan create(1:string key, 2:i16 second, 3:i16 minute = -1, 4:i16 hour = -1, 5:i16 day = -1, 6:i16 month = -1, 7:i16 week = -1, 8:string action="shell", 9:map<string, string> params={}) throws (1:ForsunPlanError err), #建立延时运行任务 ForsunPlan createTimeout(1:string key, 2:i16 second, 3:i16 minute = -1, 4:i16 hour = -1, 5:i16 day = -1, 6:i16 month = -1, 7:i16 week = -1, 8:i16 count=1, 9:string action="shell", 10:map<string, string> params={}) throws (1:ForsunPlanError err), #删除任务 ForsunPlan remove(1:string key) throws (1:ForsunPlanError err), #获取任务信息 ForsunPlan get(1:string key) throws (1:ForsunPlanError err), #获取当前即将运行任务列表 list<ForsunPlan> getCurrent(), #获取某个时间运行任务列表 list<ForsunPlan> getTime(1:i32 timestamp), #查询某些key前缀任务列表 list<string> getKeys(1:string prefix), #thrift回调器请求函数定义 void forsun_call(1:string key, 2:i32 ts, 3:map<string, string> params) }
回调器参数为create和createTimeout最后一个参数params key和value的map。
回调thrift接口时,固定请求void forsun_call(1:string key, 2:i32 ts, 3:map<string, string> params)该函数,第三个params参数即为任务定义时的params值。