C#/.NET基於Topshelf創建Windows服務程式及服務的安裝和卸載(極速,簡潔)

来源:https://www.cnblogs.com/bobositlife/archive/2019/04/12/create-windows-service-with-topshelf-in-csharp-console-application.html
-Advertisement-
Play Games

對於使用Windows操作系統的人來說,Windows Service(Windows服務)應該不會陌生。在Windows操作系統中,我們可以在”運行”視窗中運行service.msc,即可打開一個查看Windows服務的視窗。Windows服務基本都是一些後臺運行的服務進程,沒有UI界面,每個服務... ...


本文首發於:碼友網--一個專註.NET/.NET Core開發的編程愛好者社區。

文章目錄

C#/.NET基於Topshelf創建Windows服務的系列文章目錄:

  1. C#/.NET基於Topshelf創建Windows服務程式及服務的安裝和卸載 (1)
  2. 在C#/.NET應用程式開發中創建一個基於Topshelf的應用程式守護進程(服務) (2)
  3. C#/.NET基於Topshelf創建Windows服務的守護程式作為服務啟動的客戶端桌面程式不顯示UI界面的問題分析和解決方案 (3)

前言

對於使用Windows操作系統的人來說,Windows Service(Windows服務)應該不會陌生。在Windows操作系統中,我們可以在"運行"視窗中運行service.msc

即可打開一個查看Windows服務的視窗,如圖:

Windows服務基本都是一些後臺運行的服務進程,沒有UI界面,每個服務處理著各自獨立的任務並且有專門的啟動或者停止策略。所以,Windows服務在很多情況下會被用來者處理一些定時任務或者調度。

那麼,對於.NET的開發者來說,可不可以自己創建Windows服務呢,如何使用C#創建Windows服務呢?

本文就為大家分享一種基於Topshelf創建的Windows服務的方法。

創建Topshelf服務項目

首先打開Visual Studio(本文使用的是Visual Studio 2019),打開新建項目的對話框,選擇.NET Framework的控制台應用程式(Console App(.NET Framework)),如圖:

註:只可選擇控制台應用程式

點擊"下一步",在項目名稱中輸入TopshelfDemoService,.NET Framework 選擇4.6.2,其中選項根據自己情況填寫即可,最後點擊"創建"按鈕。

安裝Topshelf組件

TopshelfDemoService項目中,打開Nuget包管理工具,搜索Topshelf,在搜索結果中選中Topshelf,點擊"安裝",如圖:

編寫Topshelf服務的示常式序代碼

Topshelf組件安裝完成後,我們就可以開始編寫服務的示例代碼了。

首先,創建一個名為HealthMonitorService.cs的類(其作用假設為定時監控某個系統的運行健康狀況),在其中分別創建方法:Start()Stop()以及一個定時器,讓定時器定時執行檢查系統健康狀況的任務(這裡模擬的每秒向控制台輸出一條文本信息),完整的代碼如下:

using System;
using System.Timers;

namespace TopshelfDemoService
{
    internal class HealthMonitorService
    {
        private readonly Timer _timer;
        public HealthMonitorService()
        {
            _timer = new Timer(1000) { AutoReset = true };
            _timer.Elapsed += (sender, eventArgs) => Console.WriteLine("執行系統健康檢查任務,所有指標均正常。執行時間:{0}", DateTime.Now);
        }

        public void Start()
        {
            _timer.Start();
        }
        public void Stop()
        {
            _timer.Stop();
        }
    }
}

再創建一個名為MyServiceConfigure.cs的服務配置類,這個類主要用來配置Topshelf服務的各種運行參數,代碼如下:

using System;
using Topshelf;

namespace TopshelfDemoService
{
    internal class MyServiceConfigure
    {
        internal static void Configure()
        {
            var rc = HostFactory.Run(host =>                                    // 1
            {
                host.Service<HealthMonitorService>(service =>                   // 2
                {
                    service.ConstructUsing(() => new HealthMonitorService());   // 3
                    service.WhenStarted(s => s.Start());                        // 4
                    service.WhenStopped(s => s.Stop());                         // 5
                });

                host.RunAsLocalSystem();                                        // 6

                host.EnableServiceRecovery(service =>                           // 7
                {
                    service.RestartService(3);                                  // 8
                });
                host.SetDescription("Windows service based on topshelf");       // 9
                host.SetDisplayName("Topshelf demo service");                   // 10
                host.SetServiceName("TopshelfDemoService");                     // 11
                host.StartAutomaticallyDelayed();                               // 12
            });

            var exitCode = (int)Convert.ChangeType(rc, rc.GetTypeCode());       // 13
            Environment.ExitCode = exitCode;
        }
    }
}

註:其中數字的含義請見本文末尾的解釋。

最後,打開Program.cs文件,開啟Topshelf服務,如下:

