亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#用Topshelf創(chuàng)建Windows服務的步驟分享

 更新時間:2020年05月17日 14:40:53   作者:縹緲的塵埃  
這篇文章主要給大家介紹了關(guān)于C#如何利用Topshelf創(chuàng)建Windows服務的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C#具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

一、項目創(chuàng)建

創(chuàng)建一個控制臺應用程序,項目右鍵->管理 NuGet 程序包->Topshelft及Topshelf.Log4Net。

 

   

二、Topshelf配置

    一般來說,服務都會設置每隔多長時間執(zhí)行一次任務,這里使用System.Threading.Timer來做個簡單的日志記錄,將日志寫入到Debug\Log文件夾下。

    2.1、Log4Net配置

    新建一個log4net.config的配置文件,在其屬性的復制到輸出目錄項下選擇始終復制。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <configSections>
 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
 </configSections>
 <log4net>
 <!-- Console部分log輸出格式的設定 -->
 <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
  <layout type="log4net.Layout.PatternLayout">
  <conversionPattern value="%date [%thread] %-5level %logger - %message %newline" />
  </layout>
 </appender>
 <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="Log\"/>
  <appendToFile value="true"/>
  <maxSizeRollBackups value="10"/>
  <maximumFileSize value="1MB"/>
  <rollingStyle value="Date"/>
  <datePattern value='yyyy-MM-dd".log"' />
  <staticLogFileName value="false"/>
  <!--最小鎖定模型以允許多個進程可以寫入同一個文件-->
  <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
  <layout type="log4net.Layout.PatternLayout">
  <conversionPattern value="%date %-5level %logger - %message %newline"/>
  </layout>
 </appender>
 <root>
  <level value="ALL" />
  <appender-ref ref="ConsoleAppender" />
  <appender-ref ref="RollingLogFileAppender" />
 </root>
 </log4net>
</configuration>

    2.2、TopshelfService

    新建一個TopshelfService類:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Topshelf;
using Topshelf.Logging;

namespace LinkTo.Test.TopshelfService
{
  public class TopshelfService : ServiceControl
  {
    private static readonly LogWriter logger = HostLogger.Get<TopshelfService>();
    private static Timer timerAsync = null;
    private readonly int dueTimeInterval = 1000 * 5; //單位:毫秒
    private readonly int periodInterval = 1000 * 5; //單位:毫秒

    /// <summary>
    /// 構(gòu)造函數(shù)
    /// </summary>
    public TopshelfService()
    {
      timerAsync = new Timer(AutoAsyncCallback, null, Timeout.Infinite, Timeout.Infinite);
    }

    /// <summary>
    /// 啟動服務
    /// </summary>
    /// <param name="hostControl"></param>
    /// <returns></returns>
    public bool Start(HostControl hostControl)
    {
      try
      {
        logger.Info("HelloTopshelf Start");
        timerAsync.Change(dueTimeInterval, periodInterval);
      }
      catch (Exception ex)
      {
        logger.Info(ex.Message);
      }
      return true;
    }

    /// <summary>
    /// 停止服務
    /// </summary>
    /// <param name="hostControl"></param>
    /// <returns></returns>
    public bool Stop(HostControl hostControl)
    {
      try
      {
        logger.Info("HelloTopshelf Stop");
        if (timerAsync != null)
        {
          timerAsync.Change(Timeout.Infinite, Timeout.Infinite);
          timerAsync.Dispose();
          timerAsync = null;
        }
      }
      catch (Exception ex)
      {
        logger.Info(ex.Message);
      }
      return true;
    }

    /// <summary>
    /// 回調(diào)函數(shù)
    /// </summary>
    /// <param name="state"></param>
    private void AutoAsyncCallback(object state)
    {
      try
      {
        timerAsync.Change(Timeout.Infinite, Timeout.Infinite);
        logger.Info("AutoAsyncCallback執(zhí)行開始");
        Thread.Sleep(1000 * 10);
      }
      catch (Exception ex)
      {
        logger.ErrorFormat("AutoAsyncCallback執(zhí)行異常:{0}", ex.Message);
      }
      finally
      {
        timerAsync.Change(dueTimeInterval, periodInterval);
        logger.Info("AutoAsyncCallback執(zhí)行結(jié)束");
        logger.Info(Environment.NewLine);
      }
    }
  }
}

    2.3、配置和運行宿主服務

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Topshelf;

namespace LinkTo.Test.TopshelfService
{
  class Program
  {
    static void Main(string[] args)
    {
      HostFactory.Run(x =>
      {
        x.UseLog4Net("log4net.config");
        x.RunAsLocalSystem();
        x.Service(settings => new TopshelfService());
        //服務的描述
        x.SetDescription("你好,Topshelf!");
        //服務的顯示名稱
        x.SetDisplayName("Hello Topshelf Service");
        //服務名稱
        x.SetServiceName("HelloTopshelf");
      });
    }
  }
}

    三、安裝與卸載

    3.1、安裝服務

    在Debug文件夾下面,創(chuàng)建一個"安裝服務.bat"的批處理文件:

