Windows服务与计时器

Nit*_*bra 29 .net c# windows windows-services timer

我在c#.net中创建了一个带有计时器的Windows服务.它在Visual Studio中调试/构建项目时工作正常,但安装后它不执行其操作.

这背后可能是什么原因?

代码:

public partial class Service1 : ServiceBase
{
        FileStream fs;
        StreamWriter m_streamWriter;
        Timer tm = new Timer();

        public Service1()
        {
            InitializeComponent();

            this.ServiceName = "timerservice";

            tm.Interval = 2000;
            tm.Tick += new EventHandler(PerformOperations);
            tm.Start();

            fs = new FileStream(@"c:\mcWindowsService.txt", FileMode.OpenOrCreate, FileAccess.Write);

            m_streamWriter = new StreamWriter(fs);
            m_streamWriter.BaseStream.Seek(0, SeekOrigin.End);
        }

        private void PerformOperations(object sener, EventArgs e)
        {
            //StreamWriter swr = new StreamWriter("c:\\test_from_database.txt",true);

            try
            {
                OdbcConnection con = new OdbcConnection("DSN=liquor_data");

                OdbcDataAdapter adp = new OdbcDataAdapter("", con);

                DataSet ds = new DataSet();

                string sql = "select * from item_group";
                adp.SelectCommand.CommandText = sql;

                adp.Fill(ds, "item_group");

                foreach (DataRow dr in ds.Tables["item_group"].Rows)
                {
                    //      swr.Write(dr["group_name"].ToString() + "\t\t" + DateTime.Now.TimeOfDay.ToString() + "\n");

                    //Console.WriteLine(dr["group_name"].ToString() + "\t\t" + DateTime.Now.TimeOfDay.ToString() + "\n");
                    m_streamWriter.WriteLine(dr["group_name"].ToString() + "\t\t" + DateTime.Now.TimeOfDay.ToString() + "\n");
                }

                m_streamWriter.Flush();
            }

            catch (Exception ex)
            {
                // swr.Write("Error :"+ ex.Message + "\t\t" + DateTime.Now.TimeOfDay.ToString() + "\n"); }
            }
        }
    }
Run Code Online (Sandbox Code Playgroud)

T-m*_*oty 56

使用Windows服务的第一种方法并不容易..

很久以前,我写了一个C#服务.

这是Service类的逻辑(测试,工作正常):

namespace MyServiceApp
{
    public class MyService : ServiceBase
    {
        private System.Timers.Timer timer;

        protected override void OnStart(string[] args)
        {
            this.timer = new System.Timers.Timer(30000D);  // 30000 milliseconds = 30 seconds
            this.timer.AutoReset = true;
            this.timer.Elapsed += new System.Timers.ElapsedEventHandler(this.timer_Elapsed);
            this.timer.Start();
        }

        protected override void OnStop()
        {
            this.timer.Stop();
            this.timer = null;
        }

        private void timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        {
            MyServiceApp.ServiceWork.Main(); // my separate static method for do work
        }

        public MyService()
        {
            this.ServiceName = "MyService";
        }

        // service entry point
        static void Main()
        {
            System.ServiceProcess.ServiceBase.Run(new MyService());
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我建议您在一个单独的静态方法中编写您的实际服务工作(为什么不在控制台应用程序中添加对它的引用),以简化调试和清理服务代码.

确保间隔足够,并且仅在OnStart和OnStop覆盖中写入日志.

希望这可以帮助!


Lui*_*ada 7

您需要将主代码放在OnStart方法上.

我的另一个答案可能有所帮助.

您需要放置一些代码以在visual-studio中启用调试,同时保持您的应用程序作为Windows服务有效.这个其他SO线程涵盖了调试Windows服务的问题.

编辑:

请参阅此处提供OnStart的MSDN方法文档,其中可以阅读:

不要使用构造函数来执行应该在 OnStart中的处理.使用OnStart处理服务的所有初始化.构造函数在应用程序的可执行文件运行时调用,而不是在服务运行时调用.可执行文件在OnStart之前运行.例如,当您继续时,不会再次调用构造函数,因为SCM已将对象保存在内存中.如果OnStop释放在构造函数而不是OnStart中分配的资源,则第二次调用服务时将不会再次创建所需的资源.