欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

一、項(xiàng)目創(chuàng)建

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

 

   

二、Topshelf配置

    一般來(lái)說(shuō),服務(wù)都會(huì)設(shè)置每隔多長(zhǎng)時(shí)間執(zhí)行一次任務(wù),這里使用System.Threading.Timer來(lái)做個(gè)簡(jiǎn)單的日志記錄,將日志寫入到Debug\Log文件夾下。

    2.1、Log4Net配置

    新建一個(gè)log4net.config的配置文件,在其屬性的復(fù)制到輸出目錄項(xiàng)下選擇始終復(fù)制。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <configSections>
 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
 </configSections>
 <log4net>
 <!-- Console部分log輸出格式的設(shè)定 -->
 <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"/>
  <!--最小鎖定模型以允許多個(gè)進(jìn)程可以寫入同一個(gè)文件-->
  <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

    新建一個(gè)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>
    /// 啟動(dòng)服務(wù)
    /// </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>
    /// 停止服務(wù)
    /// </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、配置和運(yùn)行宿主服務(wù)

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());
        //服務(wù)的描述
        x.SetDescription("你好,Topshelf!");
        //服務(wù)的顯示名稱
        x.SetDisplayName("Hello Topshelf Service");
        //服務(wù)名稱
        x.SetServiceName("HelloTopshelf");
      });
    }
  }
}

    三、安裝與卸載

    3.1、安裝服務(wù)

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

@echo on

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

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

@echo off
echo 請(qǐng)按任意鍵開始安裝LinkTo.Test.TopshelfService服務(wù)

rem 輸出空行
echo.
pause

LinkTo.Test.TopshelfService install
net start HelloTopShelf

pause

    3.2、卸載服務(wù)

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

@echo on

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

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

@echo off
echo 請(qǐng)按任意鍵開始卸載LinkTo.Test.TopshelfService服務(wù)

rem 輸出空行
echo.
pause

net stop HelloTopShelf
LinkTo.Test.TopshelfService uninstall

pause

    3.3、查看服務(wù)

    在運(yùn)行中輸入"services.msc"進(jìn)入服務(wù),即可看到新建的HelloTopshelf服務(wù):

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

    項(xiàng)目右鍵->添加->新建項(xiàng)->應(yīng)用程序清單文件。

 

    將requestedExecutionLevel節(jié)點(diǎn)的level設(shè)置為"requireAdministrator"。

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

總結(jié)

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

    C#使用AnimateWindow()實(shí)現(xiàn)動(dòng)畫窗體的方法

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

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

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

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

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

    C#中計(jì)算時(shí)間差中的小數(shù)問(wèn)題解決

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

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

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

最新評(píng)論