System.Timers.Timer timer1_Elapsed没有触发!救命!

Bex*_*Bex 2 c# windows service

我正在创建另一个Windows服务,我的计时器没有滴答作响,我不明白为什么!我正在使用system.timers.timer,就像我以前的服务一样,它不起作用.我试过附加它但它似乎没有做任何事情.

我的代码:

    namespace ExpiryNotifier
{
    public partial class ExpiryNotifier : ServiceBase
    {
        public ExpiryNotifier()
        {
            InitializeComponent();
            if (!System.Diagnostics.EventLog.SourceExists("ExpiryNotifier"))
            {
                System.Diagnostics.EventLog.CreateEventSource("ExpiryNotifier", "ExpiryNotifier");
            }
            eventLog1.Source = "ExpiryNotifier";
            eventLog1.Log = "ExpiryNotifier";
        }
        private Timer timer1 = new Timer();
        protected override void OnStart(string[] args)
        {
            eventLog1.WriteEntry("Service Started");
            timer1.Elapsed += timer1_Elapsed;
            timer1.Interval = 10000;
            timer1.Enabled = true;

        }

        protected override void OnStop()
        {
            eventLog1.WriteEntry("Service Stopped");
            timer1.Enabled = false;

        }

        private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        {
            eventLog1.WriteEntry("timer tick");
            timer1.Stop();

            EmailerService.EmailerService service = new EmailerService.EmailerService();
            DataSet expiringQualifications = service.GetDetailsOfExpiringQualifications();

            if(expiringQualifications.Tables[0].Rows.Count>0)
            {
                foreach(DataRow rw in expiringQualifications.Tables[0].Rows)
                {
                    if (!string.IsNullOrEmpty(rw["EmailAddress"].ToString()) )
                    {
                        if (rw["QualAwardDescription"] != null)
                        {
                            service.SendQualExpiryEmail(rw["EmailAddress"].ToString(), rw["firstName"].ToString(),
                                                        rw["QualAwardDescription"].ToString());
                        }
                    }
                }
            }


            timer1.Start();
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

有谁能看到这个问题?

提前致谢!

贝克斯

Han*_*ant 8

System.Timers.Timer是一个丑陋的计时器.它做的一件令人讨厌的事情是吞噬Elapsed事件处理程序引发的异常.因为你在输入方法时停止它会杀死你的计时器.没有任何通知,它只是停止工作.

您必须至少为此代码添加异常处理,以便您可以记录异常并停止服务.

还要注意OnStart()方法中的错误,每次启动服务时都会不断添加事件处理程序.Elapsed事件多次运行,本身就是轰炸某事的好方法.

考虑System.Threading.Timer,它没有任何这些问题.