`

删除windows服务的方法

阅读更多
引用
我们一般很少用命令SC来删除windows服务,今天特地介绍一下

删除服务命令为:sc delete "服务名"


下面是关于sc命令说明

SC与“服务控制器”和已安装设备进行通讯。SC.exe 检索和设置有关服务的控制信息。可以使用 SC.exe 来测试和调试服务程序。可以设置存储在注册表中的服务属性来控制如何在启动时和作为后台程序运行时启动服务应用程序。SC.exe 的参数可以配置指定的服务,检索当前服务的状态,也可以停止和启动服务。可以生成批处理文件来调用不同的 SC.exe 命令以自动启动或关闭服务序列。SC.exe 提供的功能类似于“控制面板”中“管理工具”项中的“服务”。

有关命令的语法,请单击下面任一 sc 命令:

sc boot

表明最近的启动是否应该存储为上次已知的正确配置。

语法
sc [ServerName] boot [{bad | OK}]

参数
ServerName
指定服务所在的远程服务器名称。名称必须采用通用命名约定 (UNC) 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
[{bad | OK}]
指定最近的启动是否错误或它是否应该存储为上次已知的正确配置。
/?
在命令提示符下显示帮助。
示例
下面的示例显示了如何使用 sc boot 命令:

sc boot ok
sc boot bad

sc config

修改注册表和“服务控制管理器”数据库中的服务项的值。

语法
sc [ServerName] config [ServiceName] [type= {own | share | kernel | filesys | rec | adapt | interact type= {own | share}}] [start= {boot | system | auto | demand | disabled}] [error= {normal | severe | critical | ignore}] [binpath= BinaryPathName] [group= LoadOrderGroup] [tag= {yes | no}] [depend= dependencies] [obj= {AccountName | ObjectName}] [displayname= DisplayName] [password= Password]

参数
ServerName
指定服务所在的远程服务器名称。名称必须采用通用命名约定 (UNC) 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
type= {own | share | kernel | filesys | rec | adapt | interact type= {own | share}}
指定该服务类型。 值 描述
own 服务以其自身的进程运行。不与其他服务共享可执行文件。这是默认设置。
share 服务作为共享进程运行。它与其他服务共享一可执行文件。
kernel 驱动程序。
filesys 文件系统驱动程序。
rec 文件系统识别驱动程序(标识计算机上使用的文件系统)。
adapt 适配器驱动器(标识键盘、鼠标、磁盘驱动器这样的硬件项)。
interact 服务可以与桌面交互作用,接收用户的输入。交互服务必须在 LocalSystem 帐户下运行。该类型必须与 type= own 或 type= shared(例如,type= interact type= own)结合使用。单独使用 type= interact 将会产生一个无效参数错误。

start= {boot | system | auto | demand | disabled}
指定服务的启动类型。 值 描述
boot 由启动引导程序加载的设备驱动器。
system 在核心初始化过程中启动的设备驱动器。
auto 每次计算机重新启动时,甚至没有人登录计算机时,都能自动开始的服务。
demand 必须手动启动的服务。如果没有指定 start=,这就是默认值。
disabled 不能启动的服务。要启动一个禁用的服务,把启动类型更改为其他值。

error= {normal | severe | critical | ignore}
如果在启动中,服务器启动失败,则指定错误的严重性。 值 描述
normal 将记录错误,并且显示消息对话框,通知用户服务启动失败。启动将继续。这是默认设置。
severe 记录错误(如果存在)。计算机尝试以最新的有效配置重新启动。这可能导致计算机能够重新启动,但服务器却仍然不能运行。
critical 记录错误(如果存在)。计算机尝试以最新的有效配置重新启动。如果上次已知正常的配置失败,启动也将失败,启动过程就会以“蓝屏”错误而停止。
ignore 错误已记录,启动继续。记录错误超出在事件日志的范围,不再给用户作出提示。

binpath= BinaryPathName
指定一个进入服务二进制文件的路径。
group= LoadOrderGroup
指定一个该服务为其中成员的组名。组列表存储在 HKLM\System\CurrentControlSet\Control\ServiceGroupOrder 子项的注册表中。默认设置为空值。
tag= {yes | no}
指定是否在“CreateService”调用中获得 TagID。标记仅用于根启动或系统启动驱动程序。
depend= dependencies
指定必须在此项服务之前启动的服务名或组名。名称以斜线 (/) 分隔。
obj= {AccountName | ObjectName}
指定一个将运行的服务的帐户名,或指定一个将会运行的驱动程序的 Windows 驱动程序对象名。默认设置为 LocalSystem。
displayname= DisplayName
指定一个可以在用户界面程序用来为用户标识服务的友好的、有意义的名称。例如,一项服务的子项名是对用户没有帮助的 wuauserv,而显示的名称是“自动更新”。
password= Password
指定一个密码。如果使用了非 LocalSystem 的帐户,则此项是必需的。
/?
在命令提示符下显示帮助。
注释
如果参数及其值之间没有空格,(例如,是 type= own,而不是 type=own),则操作会失败。
示例
下面示例显示了如何使用 sc config 命令:

sc config NewService binpath= "ntsd -d c:\windows\system32\NewServ.exe"

sc continue

为了恢复暂停的服务,要给服务发送一个 CONTINUE 控制请求。

语法
sc [ServerName] continue [ServiceName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
注释
使用 continue 操作来恢复暂停的服务。
示例
下面的示例显示了如何使用 sc continue 命令:

sc continue tapisrv

sc control

向服务发送 CONTROL B。

语法
sc [ServerName] control [ServiceName] [{paramchange | netbindadd | netbindremove | netbindenable | netbinddisable | UserDefinedControlB}]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
{paramchange|netbindadd|netbindremove|netbindenable|netbinddisable|UserDefinedControlB
指定要发送到服务的控制。
/?
在命令提示符下显示帮助。
sc create

为服务在注册表和“服务控制管理器”中创建子项和入口。

语法
sc [ServerName] create [ServiceName] [type= {own | share | kernel | filesys | rec | adapt | interact type= {own | share}}] [start= {boot | system | auto | demand | disabled}] [error= {normal | severe | critical | ignore}] [binpath= BinaryPathName] [group= LoadOrderGroup] [tag= {yes | no}] [depend= dependencies] [obj= {AccountName | ObjectName}] [displayname= DisplayName] [password= Password]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
type= {own | share | kernel | filesys | rec | adapt | interact type= {own | share}}
指定该服务类型。默认类型为 type= own。值 描述
own 服务以其自身的进程运行。不与其他服务共享可执行文件。这是默认设置。
share 服务作为共享进程运行。它与其他服务共享一可执行文件。
kernel 驱动程序。
filesys 文件系统驱动程序。
rec 文件系统识别驱动器(标识在计算机上使用的文件系统)。
interact 服务可以与桌面交互作用,接收用户的输入。交互服务必须在 LocalSystem 帐户下运行。该类型必须与 type= own 或 type= shared(例如,type= interact type= own)结合使用。单独使用 type= interact 将会产生一个无效参数错误。

start= {boot | system | auto | demand | disabled}
指定服务的启动类型。默认的启动类型是 start= demand。boot 由启动引导程序加载的设备驱动器。
system 在核心初始化过程中启动的设备驱动器。
auto 每次计算机重新启动时,甚至没有人登录计算机时,都能自动开始的服务。
demand 必须手动启动的服务。如果没有指定 start=,这就默认值。
disabled 不能启动的服务。要启动一个禁用的服务,把启动类型更改为其他值。

error= {normal | severe | critical | ignore}
如果在启动中,服务器启动失败,则指定错误的严重性。默认设置为 ascii。normal 将记录错误,并且显示消息对话框,通知用户服务启动失败。启动将继续。这是默认设置。
severe 记录错误(如果存在)。计算机尝试以最新的有效配置重新启动。这可能导致计算机能够重新启动,但服务器却仍然不能运行。
critical 记录错误(如果存在)。计算机尝试以最新的有效配置重新启动。如果上次已知正确的配置失败,启动也将失败,启动过程就会以“蓝屏”错误而停止。
ignore 错误已记录,启动继续。记录错误超出在事件日志的范围,不再给用户作出提示。

binpath= BinaryPathName
指定一个进入服务二进制文件的路径。binpath= 没有默认值,必须要给出此字符串。
group= LoadOrderGroup
指定一个该服务为其中成员的组名。组列表存储在 HKLM\System\CurrentControlSet\Control\ServiceGroupOrder 子项的注册表中。默认设置为空值。
tag= {yes | no}
指定是否在“CreateService”调用中获得 TagID。标记仅用于根启动或系统启动驱动程序。
depend= dependencies
指定必须要在此项服务之前启动的服务名或组名。名称以斜线 (/) 分离开来。
obj= {AccountName | ObjectName}
指定一个将运行的服务的帐户名,或指定一个将会运行的驱动程序的 Windows 驱动程序对象名。
displayname= DisplayName
指定被用户界面程序用来标识服务的友好名称。
password:password
指定一个密码。如果使用的不是 LocalSystem 的帐户,密码是必需的。
/?
在命令提示符下显示帮助。
注释
如果参数及其值之间没有空格,(例如,是 type= own,而不是 type=own),则操作会失败。
示例
下面的示例显示了如何使用 sc create 命令:

sc \\myserver create NewService binpath= c:\windows\system32\NewServ.exe
sc create NewService binpath= c:\windows\system32\NewServ.exe type= share start= auto depend= "+TDI Netbios"

sc delete

从注册表中删除服务子项。如果服务正在运行或者另一个进程有一个该服务的打开句柄,那么此服务将标记为删除。

语法
sc [ServerName] delete [ServiceName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
注释
使用“添加或删除程序”删除 DHCP、DNS 或任何其他内置的操作系统服务。“添加或删除程序”不只删除该服务的注册表子项,而且还卸载该服务并删除其所有的快捷方式。
示例
下面的示例显示了如何使用 sc delete 命令:

sc delete newserv

sc description

设置服务的描述字符串。

语法
sc [ServerName] description [ServiceName] [Description]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
Description
为指定服务指定描述。如果没有指定字符串,则不会修改该服务的描述。对包含在服务描述中的字符数量没有限制。
/?
在命令提示符下显示帮助。
示例
下面的示例显示了如何使用 sc description 命令:

sc description newserv "Runs quality of service control."

sc enumdepend

列出只有运行了指定服务才能够运行的服务。

语法
sc [ServerName] enumdepend [ServiceName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
BufferSize
以字节为单位指定枚举缓冲区的大小。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
注释
如果缓冲区不够大,enumdepend 操作只会部分输出依存服务,并指定输出所有依存服务所需的额外缓冲区大小。如果输出被截断,重新运行该操作并指定更大的缓冲区大小。
示例
下面的示例显示了如何使用 sc enumdepend 命令:

sc enumdepend rpcss 5690
sc enumdepend tapisrv

sc failure

指定服务失败时要采取的操作。

语法
sc [ServerName] failure [ServiceName] [reset= ErrorFreePeriod] [reboot= BroadcastMessage] [command= CommandLine] [actions= FailureActionsAndDelayTime]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
reset= ErrorFreePeriod
指定没有失败的周期长度(单位为秒),此后失败计算应该重置为 0。这个参数必须与 actions= 参数结合使用。
reboot= BroadcastMessage
指定服务失败时要广播的消息。
command= CommandLine
指定服务失败时要运行的命令行。有关在失败时如何运行批处理或 VBS 文件的信息,请参阅“注释”。
actions= FailureActionsAndDelayTime
指定失败操作及其延迟时间(单位为毫秒),以正斜杠 (/) 隔开。下列操作有效:run、restart 和 reboot。此参数必须与 reset= 参数结合使用。在失败时不采取操作请使用 actions= ""。
/?
在命令提示符下显示帮助。
注释
不是所有的服务都允许更改其失败选项。其中一些作为服务集的一部分运行。
要在失败时运行批处理文件,请指定 cmd.exe Drive:\FileName.bat 为 command= 的参数,其中 Drive:\FileName.bat 是批处理文件的完全合格的名称。
要在失败时运行 VBS 文件,请指定 cscript drive:\myscript.vbs 为 command= 的参数,其中 drive:\myscript.vbs 是脚本文件完全合格的名称。
可以将三种不同的操作指定为 actions= 的参数,它们将会在服务的第一次、第二次、第三次失败时使用。
如果参数及其值之间没有空格,(例如,是 type= own,而不是 type=own),则操作会失败。
示例
下面的示例显示了如何使用 sc failure 命令:

sc failure msftpsvc reset= 30 actions= restart/5000
sc failure dfs reset= 60 command= c:\windows\services\restart_dfs.exe actions= run/5000
sc failure dfs reset= 60 actions= reboot/30000
sc failure dfs reset= 60 reboot= "The Distributed File System service has failed.Because of this, the computer will reboot in 30 seconds." actions= reboot/30000
sc failure myservice reset= 3600 reboot= "MyService crashed -- rebooting machine" command= "%windir%\MyServiceRecovery.exe" actions= restart/5000/run/10000/reboot/60000

sc getdisplayname

获得与特定服务关联的显示名称。

语法
sc [ServerName] getdisplayname [ServiceName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
BufferSize
指定缓冲区大小(以字节为单位)。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
示例
下面的示例显示了如何使用 sc getdisplayname 命令:

sc getdisplayname clipsrv
sc getdisplayname tapisrv
sc getdisplayname sharedaccess

sc getkeyname

使用特定服务的显示名称作为输入会获得与其相关联的项名。

语法
sc [ServerName] getkeyname [ServiceDisplayName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceDisplayName
指定服务的显示名称。
BufferSize
指定缓冲区大小(以字节为单位)。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
注释
如果 ServiceDisplayName 包含空格,请使用引号将文本引起来(例如,"Service Display Name")。
示例
下面的示例显示了如何使用 sc getkeyname 命令:

sc getkeyname "remote procedure call (rpc)"
sc getkeyname "internet connection sharing"
sc getkeyname clipbook

sc interrogate

向服务发送一个 INTERROGATE 控制请求。

语法
sc [ServerName] interrogate [ServiceName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
注释
使用“服务控制管理器”向服务发送 INTERROGATE 会导致该服务使用“服务控制管理器”更新其状态。
示例
下面的示例显示了如何使用 sc interrogate 命令:

sc interrogate sharedaccess
sc interrogate rpcss

sc lock

锁定“服务控制管理器”的数据库。

语法
sc [ServerName] lock

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
/?
在命令提示符下显示帮助。
注释
锁定“服务控制管理器”的数据库会阻止启动任何服务。如果要确保服务在停止之后不会启动,请使用这个命令。这允许您不受干扰的进行一些操作(例如,删除服务)。
使用 lock 操作锁定“服务控制管理器”的数据库,然后通过键入 u 来使数据库解锁。也可停止锁定数据库的进程。
示例
下面的示例显示了如何使用 sc lock 命令:

sc lock

sc pause

发送 PAUSE 控制请求到服务。

语法
sc [ServerName] pause [ServiceName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
注释
在终止服务之前使用 pause 操作来暂停它。
不是所有的服务都能够被暂停。
在暂停时不是所有的服务都执行同样的操作。一些服务继续为已有的客户端服务,但不会接受新的客户端。其他的会终止对已有客户端的服务,而且也不会接受新的客户端。
示例
下面的示例显示了如何使用 sc pause 命令:

sc pause tapisrv

sc qc

查询服务的配置信息。

语法
sc [ServerName] qc [ServiceName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
BufferSize
指定缓冲区大小(以字节为单位)。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
注释
qc 操作显示有关服务的下列信息:SERVICE_NAME(服务在注册表中的子键名)、TYPE、ERROR_CONTROL、BINARY_PATH_NAME、LOAD_ORDER_GROUP、TA、DISPLAY_NAME、DEPENDENCIES 和 SERVICE_START_NAME。
管理员可以使用 SC 来确定任一服务的二进制名称,并查明它是否与其他服务共享一个进程,在命令行键入下列命令:

sc qc ServiceName

SC 有助于将 Microsoft 管理控制台 (MMC) 中的服务与“系统监视器”中的进程匹配起来。如果二进制名称是 Services.exe,那么服务共享“服务控制器”进程。

Services.exe 启动所有的服务。为保存系统资源,几个为 Windows 开发的 Win32 服务被编写为共享 Services.exe 进程。这些服务不作为独立的进程列在“系统监视器”或“任务管理器”之中。Svchost.exe 也是如此,它是很多操作服务共享的服务主进程。

因为第三方 Win32 服务也可以配置为共享进程,所以不可能为每一个 Win32 服务创建一个进程。SC 可以用来获得这些服务的配置信息。但是,如果一项服务不与其他服务共享其进程,那么在服务运行时,“系统监视器”中会出现其进程。

因为 SC 与包含在 Windows 中的 Services.exe 相比,提供了更为详细和准确的、关于服务的信息,所以对于服务开发员来说 SC 更有用处。Services.exe 可以确定服务是在运行、停止还是正在暂停。尽管这些工具对于正在平稳运行的已调试程序已经足够,但是它们提供的关于正在开发的服务的信息却会使人误解。例如,一项正在启动的服务不管其实际运行与否都显示为已启动。

SC 执行对所有 Windows 服务控制应用编程接口 (API) 函数的调用。通过在命令行指定这些函数来将其设置为参数。

使用 SC,可以查询服务状态,检索存储在状态结构域中的值。Services.exe 不能提供服务的完整状态,但 SC 显示了精确的服务状态,以及最新的检查点号码和等待提示。可以将检查点用作调试工具,原因在于它表明了在程序停止响应之前初始化进行的程度。SC 也可以用来指定远程计算机名,以便于在远程计算机上调用服务 API 函数或查看服务状态结构。

示例
下面的示例显示了如何使用 sc qc 命令:

sc qc \\myserver newsrvice
sc qc rpcss 248

sc qdescription

显示服务的描述字符串。

语法
sc [ServerName] qdescription [ServiceName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
BufferSize
指定缓冲区大小(以字节为单位)。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
示例
下面的示例显示了如何使用 sc qdescription 命令:

sc qdescription rpcss
sc qdescription rpcss 138

sc qfailure

显示指定服务失败时要执行的操作。

语法
sc [ServerName] qfailure [ServiceName] [BufferSize]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
BufferSize
指定缓冲区大小(以字节为单位)。默认值为 1024 字节。
/?
在命令提示符下显示帮助。
注释
qfailure 操作显示了下面有关服务的信息:SERVICE_NAME(服务在注册表中的子键名)、RESET_PERIOD、REBOOT_MESSAGE、COMMAND_LINE 和 FAILURE_ACTIONS。
示例
下面的示例显示了如何使用 sc qfailure 命令:

sc qfailure rpcss
sc qfailure rpcss 20

sc query

获得和显示关于指定的服务、驱动程序、服务类型或驱动程序类型的信息。

语法
sc [ServerName] query [ServiceName] [type= {driver | service | all}] [type= {own | share | interact | kernel | filesys | rec | adapt}] [state= {active | inactive | all}] [bufsize= BufferSize] [ri= ResumeIndex] [group= GroupName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。此 query 参数不与其他的 query 参数结合使用(除了 ServerName)。
type= {driver | service | all}
指定需要列出的内容。默认类型为 service。 值 描述
driver 仅指定需要枚举的驱动程序。
service 仅指定需要枚举的服务。
all 指定需要枚举的驱动程序和服务器。

type= {own | share | interact | kernel | filesys | rec | adapt}
指定需要枚举的服务类型或驱动程序类型。 值 描述
own 服务以其自身的进程运行。不与其他服务共享可执行文件。这是默认设置。
share 服务作为共享进程运行。它与其他服务共享一可执行文件。
interact 服务可以与桌面交互作用,接收用户的输入。交互服务必须在 LocalSystem 帐户下运行。
kernel 驱动程序。
filesys 文件系统驱动程序。

state= {active | inactive | all}
指定用来枚举的服务的已开始状态。默认状态是 active。值 描述
active 指定所有的激活服务。
inactive 指定所有暂停或停止的服务。
all 指定所有服务。

bufsize= BufferSize
以字节为单位指定枚举缓冲区的大小。默认大小为 1024 字节。当从查询返回的显示结果超过 1024 个字节时,增加枚举缓冲区的大小。
ri= ResumeIndex
指定开始或继续枚举的索引数。默认值为 0。在查询返回的信息超过默认缓冲区能够显示的大小时,请与 bufsize= 参数结合使用这个参数。
group= GroupName
指定枚举的服务组。默认设置为所有组。
/?
在命令提示符下显示帮助。
注释
如果参数及其值之间没有空格,(例如,是 type= own,而不是 type=own),则操作会失败。
query 操作显示了以下关于服务的信息:SERVICE_NAME (服务在注册表中的子键名)、TYPE、STATE(也是不可用的状态)、WIN32_EXIT_B、SERVICE_EXIT_B、CHECKPOINT 和 WAIT_HINT。
在某些情况下,type= 参数可以使用两次。“type=”参数的第一次出现指定是否查询服务、驱动程序或所有这些。type= 参数的第二次出现指定一个由“create”操作进一步缩小查询范围的类型。
当 query 命令的显示结果超过了枚举缓冲区的大小时,显示类似于以下的消息:
Enum: 更多数据,需要在索引 79 开始恢复的 1822 字节

要显示剩余的 query 信息,重新运行 query,设置 bufsize= 为字节数,设置 ri= 为指定的索引。例如,在命令行键入下面的指令会显示剩余的输出:

sc query bufsize= 1822 ri= 79

示例
下面的示例显示了如何使用 sc query 命令:

sc query
sc query messenger
sc query type= driver
sc query type= service
sc query state= all
sc query bufsize= 50
sc query ri= 14
sc query type= service type= interact
sc query type= driver group= ndis

sc queryex

获得和显示关于服务、驱动程序、服务类型或驱动程序类型的扩展信息。

语法
sc [ServerName] queryex [type= {driver | service | all}] [type= {own | share | interact | kernel | filesys | rec | adapt}] [state= {active | inactive | all}] [bufsize= BufferSize] [ri= ResumeIndex] [group= GroupName]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。此 queryex 参数不与 ServerName 之外的任何其他 queryex 参数结合使用。
type= {driver | service | all}
指定需要列出的内容。默认类型为 service。 值 描述
driver 仅指定需要枚举的驱动程序。
service 仅指定需要枚举的服务。
all 指定需要枚举的驱动程序和服务器。

type= {own | share | interact | kernel | filesys | rec | adapt}
指定需要枚举的服务类型或驱动程序类型。值 描述
own 服务以其自身的进程运行。不与其他服务共享可执行文件。这是默认设置。
share 服务作为共享进程运行。它与其他服务共享一可执行文件。
interact 服务可以与桌面交互作用,接收用户的输入。交互服务必须在 LocalSystem 帐户下运行。
kernel 驱动程序。
filesys 文件系统驱动程序。

state= {active | inactive | all}
指定用来枚举的服务的已开始状态。默认状态是 active。值 描述
active 指定所有的激活服务。
inactive 指定所有暂停或停止的服务。
all 指定所有服务。

bufsize= BufferSize
以字节为单位指定枚举缓冲区的大小。默认大小为 1024 字节。
ri= ResumeIndex
指定开始或继续枚举的索引数。默认值为 0。
group= GroupName
指定枚举的服务组。默认设置为所有组。
/?
在命令提示符下显示帮助。
注释
如果参数及其值之间没有空格,(例如,是 type= own,而不是 type=own),则操作会失败。
queryex 操作显示以下有关服务的信息:SERVICE_NAME(服务在注册表中的子键名)、TYPE、STATE(也是不可用的状态)、WIN32_EXIT_B、SERVICE_EXIT_B、CHECKPOINT、WAIT_HINT、PID 和 FLAGS。
在某些情况下,“type=”参数可以使用两次。“type=”参数的第一次出现指定是否查询服务、驱动器或所有这些。type= 参数的第二次出现指定一个由 create 操作进一步缩小查询范围的类型。
在 queryex 命令的显示结果超过了枚举缓冲区大小时,显示类似于以下的消息:
Enum:数据超出,在索引 75 处重新启动需要 2130 个字节

要显示 queryex 的剩余信息,重新运行 queryex,设置 bufsize= 为字节数,ri= 为指定索引。例如,在命令行键入下面的指令会显示剩余的输出:

sc queryex bufsize= 2130 ri= 75

示例
下面的示例显示了如何使用 sc queryex 命令:

sc queryex messenger
sc queryex group= ""

sc querylock

查询和显示“服务控制管理器”数据库的锁定信息。

语法
sc [ServerName] querylock

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
/?
在命令提示符下显示帮助。
sc sdset

使用“服务描述符定义语言 (SDDL)”来设置服务的安全描述符。

语法
sc [ServerName] sdset ServiceName ServiceSecurityDescriptor

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
ServiceSecurityDescriptor
在 SDDL 中指定服务描述符。
/?
在命令提示符下显示帮助。
注释
有关 SDDL 的详细信息,请参阅 Microsoft 网站上的“Security Descriptor Definition Language”(安全描述符定义语言)。(http://msdn.microsoft.com/)
sc sdshow

使用 SDDL 显示服务的安全描述符。

语法
sc [ServerName] sdshow ServiceName

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
Servicename
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
注释
有关 SDDL 的详细信息,请参阅 Microsoft 网站上的“Security Descriptor Definition Language”(安全描述符定义语言)。(http://msdn.microsoft.com/)
示例
sc sdshow rpcss

sc start

启动正在运行的服务。

语法
sc [ServerName] start ServiceName [ServiceArguments]

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
ServiceArguments
指定传递给要启动的服务的服务参数。
/?
在命令提示符下显示帮助。
示例
下面的示例显示了如何使用 sc start 命令:

sc start tapisrv

sc stop
向服务发送 STOP 控制请求。

语法
sc [ServerName] stop ServiceName

参数
ServerName
指定服务所在的远程服务器名称。该名称必须使用 UNC 格式(“\\myserver”)。要在本机上运行 SC.exe,请忽略此参数。
ServiceName
指定由 getkeyname 操作返回的服务名。
/?
在命令提示符下显示帮助。
警告

编辑注册表不当可能会严重损坏您的系统。在更改注册表之前,应备份计算机上任何有价值的数据。
注释
不是所有的服务都可以被停止。
示例
下面的示例显示了如何使用 sc stop 命令:

sc stop tapisrv

分享到:
评论

相关推荐

    如何删除Windows服务.docx

    **删除Windows服务的方法** 当遇到恶意软件或不需要的服务时,可能需要删除它们。以下是两种常见的方法: **方法一:使用sc.exe命令** 1. 打开命令提示符(开始菜单 -> 运行 -> 输入cmd.exe)。 2. 在命令提示符中...

    删除Windows服务的方法.docx

    ### 删除Windows服务的方法 #### 什么是Windows服务? Windows服务(Windows Service)是Windows操作系统的核心组成部分之一,用于支持各种后台操作和服务。与普通的应用程序不同,Windows服务通常没有用户界面,...

    win7 删除Windows服务的方法.docx

    【删除Windows服务的方法】 1. 使用`sc.exe`命令: `sc.exe`是Windows提供的命令行工具,可以用来管理服务。以管理员权限打开命令提示符,然后输入`sc delete 服务名`来删除服务。例如,如果要删除名为“KSD2...

    C# windows服务删除过期文件每天执行一次.

    本项目聚焦于使用C#编程语言创建一个Windows服务,该服务的主要功能是每天定时删除指定目录中的过期文件。下面将详细讲解这个知识点。 首先,我们需要了解C#中创建Windows服务的基本步骤。这通常涉及到以下几个关键...

    windows2003服务器双线双IP双网卡设置方法_双线

    Windows 2003 服务器双线双 IP 双网卡设置方法 Windows 2003 服务器双线双 IP 双网卡设置方法是指在 Windows 2003 服务器上配置双网卡,分别连接到两个网络,实现同时访问两个网络的功能。本文将详细介绍 Windows ...

    删除Windows服务

    #### 删除Windows服务的方法 1. **使用`sc.exe`命令** - 打开命令提示符(cmd.exe)。 - 输入`sc delete "服务名"`(将“服务名”替换为实际的服务名称),然后按Enter键。例如: ``` sc delete KSD2Service ...

    windows创建服务代码

    创建Windows服务通常是系统级任务,需要使用特定的API函数。在本案例中,我们关注的焦点是通过C++编程来创建Windows服务。文件"NTService.cpp"、"NTService.h"和"NTServiceEventLogMsg.h"构成了实现这一功能的基础...

    Windows手动删除服务列表中残留服务的方法.docx

    Windows 手动删除服务列表中残留服务的方法 Windows 操作系统中,服务列表中可能会残留一些无用或损坏的服务,这些服务可能会占用系统资源,影响系统性能。删除这些残留服务可以释放系统资源,提高系统性能。本文将...

    Windows服务的程序实例

    本篇文章将详细探讨如何创建、打开、关闭以及删除Windows服务,并提供相关的程序实例。 一、创建Windows服务 创建Windows服务通常涉及以下步骤: 1. 编写服务程序:首先,我们需要编写一个.NET Framework或C++应用...

    Windows 服务手动添加删除方法.doc

    Windows 服务手动添加删除方法 Windows 服务手动添加删除方法是指在 Windows 平台下,将应用程序或进程注册为系统服务,以便支持其他程序的运行。服务是一种特殊的应用程序,它从服务启动开始就一直处于运行状态,...

    创建Windows服务程序

    总结,创建Windows服务程序涉及编程语言的选择、ServiceBase类的使用、关键方法的重写以及服务生命周期的管理。通过`sc`命令,我们可以方便地控制服务的状态。了解这些知识点,开发者就能创建出能够按需运行、自我...

    Windows服务

    在本教程中,我们将深入探讨如何管理和操作Windows服务,包括如何删除服务以及使用Windows服务查看工具。 首先,让我们来了解一下什么是Windows服务查看工具。这个工具,通常称为“Services.msc”,是一个内置的...

    WindowsService(服务)安装卸载管理工具-下载

    以下是一些关于Windows服务及管理工具的相关知识点: 1. **服务的概念**:Windows服务是系统级的进程,它们在用户登录之前启动,持续运行直到被停止。服务通常用于执行自动化任务,如监控硬件、网络通信、数据库...

    Windows_Installer服务不能启动的解决方法

    ### Windows Installer服务不能启动的解决方法 在日常的软件安装过程中,我们时常会遇到与Windows Installer服务相关的错误,尤其是在尝试安装MSI格式的文件时。本文将深入探讨这一问题,并提供针对不同Windows操作...

    C# windows服务删除过期文件每天执行一次

    在本场景中,"C# windows服务删除过期文件每天执行一次"是一个用C#编程语言编写的Windows服务,它的主要功能是每天自动清理指定目录中的过期文件,以保持系统的整洁和高效运行。 首先,让我们了解一下C#编程语言。...

    windows服务小示例,每天定时删除文件夹里面7天前的文件,清理垃圾

    本示例“windows服务小示例”旨在实现一个定时清理功能,即每天自动删除指定文件夹内7天前的文件,以帮助用户维护系统清洁,避免无用文件占用过多存储空间。 要实现这个功能,首先需要创建一个Windows服务应用。这...

    C#Windows服务控制代码

    在IT领域,Windows服务是一种特殊的后台应用程序,它们在没有用户界面的情况下运行,通常用于执行长期任务或提供系统级的功能。C#是微软开发的一种面向对象的编程语言,非常适合用来创建Windows服务。本篇将深入探讨...

    windows服务安装和卸载

    在Windows操作系统中,服务是一种特殊的后台程序,它们在用户登录之前或不与用户...通过以上方法,你可以方便地管理和维护Windows服务。注意,操作服务时应确保具有足够的权限,并谨慎操作,以免影响系统的正常运行。

Global site tag (gtag.js) - Google Analytics