Windows Service的安装卸载 和 Service控制

原文地址:http://www.cnblogs.com/Peter-Zhang/archive/2011/10/15/2212663.html

  本文内容包括如何通过C#代码安装Windows Service(exe文件,并非打包后的安装文件)、判断Service是否存在、获得Service状态及启动停止Service。

  创建Windows Service项目并Build得到exe文件,如何创建 Service 可参考 创建windows service 并打包成安装文件

一、 Windows服务的安装和卸载

  安装和卸载服务可以使用 .NET 工具installutil.exe (eg:安装-> installutil xxx.exe 卸载-> installutil /u xxx.exe),使用ManagedInstallerClass可以实现安装卸载Windows 服务,ManagedInstallerClass 在System.Configuration.Install命名空间下。

  实现如下:

         ///<summary> /// 使用Windows Service对应的exe文件 安装Service
/// 和 installutil xxx.exe 效果相同
///</summary> ///<param name="installFile">exe文件(包含路径)</param> ///<returns>是否安装成功</returns> public static bool InstallServie(string installFile)
{
string[] args = { installFile };
try
{
ManagedInstallerClass.InstallHelper(args);
return true;
}
catch
{
return false;
}
} ///<summary> /// 使用Windows Service对应的exe文件 卸载Service
/// 和 installutil /u xxx.exe 效果相同
///</summary> ///<param name="installFile">exe文件(包含路径)</param> ///<returns>是否卸载成功</returns> public static bool UninstallService(string installFile)
{
string[] args = { "/u", installFile };
try
{
// 根据文件获得服务名,假设exe文件名和服务名相同 string tmp = installFile;
if (tmp.IndexOf('\\') != -)
{
tmp = tmp.Substring(tmp.LastIndexOf('\\') + );
}
string svcName = tmp.Substring(, tmp.LastIndexOf('.'));
// 在卸载服务之前 要先停止windows服务 StopService(svcName); ManagedInstallerClass.InstallHelper(args);
return true;
}
catch
{
return false;
}
}

  注意: 服务删除前需要先停止服务,否则服务被标记为禁用,并无法删除。原因:系统删除服务时,首先是标记服务为“删除”,等待服务的所有引用完全断开后,服务才被完全删除。当服务引用未完全断开时,就删除服务,系统将服务锁死为“禁用”状态,并禁止其他操作,注意此时服务尚未完全删除。所以对已删除后立即重装的服务,需要完全释放与服务相关的所有引用,此时系统才真正完全删除服务,之后才能再次安装服务。如果出现服务禁用问题,检查代码,哪些地方有服务引用,同时检查是否其他程序还在引用,也要终止这些引用程序。

二、Windows服务的状态获取和控制

  使用ServiceController来获取服务状态或对服务进行控制。

  ServiceController 表示 Windows 服务并允许连接到正在运行或者已停止的服务、对其进行操作或获取有关它的信息。使用 ServiceController类连接到现有服务并控制其行为。当创建 ServiceController 类的实例时,设置其属性,以便它与特定的 Windows 服务交互作用。然后可以使用此类来启动、停止和以其他方式操作该服务。创建实例后,必须为其设置两个属性来标识与其交互的服务:计算机名称和要控制的服务的名称。默认情况下,MachineName 设置为本地计算机,因此不需要更改它,除非想将该实例设置为指向另一台计算机。

  服务可以处理的命令集取决于该服务的属性;例如,可以将服务的 CanStop 属性设置为 false。该设置使 Stop 命令在那个特定的服务上不可用;它禁用了必要的按钮,使您无法从 SCM 中停止服务。如果试图通过代码停止服务,系统将引发错误,并显示错误信息“未能停止 servicename”。

