1#

转自:http://www.cnblogs.com/shanyou/archive/2011/05/04/2037008.html

使用Topshelf创建Windows 服务简要的介绍了创建Windows服务的另一种方法,老外的一篇文章Create a .NET Windows Service in 5 steps with Topshelf通过5个步骤详细的介绍使用使用Topshelf创建Windows 服务。Topshelf是一个开源的跨平台的宿主服务框架,支持Windows和Mono,只需要几行代码就可以构建一个很方便使用的服务宿主。

1、Topshelf的代码托管在http://topshelf-project.com/,可以在这里下载到最新的代码。

2、使用Visual Studio创建一个控制台应用程序引用程序集TopShelf.dll 合log4net.dll 。

3、创建一个简单的服务类,里面包含两个方法Start和Stop,这个服务只是演示代码,所以我们每隔5秒输出一个日志。

  1. using System;
  2. using System.Timers;
  3. using log4net;

  4. namespace SampleWindowsService
  5. {
  6. public class SampleService
  7. {
  8. private Timer _timer = null;
  9. readonly ILog _log = LogManager.GetLogger(typeof(SampleService));

  10. public SampleService()
  11. {
  12. double interval = 5000;
  13. _timer = new Timer(interval);
  14. _timer.Elapsed += new ElapsedEventHandler(OnTick);
  15. }

  16. protected virtual void OnTick(object sender, ElapsedEventArgs e)
  17. {
  18. _log.Debug("Tick:" + DateTime.Now.ToLongTimeString());
  19. }

  20. public void Start()
  21. {
  22. _log.Info("SampleService is Started");

  23. _timer.AutoReset = true;
  24. _timer.Enabled = true;
  25. _timer.Start();
  26. }

  27. public void Stop()
  28. {
  29. _log.Info("SampleService is Stopped");

  30. _timer.AutoReset = false;
  31. _timer.Enabled = false;
  32. }
  33. }
  34. }
复制代码
4、在Main方法中使用Topshelf宿主我们的服务,主要是告诉Topshelf如何设置我们的服务的配置和启动和停止的时候的方法调用。
  1. using System.IO;
  2. using log4net.Config;
  3. using Topshelf;

  4. namespace SampleWindowsService
  5. {
  6. class Program
  7. {
  8. static void Main(string[] args)
  9. {
  10. XmlConfigurator.ConfigureAndWatch(
  11. new FileInfo(".\\log4net.config"));

  12. var host = HostFactory.New(x =>
  13. {
  14. x.EnableDashboard();
  15. x.Service<SampleService>(s =>
  16. {
  17. s.SetServiceName("SampleService");
  18. s.ConstructUsing(name => new SampleService());
  19. s.WhenStarted(tc =>
  20. {
  21. XmlConfigurator.ConfigureAndWatch(
  22. new FileInfo(".\\log4net.config"));
  23. tc.Start();
  24. });
  25. s.WhenStopped(tc => tc.Stop());
  26. });

  27. x.RunAsLocalSystem();
  28. x.SetDescription("SampleService Description");
  29. x.SetDisplayName("SampleService");
  30. x.SetServiceName("SampleService");
  31. });

  32. host.Run();
  33. }
  34. }
  35. }
复制代码
4、配置Log4net和运行我们的服务,服务可以当作控制台来运行,这在开发的时候是非常方便的。服务的安装很方便
SampleWindowsService.exe install
安装成功后,可以通过服务控制台启动,或者也可以通过一下命令运行
SampleWindowsService.exe start
服务的卸载方法也非常简单了
SampleWindowsService.exe uninstall