溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C#中怎么創(chuàng)建控制Windows服務(wù)

發(fā)布時(shí)間:2022-02-07 14:46:05 來源:億速云 閱讀:131 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下C#中怎么創(chuàng)建控制Windows服務(wù)的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

需求

針對一種特殊的應(yīng)用, 不需要顯示GUI, 希望常駐在Windows服務(wù)當(dāng)中,在必要的時(shí)候我們可以進(jìn)行啟動(dòng)或開機(jī)啟動(dòng)。

這個(gè)時(shí)候我們就可以創(chuàng)建WindowsService 來實(shí)現(xiàn)。

創(chuàng)建WindowsService

下面演示了使用VisualStudio2019創(chuàng)建一個(gè)基于.NetFramework的Windows服務(wù)

C#中怎么創(chuàng)建控制Windows服務(wù)

項(xiàng)目結(jié)構(gòu)如下所示:

包含了一個(gè)啟動(dòng)項(xiàng)以及一個(gè)服務(wù)類

C#中怎么創(chuàng)建控制Windows服務(wù)

右鍵查看 Service1代碼, 如下所示, 包含了重寫OnStart方法以及OnStop方法:

     public partial class Service1 : ServiceBase
    {
        public Service1()
        {
            InitializeComponent();
        }

        protected override void OnStart(string[] args)
        {
        }

        protected override void OnStop()
        {
        }
    }

當(dāng)服務(wù)被啟動(dòng), 即啟動(dòng)OnStart方法內(nèi)執(zhí)行的代碼, 而在ServiceBase當(dāng)中, 同樣提供了多種類型的方法被重寫。

C#中怎么創(chuàng)建控制Windows服務(wù)

當(dāng)我們寫完了該服務(wù)的執(zhí)行代碼之后, 下一步我們要為其添加一個(gè)安裝程序。

雙擊Service1.cs, 然后右鍵添加安裝程序,如下所示:

C#中怎么創(chuàng)建控制Windows服務(wù)

此時(shí), 項(xiàng)目結(jié)構(gòu)當(dāng)中新增了一個(gè)默認(rèn)名:ProjectInstaller.cs類, 而對應(yīng)的設(shè)計(jì)頁面如下所示:

C#中怎么創(chuàng)建控制Windows服務(wù)

serviceProcessInstaller1:

查看該類的屬性,如下所示:

C#中怎么創(chuàng)建控制Windows服務(wù)

說明:

Account: 默認(rèn)設(shè)置為User, 當(dāng) Account 屬性為時(shí) User , Username 和 Password 屬性用于定義用于運(yùn)行服務(wù)應(yīng)用程序的帳戶。

Username和 Password 對允許服務(wù)在除系統(tǒng)帳戶之外的其他帳戶下運(yùn)行。 例如,如果沒有用戶登錄,則可以允許服務(wù)在重新啟動(dòng)時(shí)自動(dòng)啟動(dòng)。 如果保留 Username 或 Password 為空,并且將設(shè)置 Account 為 User ,則在安裝時(shí)系統(tǒng)將提示您輸入有效的用戶名和密碼。

還可以指定服務(wù)在本地系統(tǒng)帳戶下運(yùn)行,或以本地或網(wǎng)絡(luò)服務(wù)運(yùn)行。 ServiceAccount有關(guān)帳戶類型的詳細(xì)信息,請參閱枚舉:

C#中怎么創(chuàng)建控制Windows服務(wù)

serviceInstaller1:

查看該類的屬性,如下所示:

C#中怎么創(chuàng)建控制Windows服務(wù)

注: 該類擴(kuò)展 ServiceBase 來實(shí)現(xiàn)服務(wù)。 在安裝服務(wù)應(yīng)用程序時(shí)由安裝實(shí)用工具調(diào)用該類。

說明:

  • DelayedAutoStart : 若要延遲該服務(wù)的自動(dòng)啟動(dòng),則為 true;否則為 false。 默認(rèn)值為 false。

  • Description : 服務(wù)的說明。 默認(rèn)值為空字符串("")。

  • DisplayName : 與服務(wù)關(guān)聯(lián)的名稱,常用于交互工具。

  • ServiceName: 要安裝的服務(wù)的名稱。 該值必須在安裝實(shí)用工具嘗試安裝服務(wù)以前進(jìn)行設(shè)置。

  • ServicesDependedOn : 在與該安裝程序關(guān)聯(lián)的服務(wù)運(yùn)行以前必須運(yùn)行的一組服務(wù)。

  • StartType : 表示服務(wù)的啟動(dòng)方式。 默認(rèn)值為 Manual,指定在計(jì)算機(jī)重新啟動(dòng)后服務(wù)將不會(huì)自動(dòng)啟動(dòng)。

控制WindowsService

創(chuàng)建完成服務(wù)之后, 接下來就是針對服務(wù)進(jìn)行控制, 現(xiàn)在,可以使用 ServiceController 類來連接和控制現(xiàn)有服務(wù)的行為。

ServiceController: 表示 Windows 服務(wù)并允許連接到正在運(yùn)行或者已停止的服務(wù)、對其進(jìn)行操作或獲取有關(guān)它的信息。

通過ServiceController,我們可以獲取本機(jī)的Service服務(wù),以及啟動(dòng)、暫停、延續(xù)、掛起、關(guān)閉、刷新等動(dòng)作, 如下所示:

C#中怎么創(chuàng)建控制Windows服務(wù)

下面的示例演示如何使用 ServiceController 類來控制 Service1 服務(wù)示例。