@echo on

rem 設置DOS窗口的背景顏色及字體顏色
color 2f

rem 設置DOS窗口大小 
mode con: cols=80 lines=25

@echo off
echo 請按任意鍵開始安裝LinkTo.Test.TopshelfService服務

rem 輸出空行
echo.
pause

LinkTo.Test.TopshelfService install
net start HelloTopShelf

pause

    3.2、卸載服務

    在Debug文件夾下面,創(chuàng)建一個"卸載服務.bat"的批處理文件:

@echo on

rem 設置DOS窗口的背景顏色及字體顏色
color 2f

rem 設置DOS窗口大小 
mode con: cols=80 lines=25

@echo off
echo 請按任意鍵開始卸載LinkTo.Test.TopshelfService服務

rem 輸出空行
echo.
pause

net stop HelloTopShelf
LinkTo.Test.TopshelfService uninstall

pause

    3.3、查看服務

    在運行中輸入"services.msc"進入服務,即可看到新建的HelloTopshelf服務:

    四、添加管理員權(quán)限要求

    項目右鍵->添加->新建項->應用程序清單文件。

 

    將requestedExecutionLevel節(jié)點的level設置為"requireAdministrator"。

<requestedExecutionLevel level="requireAdministrator" uiAccess="false" />

總結(jié)

到此這篇關(guān)于C#用Topshelf創(chuàng)建Windows服務的文章就介紹到這了,更多相關(guān)C#用Topshelf創(chuàng)建Windows服務內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#實現(xiàn)的優(yōu)酷真實視頻地址解析功能(2014新算法)

    C#實現(xiàn)的優(yōu)酷真實視頻地址解析功能(2014新算法)

    這篇文章主要介紹了C#實現(xiàn)的優(yōu)酷真實視頻地址解析功能(2014新算法),本文在當前環(huán)境下是有效的,因為優(yōu)酷之前更新了算法,需要的朋友可以參考下
    2014-10-10
  • c#在程序中定義和使用自定義事件方法總結(jié)

    c#在程序中定義和使用自定義事件方法總結(jié)

    在本篇文章中小編給大家整理了關(guān)于c#在程序中定義和使用自定義事件方法總結(jié)相關(guān)知識點,需要的朋友們學習下。
    2019-03-03
  • C#面向?qū)ο筇卣鞯木唧w實現(xiàn)及作用詳解

    C#面向?qū)ο筇卣鞯木唧w實現(xiàn)及作用詳解

    所有的面相對象思想,歸根結(jié)底是為了簡化代碼,減少代碼量,構(gòu)建更符合現(xiàn)實生活邏輯的程序代碼,從而減輕程序員的負擔。不能一味地或者說刻意地去使用面相對象的思想而忽略了程序所實現(xiàn)的功能或者框架,要根據(jù)實際情況
    2013-10-10
  • C#中對象狀態(tài)模式教程示例

    C#中對象狀態(tài)模式教程示例

    這篇文章主要為大家介紹了C#中對象狀態(tài)模式的教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • C# 中的IComparable和IComparer的使用及區(qū)別

    C# 中的IComparable和IComparer的使用及區(qū)別

    這篇文章主要介紹了C# 中的IComparable和IComparer的使用及區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-01-01
  • C#使用AnimateWindow()實現(xiàn)動畫窗體的方法

    C#使用AnimateWindow()實現(xiàn)動畫窗體的方法

    用API函數(shù)AnimateWindow函數(shù)來實現(xiàn)窗體的動畫效果,在C#中,你可以使用P/Invoke技術(shù)調(diào)用Windows API中的AnimateWindow函數(shù)來實現(xiàn)動畫窗體,本文就給大家介紹了C#使用AnimateWindow()實現(xiàn)動畫窗體的方法,感興趣的朋友可以參考下
    2024-04-04
  • 基于WPF實現(xiàn)驗證碼控件

    基于WPF實現(xiàn)驗證碼控件

    這篇文章主要介紹了如何利用WPF實現(xiàn)一個簡單的驗證碼控件,文中的示例代碼講解詳細,對我們學習或工作有一定幫助,需要的可以參考一下
    2022-08-08
  • C#基礎知識之new關(guān)鍵字介紹

    C#基礎知識之new關(guān)鍵字介紹

    在 C# 中,new 關(guān)鍵字可用作運算符、修飾符或約束,本文主要介紹這三種用法。
    2016-04-04
  • C#中計算時間差中的小數(shù)問題解決

    C#中計算時間差中的小數(shù)問題解決

    C#中計算時間差中的小數(shù)問題解決需要的朋友可以參考一下
    2013-03-03
  • C++實現(xiàn)日期類的示例詳解

    C++實現(xiàn)日期類的示例詳解

    這篇文章主要為大家詳細介紹了四個C++常用的日期類的實現(xiàn),文中的示例代碼講解詳細,對我們學習C++有一定的幫助,需要的可以參考一下
    2023-02-02

最新評論