namespace TopshelfDemoService
{
    class Program
    {
        static void Main(string[] args)
        {
            MyServiceConfigure.Configure();
        }
    }
}

好了,完成到這裡,整個示常式序就寫好了,按F5運行示常式序,你將看到如下類似的控制台信息:

可以看到,我們創建的TopshelfDemoService服務每秒向控制台列印了一條文本信息,這和我們的預期是吻合的。

這樣,我們就成功創建了一個基於Topshelf的Windows服務,當然,這也只是一個簡單和示例服務程式,其中沒有複雜的業務邏輯和配置等等。這些都等待你去發掘。

作為Windows服務安裝和卸載

我們剛纔運行的只是一個控制台應用程式,如果將這個控制台應用程式關掉,定時任務也會被停止了。如果我們希望定時任務可以一直運行,那需要將這個控制台應用程式作為服務安裝到Windows服務進程中,如何操作呢?

非常簡單的安裝和卸載命令。

首先,以管理員身份打開一個命令行工具,進入到控制台應用程式所在目錄。

安裝

安裝服務運行如下命令:

TopshelfDemoService.exe install

打開Windows服務查看視窗(刷新),可以看到Topshelf demo service已經在服務列表中了,如圖:

這時,我們只需要按照Windows服務來操作這個服務即可。

卸載

如果需要卸載服務,則運行如下命令:

TopshelfDemoService.exe uninstall

Topshelf配置參數說明

1.設置服務主機使用HostFactory.Run()來創建並運行一個Topshelft服務。
2.設置Topshelf使用類型HealthMonitorService作為服務類。
3.配置如何創建一個服務的實例,這裡採用的是使用關鍵字new來實例化一個HealthMonitorService對象,你也可以使用IoCp容器來實例化服務對象。
4.設置當服務啟動時執行的操作。
5.設置當服務停止時執行的操作。
6.設置將服務以本地系統身份運行。
7.啟動恢復服務模式(當服務意外停止後自動恢復)。
8.設置第一次自動恢復服務的延遲時間為3分鐘。
9.設置Topshelf服務在Windows服務中的描述信息。
10.設置Topshelf服務在Windows服務中的顯示名稱。
11.設置Topshelf服務在Windows服務中的服務名稱。
12.設置Topshelf服務隨Windows啟動時自動運行(延遲)。
13.設置服務的退出代碼。

示例代碼托管和下載

本示例代碼托管地址可以在原出處找到:示例代碼下載地址


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • yyyyyyyyyyyyyyyyyyyyyyy yyyyyyyyyyyyyyyyyyyyyyy ...
  • 使用 ASP.NET Core MVC 創建 Web API 使用 ASP.NET Core MVC 創建 Web API(一) 使用 ASP.NET Core MVC 創建 Web API(二) 十、添加 GetBookItem 方法 1) 在Visual Studio 2017中的“解決方案資源 ...
  • 索引: 目錄索引 一.API 列表 1.Set<M, F>(Expression<Func<M, F>> propertyFunc, F newVal) 如: .Set(it => it.BodyMeasureProperty, "{xxx:yyy,mmm:nnn,zzz:aaa}") 用於 單表 ...
  • 今天自己開發了一個訂機票的微信公眾號,功能基本已經完成,然後想部署到伺服器實際測試下。結果部署上去出現各種問題。先安裝asp.net core模塊,然後發現資料庫並不像在開發時一樣,執行ef的命令行語句就可以了。可以到輸出目錄找到對應的sql語句,到伺服器上執行一下。 後來部署上去以後,發現很多對應... ...
  • 轉自:https://blog.csdn.net/jie_liang/article/details/77340905 用以記錄: 在sql查詢中為了提高查詢效率,我們常常會採取一些措施對查詢語句進行sql優化,下麵總結的一些方法,有需要的可以參考參考。 1.對查詢進行優化,應儘量避免全表掃描,首先 ...
  • //通過ClassName獲取div,使用setAttribute設置div禁止點擊 pointer-events: none;是css3新出現的屬性,意思就是禁止滑鼠點擊事件,當元素中有這一屬性時,鏈接、點擊事件統統失效 ...
  • 通過註解(特性)的方式進行對象的註冊與註入,方便,靈活! 本篇主要講如何去實現,下一篇主要講如何把它集成到mvc和api環境里,實現自動的註入! spring ioc工作的過程大致為,統一的註冊組件,攔截當前請求,統一的註入當前請求所需要的組件,事實上,說到這事,.net也完全可以實現這個功能和工作 ...
  • 看這個方案之前,先說明下為什麼要加入SSO,以防對大家產生不好的影響。我們產品使用傳統winform+db服務+Db存儲方式開發,一群老菜幫子開發,以傳統的datatble做數據傳遞,很多年了未有變化。 然後我來了,感覺我這個老菜幫子都受不了這種開發,然後下定決心,作了一些封裝,看起來有點像orm的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...