8

我有一个 Windows 服务正在运行,在这里面我想每隔几分钟运行一个函数。我找到了一些代码,但它似乎不起作用?我有一个记录器,它似乎没有进入 timer_Elapsed 函数?

 protected override void OnStart(string[] args)
    {
       // SmartImportService.WebService.WebServiceSoapClient test = new WebService.WebServiceSoapClient();
       // test.Import();
         log.Info("Info - Service Started");
        _timer = new Timer(10 * 60 * 1000); // every 10 minutes??
        _timer.Elapsed += new System.Timers.ElapsedEventHandler(timer_Elapsed);
    }

    private void timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
    {
        log.Info("Info - Check time");
        DateTime startAt = DateTime.Today.AddHours(9).AddMinutes(48);
        if (_lastRun < startAt && DateTime.Now >= startAt)
        {
            // stop the timer 
            _timer.Stop();               

            try
            {
                log.Info("Info - Import");
                SmartImportService.WebService.WebServiceSoapClient test = new WebService.WebServiceSoapClient();
                test.Import();
            }
            catch (Exception ex) {
                log.Error("This is my error - ", ex);
            }

            _lastRun = DateTime.Now;
            _timer.Start();
        }
    }
4

5 回答 5

21

您需要启动计时器:

protected override void OnStart(string[] args)
{
     log.Info("Info - Service Started");
    _timer = new Timer(10 * 60 * 1000); // every 10 minutes
    _timer.Elapsed += new System.Timers.ElapsedEventHandler(timer_Elapsed);
    _timer.Start(); // <- important
}
于 2012-04-18T08:55:17.757 回答
4

没看懂_timer.Start(),应该是你的问题

于 2012-04-18T08:55:34.367 回答
3

Daniel Hilgarth是正确的 - 主要问题是您永远不会在计时器上调用 Start。

话虽如此,您可能还需要考虑使用 Windows 任务计划程序而不是带有计时器的服务。这允许您将任务安排为每 10 分钟运行一次,但也可以在需要时更改计划,而无需更改编译。

于 2012-04-18T09:05:56.687 回答
3

我也需要这个功能。也就是说,我的 C# windows 服务必须每 10 分钟检查一次电子邮件。我剥离了一些逻辑以使代码更有效,如下所示:

private void timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        {
            _timer.Stop();
            try
            {
                EventLog.WriteEntry(Program.EventLogName, "Checking emails " + _count++);
            }
            catch (Exception ex)
            {
                EventLog.WriteEntry(Program.EventLogName, "This is my error " + ex.Message);
            }
            _timer.Start();
        }

timer_elapsed 方法确实会每 10 分钟调用一次,从第一个 _timer.start() 开始,顺便说一下你错过了它。我没有对_lastRun 和startAt 进行任何检查。我认为我们不需要它

于 2013-01-23T10:08:01.853 回答
1

尝试启动timer,

protected override void OnStart(string[] args)
    {
       // SmartImportService.WebService.WebServiceSoapClient test = new WebService.WebServiceSoapClient();
       // test.Import();
         log.Info("Info - Service Started");
        _timer = new Timer(10 * 60 * 1000); // every 10 minutes??
            _timer.Elapsed += new System.Timers.ElapsedEventHandler(timer_Elapsed);
_timer.Start();
    }

    private void timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
    {
        log.Info("Info - Check time");
        DateTime startAt = DateTime.Today.AddHours(9).AddMinutes(48);
        if (_lastRun < startAt && DateTime.Now >= startAt)
        {
            // stop the timer 
            _timer.Stop();               

            try
            {
                log.Info("Info - Import");
                SmartImportService.WebService.WebServiceSoapClient test = new WebService.WebServiceSoapClient();
                test.Import();
            }
            catch (Exception ex) {
                log.Error("This is my error - ", ex);
            }

            _lastRun = DateTime.Now;
            _timer.Start();
        }
    }
于 2012-04-18T08:56:58.187 回答