常用操作如下:

  1.  获得Service对应的ServiceController实例

         ///<summary> /// 获得service对应的ServiceController对象  ///</summary> ///<param name="serviceName">服务名</param> ///<returns>ServiceController对象,若没有该服务,则返回null</returns>         public static ServiceController GetService(string serviceName)          {              ServiceController[] services = ServiceController.GetServices();              foreach (ServiceController s in services)              {                  if (s.ServiceName == serviceName)                  {                      return s;                  }              }              return null;          }

  2.  检查指定的服务是否存在

         ///<summary> /// 检查指定的服务是否存在。
///</summary> ///<param name="serviceName">要查找的服务名字</param> ///<returns>是否存在</returns> public static bool ServiceExisted(string serviceName)
{
if (GetService(serviceName) == null)
{
return false;
}
else
{
return true;
}
}

  3. 获得服务详细信息

         ///<summary> /// 获得Service的详细信息  ///</summary> ///<param name="serviceName">服务名</param> ///<returns>Service信息,保存在string中</returns>         public static string GetServiceInfo(string serviceName)          {              StringBuilder details = new StringBuilder();                ServiceController sc = GetService(serviceName);                if (sc == null)              {                  return string.Format("{0} 不存在!", serviceName);              }                details.AppendLine(string.Format("服务标识的名称: {0}", sc.ServiceName));              details.AppendLine(string.Format("服务友好名称:{0}", sc.DisplayName));              details.AppendLine(string.Format("服务在启动后是否可以停止: {0}", sc.CanStop));              details.AppendLine(string.Format("服务所驻留的计算机的名称: {0}", sc.MachineName)); // "." 表示本地计算机             details.AppendLine(string.Format("服务类型: {0}", sc.ServiceType.ToString()));              details.AppendLine(string.Format("服务状态: {0}", sc.Status.ToString()));                // DependentServices 获取依赖于与此 ServiceController 实例关联的服务的服务集。             StringBuilder dependentServices = new StringBuilder();              foreach (ServiceController s in sc.DependentServices)              {                  dependentServices.Append(s.ServiceName + ", ");              }              details.AppendLine(string.Format("依赖于与此 ServiceController 实例关联的服务的服务: {0}", dependentServices.ToString()));                            // ServicesDependedOn 此服务所依赖的服务集。             StringBuilder serviceDependedOn = new StringBuilder();              foreach (ServiceController s in sc.ServicesDependedOn)              {                  serviceDependedOn.Append(s.ServiceName + ", ");              }              details.AppendLine(string.Format("此服务所依赖的服务: {0}", serviceDependedOn.ToString()));                return details.ToString();          }

  4.  启动服务

         ///<summary> /// 启动服务
///</summary> ///<param name="serviceName">服务名</param> ///<returns>是否启动成功</returns> public static bool StartService(string serviceName)
{
ServiceController sc = GetService(serviceName); if (sc.Status != ServiceControllerStatus.Running)
{
try
{
sc.Start();
sc.WaitForStatus(ServiceControllerStatus.Running); // 等待服务达到指定状态 }
catch
{
return false;
}
} return true;
}

  5.  停止服务

         ///<summary> /// 停止服务  ///</summary> ///<param name="serviceName">服务名</param> ///<returns>是否停止服务成功,如果服务启动后不可以停止,则抛异常</returns>         public static bool StopService(string serviceName)          {              ServiceController sc = GetService(serviceName);                if (!sc.CanStop)              {                  throw new Exception(string.Format("服务{0}启动后不可以停止.", serviceName));              }                if (sc.Status != ServiceControllerStatus.Stopped)              {                  try                  {                      sc.Stop();                      sc.WaitForStatus(ServiceControllerStatus.Stopped);  // 等待服务达到指定状态                 }                  catch                  {                      return false;                  }              }                return true;          }
 
 
 

Windows Service的安装卸载 和 Service控制(转)的更多相关文章

  1. Windows Service的安装卸载 和 Service控制

    原文 Windows Service的安装卸载 和 Service控制 本文内容包括如何通过C#代码安装Windows Service(exe文件,并非打包后的安装文件).判断Service是否存在. ...

  2. Windows服务的安装卸载及错误查找

    @echo off echo 清理原有服务项. . . %SystemRoot%\Microsoft.NET\Framework\v4.0.30319\installutil /U D:\abc\te ...

  3. window service 批处理安装/卸载命令

    开启服务 @echo.服务启动...... @echo off @sc create 服务名 binPath= "C:\Users\Administrator\Desktop\win32sr ...

  4. WCF 下的windows服务的安装卸载

    安装:启动vs2010(如果是win2008要以管理员来启动)命令:installutil demo.exe 卸载:先在服务里停止这个服务,然后启动vs2010(如果是win2008要以管理员来启动) ...

  5. C# Windows服务创建安装卸载

    一.创建Windows服务 使用VS创建一个新的windows服务应用程序 创建完成之后 二.相关配置 修改Service1名称为StartService(可以不改,自行选择) 添加安装程序并修改配置 ...

  6. windows系统命令服务安装卸载

    安装: sc create PDW.CHM.WebAPI binPath= "%~dp0PDW.CHM.WebAPI.exe" start= autosc start PDW.CH ...

  7. 通过批处理进行Windows服务的安装/卸载&启动/停止

    安装服务 @echo off set checked=2 set PATHS=%~sdp0 echo 按任意键执行安装……? pause>nul if %checked% EQU 2 ( %PA ...

  8. Windows Service 开发,安装与调试

    Visual Studio.net 2010 Windows Service 开发,安装与调试 本示例完成一个每隔一分钟向C:\log.txt文件写入一条记录为例,讲述一个Windows Servic ...

  9. C#Windows Service服务程序的安装/卸载、启动/停止 桌面客户端管理程序设计

    C#Windows Service服务程序的安装/卸载.启动/停止 桌面客户端管理程序设计 关于Windows Service程序的安装与卸载如果每次使用命令行操作,那简直要奔溃了,太麻烦而且还容易出 ...

随机推荐

  1. ClassNotFoundException异常的解决方法

    java.lang.ClassNotFoundException 说是某个类没有找到,找了下,发现这个类是在项目里面的,那么久奇怪了,为什么应用找不到这个类, 然后用mvn install -Dmav ...

  2. SQL开发利器SQL Prompt

    SQL开发利器SQL Prompt 5.1完全破解+使用教程 - keepfool - 博客园 http://www.cnblogs.com/keepfool/archive/2012/05/27/2 ...

  3. Redis配制说明

    配置文件参数说明:  1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程     daemonize no 2. 当Redis以守护进程方式运行时,Redis默 ...

  4. RegisterClientScriptBlock 与 RegisterStartupScript 的区别

    RegisterClientScriptBlock.RegisterStartupScript 都是注册一个脚本块. ClientScript.RegisterClientScriptBlock(th ...

  5. C# 用正则表达式替换字符串中所有特殊字符

    descriptionXML = Regex.Replace(ToDBC(descriptionXML.ToUpper().Replace((char)32, ' ').Replace((char)1 ...

  6. c++builder6.0 mdi窗体+自定义子窗体

  7. java: org.luaj.vm2.LuaError:XXX module not found lua脚本初始化出错

    我遇到这个错误是因为在引用脚本目录时,设置错了位置.设置成脚本所在目录的上级目录. lua使用和加载初始化方法 在java中使用lua,使用需要引用 luaj-jse-2.0.2.jar 同时需要使用 ...

  8. Git Step by Step

    原文地址:http://www.cnblogs.com/wilber2013/category/643754.html 1.Git简介 2.Git本地仓库 3.Git对象模型 4.探索.git目录 5 ...

  9. repo安装

    repo是使用python开发的一个用于多版本管理的工具,可以和git协作,简化git的多版本管理. repo安装: 1.新建~/bin,并将此目录包含在path变量中(如果已存在,且已在path变量 ...

  10. python第一个hello world注意问题!!

    如果你第一次写python代码,想写一个通常的hello world ,那么你需要注意这个hello world的写法,这和python的版本有直接关系!!! Python 3.x: print('h ...