using System;
using System.ServiceProcess;
using System.Diagnostics;
using System.Threading;

namespace ServiceControllerSample
{
    class Program
    {
        public enum SimpleServiceCustomCommands
        { StopWorker = 128, RestartWorker, CheckWorker };
        static void Main(string[] args)
        {
            ServiceController[] scServices;
            scServices = ServiceController.GetServices();

            foreach (ServiceController scTemp in scServices)
            {

                if (scTemp.ServiceName == "Service1")
                {
                    // Display properties for the Simple Service sample
                    // from the ServiceBase example.
                    ServiceController sc = new ServiceController("Simple Service");
                    Console.WriteLine("Status = " + sc.Status);
                    Console.WriteLine("Can Pause and Continue = " + sc.CanPauseAndContinue);
                    Console.WriteLine("Can ShutDown = " + sc.CanShutdown);
                    Console.WriteLine("Can Stop = " + sc.CanStop);
                    if (sc.Status == ServiceControllerStatus.Stopped)
                    {
                        sc.Start();
                        while (sc.Status == ServiceControllerStatus.Stopped)
                        {
                            Thread.Sleep(1000);
                            sc.Refresh();
                        }
                    }
                    // Issue custom commands to the service
                    // enum SimpleServiceCustomCommands
                    //    { StopWorker = 128, RestartWorker, CheckWorker };
                    sc.ExecuteCommand((int)SimpleServiceCustomCommands.StopWorker);
                    sc.ExecuteCommand((int)SimpleServiceCustomCommands.RestartWorker);
                    sc.Pause();
                    while (sc.Status != ServiceControllerStatus.Paused)
                    {
                        Thread.Sleep(1000);
                        sc.Refresh();
                    }
                    Console.WriteLine("Status = " + sc.Status);
                    sc.Continue();
                    while (sc.Status == ServiceControllerStatus.Paused)
                    {
                        Thread.Sleep(1000);
                        sc.Refresh();
                    }
                    Console.WriteLine("Status = " + sc.Status);
                    sc.Stop();
                    while (sc.Status != ServiceControllerStatus.Stopped)
                    {
                        Thread.Sleep(1000);
                        sc.Refresh();
                    }
                    Console.WriteLine("Status = " + sc.Status);
                    String[] argArray = new string[] { "ServiceController arg1", "ServiceController arg2" };
                    sc.Start(argArray);
                    while (sc.Status == ServiceControllerStatus.Stopped)
                    {
                        Thread.Sleep(1000);
                        sc.Refresh();
                    }
                    Console.WriteLine("Status = " + sc.Status);
                    // Display the event log entries for the custom commands
                    // and the start arguments.
                    EventLog el = new EventLog("Application");
                    EventLogEntryCollection elec = el.Entries;
                    foreach (EventLogEntry ele in elec)
                    {
                        if (ele.Source.IndexOf("Service1.OnCustomCommand") >= 0 |
                            ele.Source.IndexOf("Service1.Arguments") >= 0)
                            Console.WriteLine(ele.Message);
                    }
                }
            }
        }
    }
}
//This sample displays the following output if the Simple Service
//sample is running:
//Status = Running
//Can Pause and Continue = True
//Can ShutDown = True
//Can Stop = True
//Status = Paused
//Status = Running
//Status = Stopped
//Status = Running
//4:14:49 PM - Custom command received: 128
//4:14:49 PM - Custom command received: 129
//ServiceController arg1
//ServiceController arg2

安裝WindowsService

能夠控制我們創(chuàng)建的服務(wù)的前提是, 該服務(wù)已安裝在我們調(diào)試的設(shè)備上, 我們可以通過AssemblyInstaller 類來進(jìn)行安裝。

安裝示例

在下面的示例中, AssemblyInstaller 通過調(diào)用 AssemblyInstaller 構(gòu)造函數(shù)來創(chuàng)建。 設(shè)置此對象的屬性,并 Install Commit 調(diào)用和方法以安裝 MyAssembly.exe 程序集。

using System;
using System.Configuration.Install;
using System.Collections;
using System.Collections.Specialized;

class AssemblyInstaller_Example
{
   static void Main()
   {
      IDictionary mySavedState = new Hashtable();

      Console.WriteLine( "" );

      try
      {
         // Set the commandline argument array for 'logfile'.
         string[] commandLineOptions = new string[ 1 ] {"/LogFile=example.log"};

         // Create an object of the 'AssemblyInstaller' class.
         AssemblyInstaller myAssemblyInstaller = new
                     AssemblyInstaller( "MyAssembly.exe" , commandLineOptions );

         myAssemblyInstaller.UseNewContext = true;

         // Install the 'MyAssembly' assembly.
         myAssemblyInstaller.Install( mySavedState );

         // Commit the 'MyAssembly' assembly.
         myAssemblyInstaller.Commit( mySavedState );
      }
      catch (Exception e)
      {
         Console.WriteLine( e.Message );
      }
   }
}

卸載示例

下面的示例演示的 Uninstall 方法 Installer 。 Uninstall方法在的派生類中被重寫 Installer 。

// Override 'Uninstall' method of Installer class.
public override void Uninstall( IDictionary mySavedState )
{
   if (mySavedState == null)
   {
      Console.WriteLine("Uninstallation Error !");
   }
   else
   {
      base.Uninstall( mySavedState );
      Console.WriteLine( "The Uninstall method of 'MyInstallerSample' has been called" );
   }
}

以上就是“C#中怎么創(chuàng)建控制Windows服務(wù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI