在业务复杂的应用程序中,有时候会要求一个或者多个任务在一定的时间或者一定的时间间隔内计划进行,比如定时备份或同步数据库,定时发送电子邮件等,我们称之为计划任务。实现计划任务的方法也有很多,可以采用SQLAgent执行存储过程来实现,也可以采用Windows任务调度程序来实现,也可以使用Windows服务来完成我们的计划任务,这些方法都是很好的解决方案。但是,对于Web应用程序来说,这些方法实现起来并不是很简单的,主机服务提供商或者不能直接提供这样的服务,或者需要你支付许多额外的费用。 本文就介绍一个直接在Web应用程序中使用的简单的方法,这个方法不需要任何额外的配置即可轻松实现。
  由于ASP.NET站点是作为Web应用程序运行的,它并不受线程的限制,因此我们可以非常方便地在Application_Start和Application_End事件中建立和销毁一个计划任务。下面就简单介绍一下在Web站点实现计划任务的方法。我们的例子是定时往文件里添加信息,作为例子,这里把当前的时间定时地写入文件中。
  一个计划任务的工作单元称之为一个任务(Job),下面的代码描述了对所有任务都可以被调度引擎计划执行的一个通用的接口,这里的每个任务实现了Execute方法,供调度引擎进行调用:

 public interface ISchedulerJob
     {
         void Execute();
     }

  如前所述,我们的例子是实现往文件写如字符日期,下面就是实现这一任务的方法:

 public class SampleJob : ISchedulerJob
 {
 public void Execute()
 {
 //文件保存的物理路径,CSTest为虚拟目录名称,F:\Inetpub\wwwroot\CSTest为物理路径
 string p = @"C:\Users\Jack\Desktop\AutoRun\AutoRun";
 //我们在虚拟目录的根目录下建立SchedulerJob文件夹,并设置权限为匿名可修改,
 //SchedulerJob.txt就是我们所写的文件
 string FILE_NAME = p+ "\\SchedulerJob\\SchedulerJob.txt";
 //取得当前服务器时间,并转换成字符串
 string c = System.DateTime.Now.ToString("yyyy-mm-dd hh:MM:ss");
 //标记是否是新建文件的标量
 bool flag = false;
 //如果文件不存在,就新建该文件
 if (!File.Exists(FILE_NAME))
 {
 flag = true;
 StreamWriter sr = File.CreateText(FILE_NAME);
 sr.Close();
 }
 //向文件写入内容
 StreamWriter x = new StreamWriter(FILE_NAME,true,System.Text.Encoding.Default);
 if(flag) x.Write("计划任务测试开始:");
 x.Write("\r\n"+c);
 x.Close();
 }
 } 

  接下来,我们建立一个配置对象,告诉调度引擎执行什么任务和执行的时间间隔。

 public class SchedulerConfiguration
 {
 //时间间隔
 private int sleepInterval;
 //任务列表
 private ArrayList jobs = new ArrayList(); 

 public int SleepInterval { get { return sleepInterval; } }
 public ArrayList Jobs { get { return jobs; } } 

 //调度配置类的构造函数
 public SchedulerConfiguration(int newSleepInterval)
 {
 sleepInterval = newSleepInterval;
 }
 } 

 下面就是调度引擎,定时执行配置对象的任务 

 public class Scheduler
 {
 private SchedulerConfiguration configuration = null; 

 public Scheduler(SchedulerConfiguration config)
 {
 configuration = config;
 } 

 public void Start()
 {
 while(true)
 {
 //执行每一个任务
 foreach(ISchedulerJob job in configuration.Jobs)
 {
 ThreadStart myThreadDelegate = new ThreadStart(job.Execute);
 Thread myThread = new Thread(myThreadDelegate);
 myThread.Start();
 Thread.Sleep(configuration.SleepInterval);
 }
 }
 }
 } 

  所有的准备工作已经完成,下面就是激活引擎的工作了。为了让我们的任务计划执行,我们在Global.asax.cs文件里的Applicatio_Start和Application_End里进行建立和销毁工作,首先建立一个调度进程运行的线程,我们这里的运行间隔时间为3秒钟。

 public System.Threading.Thread schedulerThread = null;
 protected void Application_Start(Object sender, EventArgs e)
 {
 SchedulerConfiguration config = *);
 config.Jobs.Add(new SampleJob());
 Scheduler scheduler = new Scheduler(config);
 System.Threading.ThreadStart myThreadStart = new System.Threading.ThreadStart(scheduler.Start);
 System.Threading.Thread schedulerThread = new System.Threading.Thread(myThreadStart);
 schedulerThread.Start();
 } 

  最后还需要在程序退出时进行销毁:

 protected void Application_End(Object sender, EventArgs e)
 {
 if (null != schedulerThread)
 {
 schedulerThread.Abort();
 }
 } 

  好了,在VS.NET里建立一个C#的Web应用程序工程,建立TaskScheduler.cs类,并修改相应的Global.asax.cs文件。为了能看到效果,我们再建立一个表单WebForm1.aspx,定时刷新来检查我们所记录的数据:

 <%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false"
 Inherits="CSTest.WebForm1" %>
 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
 <HTML>
 <HEAD>
 <title>在Web应用程序中执行计划任务的例子</title>
 <meta http-equiv=">
 <meta name="GENERATOR" Content="Microsoft Visual Studio 7.0">
 <meta name="CODE_LANGUAGE" Content="C#">
 <meta name="vs_defaultClientScript" content="JavaScript">
 <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
 </HEAD>
 <body MS_POSITIONING="GridLayout">
 <form id="Form1" method="post" runat="server">
 <iframe style="width:100%;height:100%" src="SchedulerJob/SchedulerJob.txt"></iframe>
 </form>
 </body>
 </HTML> 

  对工程进行编译并运行,就可以看到结果了,结果如下:

计划任务测试开始:
2003-13-10 11:08:15
2003-13-10 11:08:18
2003-13-10 11:08:21
2003-13-10 11:08:24
2003-13-10 11:08:27
2003-13-10 11:08:30

  需要说明的是,以上只是在Web应用程序中执行计划任务的简单例子,对于多个任务来说,需要在不同的线程内进行工作,对计划的安排也是很简单的,实际还需要站点堵塞,当机的情况。另外这里也没有进行错误的处理等工作,相信大家会写出更加完美的代码的。

点击下载源码:http://files.cnblogs.com/zhaoxuntao/AutoRun.zip

Asp.Net(C#)自动执行计划任务的程序实例分析的更多相关文章

  1. Testlink自动执行用例小程序

    记得原来在一个公司时,具体很多原因,testlink上项目中的用例都需要执行形成漂亮的报告,但实际测试中又不需要去执行,所以就必须将用例根据上一次测试报告一个一个手工去贴结果刷用例,几百条用例,几天就 ...

  2. Oracle中获取执行计划的几种方法分析

    以下是对Oracle中获取执行计划的几种方法进行了详细的分析介绍,需要的朋友可以参考下     1. 预估执行计划 - Explain PlanExplain plan以SQL语句作为输入,得到这条S ...

  3. 在Java中如何设置一个定时任务,在每天的一个时间点自动执行一个特定的程序

    Quartz定时机制 首先导入jar包到程序内 quartz-all-1.6.0.jar 然后创建一个XML TimeConfig.xml 名字可以自己定义 <?xml version=&quo ...

  4. 使用maven构建dubbo服务的可执行jar包+Dubbo 程序实例

    https://blog.csdn.net/zsg88/article/details/76100482 https://blog.csdn.net/zsg88/article/details/762 ...

  5. ORACLE的执行计划

    转自:http://www.cnblogs.com/lovingprince/archive/2007/12/07/2166400.html 背景知识:        为了更好的进行下面的内容我们必须 ...

  6. Oracle执行计划——Oracle 如何启用执行计划

    AUTOTRACE是一项SQL*Plus功能,自动跟踪为SQL语句生成一个执行计划并且提供与该语句的处理有关的统计.SQL*Plus AUTOTRACE可以用来替代SQL Trace使用,AUTOTR ...

  7. Oracle sql执行计划解析

    Oracle sql执行计划解析 https://blog.csdn.net/xybelieve1990/article/details/50562963 Oracle优化器 Oracle的优化器共有 ...

  8. sql server 数据库优化--显示执行计划

      刚开始用SQL Server的时候,我没有用显示执行计划来对查询进行分析.我曾经一直认为我递交的SQL查询都是最优的,而忽略了查询性能究竟如何,从而对“执行计划”重视不够.在我职业初期,我只要能获 ...

  9. 分析oracle的执行计划(explain plan)并对对sql进行优化实践

    基于oracle的应用系统很多性能问题,是由应用系统sql性能低劣引起的,所以,sql的性能优化很重要,分析与优化sql的性能我们一般通过查看该sql的执行计划,本文就如何看懂执行计划,以及如何通过分 ...

随机推荐

  1. php-fpm的配置和优化

    php-fpm的安装目录 下面是我的平时的环境搭建php的各种安装目录,大家的基本也差不多. centos等linux平台 /usr/local/php/php /usr/local/php/etc/ ...

  2. jQuery单选框radio绑定click事件

    <div class="con_head"> <label><input type="radio" name="ask& ...

  3. SQL Server 内存中OLTP内部机制概述(四)

    ----------------------------我是分割线------------------------------- 本文翻译自微软白皮书<SQL Server In-Memory ...

  4. INNO安装卸载自动结束进程插件使用

    [Code] //安装前判断是否有进程正在运行,istask.dll文件与打包的exe文件一起function RunTask(FileName: string; bFullpath: Boolean ...

  5. Python 3 数值计算

    Python 3.4.3 (v3.4.3:9b73f1c3e601, Feb 24 2015, 22:43:06) [MSC v.1600 32 bit (Intel)] on win32Type & ...

  6. 使用tcpcopy拷贝线上流量压测测试环境

    tcpcopy项目地址:https://github.com/session-replay-tools/tcpcopy 作者地址:http://blog.csdn.net/wangbin579 1:环 ...

  7. PUT vs POST in REST

    来自:http://stackoverflow.com/questions/630453/put-vs-post-in-rest http://www.15yan.com/story/7dz6oXiS ...

  8. zookeeper Watcher API 说明

    Watcher 在 ZooKeeper 是一个核心功能,Watcher 可以监控目录节点的数据变化以及子目录的变化,一旦这些状态发生变化,服务器就会通知所有设置在这个目录节点上的 Watcher,从而 ...

  9. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  10. [转载]BW增量更新的理解(时间戳)

    在BW中,存在两种数据抽取方式,完全更新与增量更新,完全更新是每次把截至到某个时间的数据全部抽取,增量抽取则只抽取上次和本次抽取之间更新的数据,很显然,增量抽取能够提高系统效率,根据SAP帮 助的说法 ...