这里提供的是一个简单的后台服务处理框架,简单的后台服务处理框支持(按指定间隔时间执行;每天指定时间执行每天一次;指定时间执行一次;每天指定开始和结束时间并且按照指定间隔时间执行),开发新的定时服务任务时,只需要实现抽象类的方法、添加任务配置以及运行安装脚本即可完成一个服务的开发。
框架支持配置执行类型来控制任务的执行逻辑
按指定间隔时间执行
每天指定时间执行 每天一次
指定时间执行一次
每天指定开始和结束时间并且按照指定间隔时间执行
以下是一个定时执行存储过程的任务。
继承基类并编写业务逻辑代码
using DataAccessHelper.sqlHelper;using Services.Common;using System;namespace Services.Tasks { public class CallProcTask : ServiceBase { protected override void Exec() { try { if (_isstart) { if (!string.IsNullOrWhiteSpace(Config.Param)) { LogFactory.GetLogger().Info(string.Format(开始执行存储过程 {0}, Config.Param)); sqlHelperFactory.Instance.ExecuteNonQuery(Config.Param, null); LogFactory.GetLogger().Info(string.Format(执行存储过程 {0} 完成, Config.Param)); } } } catch (Exception ex) { LogFactory.GetLogger().Error(string.Format(执行存储过程 {0} 异常:{1}, Config.Param, ex)); } } } }
配置服务名称
配置每次执行间隔60秒
[ { //循环执行任务 每次执行间隔60秒 ServiceName: CallProcTask-proc_test任务,//服务名称 非空 Assembly: Services.exe,//程序集 非空 Methods: Services.Tasks.CallProcTask,//执行类名 对应业务的类名 非空 S_Interval: 60,//间隔时间 单位秒 ExecType: 0,//执行类型 ( 0:按指定间隔时间执行 1:每天指定时间执行 每天一次 2:指定时间执行一次 3.每天指定开始和结束时间并且按照指定间隔时间执行) 可空默认0 Param: proc_test//自定义参数 在本案例中为sql参数 可空 } ]
编写完成后,编译,运行:Install.bat 即可在服务管理器中看到对应的服务。