如何做個自己想要的Window Server了?

喜歡吃魚的青年發表於2020-08-06

前言說明

  • 使用工具:VS2019
  • 思考為什麼要使用WindowServer,它能做什麼了?(後面解答)

一:什麼是WindowServer?(我們做的是一個什麼東西?)

        Microsoft Windows 服務(過去稱為 NT 服務)允許使用者建立可在其自身的 Windows 會話中長時間執行的可執行應用程式。(微軟爸爸是這麼解釋,簡單介紹)
        我的理解,它就是一個掛載在我們系統上的服務,我們系統上服務其實有很多,比如我們的Sql資料庫的服務:MSSQLSERVER,這個是啟動資料庫的一個服務,開啟這個服務我們才能連線本地的安裝的SQL。那WindowServer應該也是一個這樣的服務,可以理解是一個可以讓我們自定義開發的服務。

二:如何建立WindowServer?(我們知道是什麼東西,怎麼做?)

1.開啟VS2019,類別選擇服務,選擇Windows服務類別

2.新增安裝程式



安裝之後,目錄會新增新檔案

2.1看看這兩個檔案
serviceInstaller1:


用的多的屬性:

  • DelayedAutoStart:是否自動啟動
  • Descrition:介紹服務(自定義)
  • DisplayName:標識伺服器友好名稱(自定義)
serviceProcessInstaller1:

  • Account:設定為LocalSystem(執行此服務的賬戶型別)

到此,一個服務就寫好,只是他還沒有任何靈魂(業務邏輯)

三:怎麼編寫我們的業務邏輯?(在哪裡注入我們的靈魂)

3.1開啟Service1類,按F7進入程式碼介面,如下圖所示:


當前類有3個方法:

  • Service1:建構函式
  • OnStart:啟動服務時會觸發的方法(可以傳遞引數)
  • OnStop:結束服務時會觸發的方法

3.2我們在OnStart和OnStop進行日誌列印,程式碼如下:

  public Service1()
        {
            InitializeComponent();
            eventLog1 = new System.Diagnostics.EventLog();
            if (!System.Diagnostics.EventLog.SourceExists("MySource"))
            {
                System.Diagnostics.EventLog.CreateEventSource(
                    "MySource", "MyNewLog");
            }
            eventLog1.Source = "MySource";
            eventLog1.Log = "MyNewLog";
        }

        protected override void OnStart(string[] args)
        {
            eventLog1.WriteEntry("In OnStart.");
            LogHelper.loginfo.Info("In OnStart.");
        }

        protected override void OnStop()
        {
            eventLog1.WriteEntry("In OnStop.");
            LogHelper.loginfo.Info("In OnStop.");
        }

這裡,我使用兩種日誌進行列印我們的日誌資訊

  • EventLog:這個是系統自帶一個控制元件(也是微軟教程中使用的日誌記錄)
  • log4net:這個是一個第三方庫日誌程式集

看看效果:

Eventlog:(日誌數量有限制,超過一定的數量就不會在顯示了)

log4net:(自定義,想怎麼存,怎麼存【推薦】)

四:編寫好的服務,如何安裝?(安裝發動機)

4.1首先編譯程式(快捷鍵:CtrL+Shift+B),生成專案

4.2找到目標檔案

  • 右鍵專案,選擇在檔案資源管理器中開啟資料夾
  • 找到Debug資料夾下面字尾為****.exe程式
  • 賦值路徑:絕對路徑,類是於:[D:****.exe]
  • 看看路徑【C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio 2019\Visual Studio Tools】,找到工具:Developer Command Prompt for VS 2019允許啟動

4.3 在開啟的CMD【就是上面開啟的Developer Command Prompt for VS 2019程式,不是我們Win+R開啟的】中,輸入命令:

InstallUtil.exe C:\**\test\bin\Debug\test.exe


如上圖示識已經安裝成功!

五:安裝好,如何啟動?(點火啟動)

輸入命令:

net start 你定義的服務的名稱【二:如何建立WindowServer=>2.新增安裝程式=>DisplayName】

如上圖表示啟動成功

六:不想用了,如何停止?(關火休息)

輸入命令:

net stop 你定義的服務的名稱【二:如何建立WindowServer=>2.新增安裝程式=>DisplayName】

如上圖表示關閉成功

七:不想要了,如何解除安裝?(拆掉髮動機)

輸入命令:

InstallUtil.exe /u C:\**\test\bin\Debug\test.exe

如上圖表示解除安裝成功

1.找到 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio 2019\Visual Studio Tools】,找到工具:Developer Command Prompt for VS 2019 啟動

2.輸入InstallUtil.exe D:\**\**.exe,回車安裝服務

3.輸入:net start SundyServer (啟動服務)

4.輸入:net stop SundyServer (停止服務)

5.輸入InstallUtil.exe /u  D:\**\**.exe 解除安裝服務

八:參考文件

建立 Windows 服務應用

九:總結

我為什麼要做這個WindwoServer,是公司需要做一個運維軟體,需要編寫一個Windows服務,我也是看著官方文件學習的,業務邏輯比較簡單, 開發也挺快的。
自己對Window服務理解,我們其實這種服務也是一個程式,只是它整合到Windows系統服務中,這樣有一個好處,可以設定開機自動啟動,而且還神不知鬼不覺,在客戶電腦上安裝,客戶也不知道,我們是做運維監控,不是幹壞事。可以把一些需要執行的任務,做成服務,放在伺服器或自己電腦服務上,就可以自動跑,設定開機自起。

十:不足的地方

  • 本文沒有介紹 EventLog是怎麼來:這個在工具箱中,可以找到,然後點選Service1,做進來就行了
  • 服務預設是啟動和停止方法,還可以擴充套件,有暫停,恢復,這兩個方法,需要我們重寫才能觸發事件

相關文章