用.NET创建Windows服务操作数据库
http://www.pconline.com.cn/pcedu/empolder/net/0505/613681.html
主要功能是完成服务启动,停止和每间一定的时间往数据表里面写数据
创建一个Windows服务
1. 新建一个项目
2. 从一个可用的项目模板列表当中选择Windows服务
3. 设计器会以设计模式打开
4. 从工具箱的组件表当中拖动一个Timer对象到这个设计表面上 (注意: 要确保是从组件列表而不是从Windows窗体列表当中使用Timer) 
5. 设置Timer属性,Enabled属性为False,Interval属性30000毫秒
6. 切换到代码视图页(按F7或在视图菜单当中选择代码),然后为这个服务填加功能
Windows服务的构成
在你类后面所包含的代码里,你会注意到你所创建的Windows服务扩充了System.ServiceProcess.Service类。所有以.NET方式建立的Windows服务必须扩充这个类。它会要求你的服务重载下面的方法,Visual Studio默认时包括了这些方法。
• Dispose – 清除任何受控和不受控资源(managed and unmanaged resources)
• OnStart – 控制服务启动
• OnStop – 控制服务停止
数据库表脚本样例
在这个例子中使用的数据库表是使用下面的T-SQL脚本创建的。我选择SQL Server数据库。你可以很容易修改这个例子让它在Access或任何你所选择的别的数据库下运行。
 CREATE TABLE [dbo].[MyServiceLog] (
CREATE TABLE [dbo].[MyServiceLog] ( [in_LogId] [int] IDENTITY (1, 1) NOT NULL,
   [in_LogId] [int] IDENTITY (1, 1) NOT NULL, [vc_Status] [nvarchar] (40)
   [vc_Status] [nvarchar] (40)  COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
           COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, [dt_Created] [datetime] NOT NULL
   [dt_Created] [datetime] NOT NULL ) ON [PRIMARY]
) ON [PRIMARY]代码部分
 using System.Collections.Generic;
using System.Collections.Generic; using System.Text;
using System.Text;
 using System;
using System; using System.Collections;
using System.Collections; using System.ComponentModel;
using System.ComponentModel; using System.Data;
using System.Data; using System.Data.SqlClient;
using System.Data.SqlClient; using System.Diagnostics;
using System.Diagnostics; using System.ServiceProcess;
using System.ServiceProcess; /*
/* http://www.pconline.com.cn/pcedu/empolder/net/0505/613681_2.html
 http://www.pconline.com.cn/pcedu/empolder/net/0505/613681_2.html */
 */ namespace WindowsService_Test
namespace WindowsService_Test {
{ public partial class Service1 : ServiceBase
    public partial class Service1 : ServiceBase {
    { public Service1()
        public Service1() {
        { InitializeComponent();
            InitializeComponent(); }
        }
 protected override void OnStart(string[] args)
        protected override void OnStart(string[] args) {
        { // TODO: 在此处添加代码以启动服务。
            // TODO: 在此处添加代码以启动服务。 this.timer1.Enabled = true;
            this.timer1.Enabled = true; this.LogMessage("Service Started");
            this.LogMessage("Service Started"); }
        }
 protected override void OnStop()
        protected override void OnStop() {
        { // TODO: 在此处添加代码以执行停止服务所需的关闭操作。
            // TODO: 在此处添加代码以执行停止服务所需的关闭操作。 this.timer1.Enabled = false;
            this.timer1.Enabled = false; this.LogMessage("Service Stopped");
            this.LogMessage("Service Stopped"); }
        }
 
         /*
        /* * Respond to the Elapsed event of the timer control
        * Respond to the Elapsed event of the timer control */
        */ private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e) {
        { this.LogMessage("Service Running");
            this.LogMessage("Service Running"); }
        } 
         /*
        /* * Log specified message to database
        * Log specified message to database */
        */ private void LogMessage(string Message)
        private void LogMessage(string Message) {
        { SqlConnection connection = null;
            SqlConnection connection = null; SqlCommand command = null;
            SqlCommand command = null; try
            try {
            { connection = new SqlConnection("Server=localhost;Database=MyDataBase;Integrated Security=false;User Id=sa;Password=;");
                connection = new SqlConnection("Server=localhost;Database=MyDataBase;Integrated Security=false;User Id=sa;Password=;"); command = new SqlCommand("INSERT INTO MyServiceLog (vc_Status, dt_Created) VALUES ('" + Message + "',getdate())", connection);
                command = new SqlCommand("INSERT INTO MyServiceLog (vc_Status, dt_Created) VALUES ('" + Message + "',getdate())", connection); connection.Open();
                connection.Open(); int numrows = command.ExecuteNonQuery();
                int numrows = command.ExecuteNonQuery(); }
            } catch (Exception ex)
            catch (Exception ex) {
            { System.Diagnostics.Debug.WriteLine(ex.Message);
                System.Diagnostics.Debug.WriteLine(ex.Message); }
            } finally
            finally {
            { command.Dispose();
                command.Dispose(); connection.Dispose();
                connection.Dispose(); }
            } }
        }
 private void timer1_Tick(object sender, EventArgs e)
        private void timer1_Tick(object sender, EventArgs e) {
        { this.LogMessage("Service Tick");
            this.LogMessage("Service Tick"); }
        } }
    } }
}
安装Windows服务
Windows服务不同于普通Windows应用程序。不可能简简单单地通过运行一个EXE就启动Windows服务了。安装一个Windows服务应该通过使用.NET Framework提供的InstallUtil.exe来完成,或者通过诸如一个Microsoft Installer (MSI)这样的文件部署项目完成。
添加服务安装程序创建一个Windows服务,仅用InstallUtil程序去安装这个服务是不够的。你必须还要把一个服务安装程序添加到你的Windows服务当中,这样便于InstallUtil或是任何别的安装程序知道应用你服务的是怎样的配置设置。
1. 将这个服务程序切换到设计视图
2. 右击设计视图选择“添加安装程序”
3. 切换到刚被添加的ProjectInstaller的设计视图
4. 设置serviceInstaller1组件的属性:
1) ServiceName = My Sample Service
2) StartType = Automatic
5. 设置serviceProcessInstaller1组件的属性
1) Account = LocalSystem
6. 生成解决方案
在完成上面的几个步骤之后,会自动由Visual Studio产生下面的源代码,它包含于ProjectInstaller.cs这个源文件内。
 namespace WindowsService_Test
namespace WindowsService_Test {
{ partial class ProjectInstaller
    partial class ProjectInstaller {
    { /// <summary>
        /// <summary> /// 必需的设计器变量。
        /// 必需的设计器变量。 /// </summary>
        /// </summary> private System.ComponentModel.IContainer components = null;
        private System.ComponentModel.IContainer components = null;
 /// <summary>
        /// <summary>  /// 清理所有正在使用的资源。
        /// 清理所有正在使用的资源。 /// </summary>
        /// </summary> /// <param name="disposing">如果应释放托管资源,为 true;否则为 false。</param>
        /// <param name="disposing">如果应释放托管资源,为 true;否则为 false。</param> protected override void Dispose(bool disposing)
        protected override void Dispose(bool disposing) {
        { if (disposing && (components != null))
            if (disposing && (components != null)) {
            { components.Dispose();
                components.Dispose(); }
            } base.Dispose(disposing);
            base.Dispose(disposing); }
        }
 组件设计器生成的代码
        组件设计器生成的代码
 private System.ServiceProcess.ServiceProcessInstaller serviceProcessInstaller1;
        private System.ServiceProcess.ServiceProcessInstaller serviceProcessInstaller1; private System.ServiceProcess.ServiceInstaller serviceInstaller1;
        private System.ServiceProcess.ServiceInstaller serviceInstaller1; }
    } }
}用InstallUtil安装Windows服务
现在这个服务已经生成,你需要把它安装好才能使用。下面操作会指导你安装你的新服务。
1. 打开Visual Studio .NET命令提示
2. 改变路径到你项目所在的bin\Debug文件夹位置(如果你以Release模式编译则在bin\Release文件夹)
3. 执行命令“InstallUtil.exe MyWindowsService.exe”注册这个服务,使它建立一个合适的注册项。
4. 右击桌面上“我的电脑”,选择“管理”就可以打计算机管理控制台
5. 在“服务和应用程序”里面的“服务”部分里,你可以发现你的Windows服务已经包含在服务列表当中了
6. 右击你的服务选择启动就可以启动你的服务了
在每次需要修改Windows服务时,这就会要求你卸载和重新安装这个服务。不过要注意在卸载这个服务前,最好确保服务管理控制台已经关闭,这会是一个很好的习惯。如果没有这样操作的话,你可能在卸载和重安装Windows服务时会遇到麻烦。仅卸载服务的话,可以执行相的InstallUtil命令用于注销服务,不过要在后面加一个/u命令开关。
调试Windows服务
从另外的角度度看,调试Windows服务绝不同于一个普通的应用程序。调试Windows服务要求的步骤更多。服务不能象你对普通应用程序做的那样,只要简单地在开发环境下执行就可以调试了。服务必须首先被安装和启动,这一点在前面部分我们已经做到了。为了便于跟踪调试代码,一旦服务被启动,你就要用Visual Studio把运行的进程附加进来(attach)。记住,对你的Windows服务做的任何修改都要对这个服务进行卸载和重安装。
附加正在运行的Windows服务
为了调试程序,有些附加Windows服务的操作说明。这些操作假定你已经安装了这个Windows服务并且它正在运行。
1. 用Visual Studio装载这个项目
2. 点击“调试”菜单
3. 点击“进程”菜单
4. 确保 显示系统进程 被选
5. 在 可用进程 列表中,把进程定位于你的可执行文件名称上点击选中它
6. 点击 附加 按钮
7. 点击 确定
8. 点击 关闭
9. 在timer1_Elapsed方法里设置一个断点,然后等它执行
总结
现在你应该对Windows服务是什么,以及如何创建、安装和调试它们有一个粗略的认识了。Windows服务的额处的功能你可以自行研究。这些功能包括暂停(OnPause)和恢复(OnContinue)的能力。暂停和恢复的能力在默认情况下没有被启用,要通过Windows服务属性来设置。
如果你要卸载一个本地服务,可以打开CMD,C:\WINDOWS\system32>sc delete MyServiceName
或者 installutil /u 服务名称
 
                    
                

 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号