C:\tmp>sc /?
错误: 未知命令
描述:
SC 是用于与服务控制管理器和服务进行通信的命令行程序。
用法:
sc <server> [command] [service name] <option1> <option2>...
选项 <server> 的格式为 "\\ServerName"
键入 "sc [command]" 可以获得有关命令的进一步帮助
命令:
query-----------查询服务的状态,
或枚举服务类型的状态。
queryex---------查询服务的扩展状态,
或枚举服务类型的状态。
start-----------启动服务。
pause-----------向服务发送 PAUSE 控制请求。
interrogate-----向服务发送 INTERROGATE 控制请求。
continue--------向服务发送 CONTINUE 控制请求。
stop------------向服务发送 STOP 请求。
config----------更改服务的配置(永久)。
description-----更改服务的描述。
failure---------更改服务失败时执行的操作。
failureflag-----更改服务的失败操作标志。
sidtype---------更改服务的服务 SID 类型。
privs-----------更改服务的所需权限。
qc--------------查询服务的配置信息。
qdescription----查询服务的描述。
qfailure--------查询失败时服务执行的操作。
qfailureflag----查询服务的失败操作标志。
qsidtype--------查询服务的服务 SID 类型。
qprivs----------查询服务的所需权限。
qtriggerinfo----查询服务的触发器参数。
qpreferrednode--查询首选的服务 NUMA 节点。
delete----------(从注册表)删除服务。
create----------创建服务(将其添加到注册表)。
control---------向服务发送控制。
sdshow----------显示服务的安全描述符。
sdset-----------设置服务的安全描述符。
showsid---------显示相应于假定名称的 SID 字符串。
triggerinfo-----配置服务的触发器参数。
preferrednode---设置首选的服务 NUMA 节点。
GetDisplayName--获取服务的 DisplayName
GetKeyName------获取服务的 ServiceKeyName。
EnumDepend------枚举服务的依存关系。
下列命令不要求服务名称:
sc <server> <command> <option>
boot------------(ok | bad) 指示是否将上一次启动保存为
最近一次已知的正确启动配置
Lock------------锁定服务数据库
QueryLock-------查询 SCManager 数据库的 LockStatus
示例:
sc start MyService
是否想参阅 QUERY 和 QUERYEX 命令的帮助? [ y | n ]:
y
QUERY 和 QUERYEX 选项:
如果查询命令带服务名称,将返回
该服务的状态。其他选项不适合这种
情况。如果查询命令不带参数或
带下列选项之一,将枚举此服务。
type= 要枚举的服务的类型(driver, service, all)
默认 = service)
state= 要枚举的服务的状态 (inactive, all)
(默认 = active)
bufsize= 枚举缓冲区的大小(以字节计)
(默认 = 4096)
ri= 开始枚举的恢复索引号
(默认 = 0)
group= 要枚举的服务组
(默认 = all groups)
语法示例
sc query - 枚举活动服务和驱动程序的状态
sc query eventlog - 显示 eventlog 服务的状态
sc queryex eventlog - 显示 eventlog 服务的扩展状态
sc query type= driver - 仅枚举活动驱动程序
sc query type= service - 仅枚举 Win32 服务
sc query state= all - 枚举所有服务和驱动程序
sc query bufsize= 50 - 枚举缓冲区为 50 字节
sc query ri= 14 - 枚举时恢复索引 = 14
sc queryex group= "" - 枚举不在组内的活动服务
sc query type= interact - 枚举所有不活动服务
sc query type= driver group= NDIS - 枚举所有 NDIS 驱动程序
C:\tmp>
如果需要查看全部的服务:
可以使用 sc query state= all
如果我想完成一个自动启动和关闭的oracle 脚本,可以通过如下步骤实现:
1)sc query state= all > sl.txt
2)findstr "DISPLAY_NAME" sl.txt > asl.txt
如下:
3)findstr /i "oracle" asl.txt > osl.txt
内容:
如果需要查看全部的服务:
可以使用 sc query state= all
如果我想完成一个自动启动和关闭的oracle 脚本,可以通过如下步骤实现:
1)sc query state= all > sl.txt
2)findstr "DISPLAY_NAME" sl.txt > asl.txt
如下:
C:\tmp>findstr "DISPLAY_NAME" sl.txt
DISPLAY_NAME: Adobe Acrobat Update Service
DISPLAY_NAME: Application Experience
DISPLAY_NAME: Application Layer Gateway Service
DISPLAY_NAME: AMD External Events Utility
DISPLAY_NAME: Avira Scheduler
DISPLAY_NAME: Avira Real-Time Protection
DISPLAY_NAME: Application Identity
DISPLAY_NAME: Application Information
DISPLAY_NAME: Application Management
DISPLAY_NAME: Windows Audio Endpoint Builder
DISPLAY_NAME: Windows Audio
。。。
3)findstr /i "oracle" asl.txt > osl.txt
内容:
C:\tmp>findstr /i "oracle" asl.txt
DISPLAY_NAME: OracleDBConsoleorcl
DISPLAY_NAME: OracleJobSchedulerORCL
DISPLAY_NAME: OracleMTSRecoveryService
DISPLAY_NAME: OracleOraDb11g_home1ClrAgent
DISPLAY_NAME: OracleOraDb11g_home1TNSListener
DISPLAY_NAME: OracleServiceORCL
DISPLAY_NAME: Oracle ORCL VSS Writer Service
4)在vim中,把DISPLAY_NAME:替换成 net stop 或者net start就可以了:
C:\tmp>gvim osl.txt
4)在vim中,把DISPLAY_NAME:替换成 net stop 或者net start就可以了:
C:\tmp>gvim osl.txt
C:\tmp>type osl.txt
net stop OracleDBConsoleorcl
net stop OracleJobSchedulerORCL
net stop OracleMTSRecoveryService
net stop OracleOraDb11g_home1ClrAgent
net stop OracleOraDb11g_home1TNSListener
net stop OracleServiceORCL
net stop Oracle ORCL VSS Writer Service
net start OracleDBConsoleorcl
net start OracleJobSchedulerORCL
net start OracleMTSRecoveryService
net start OracleOraDb11g_home1ClrAgent
net start OracleOraDb11g_home1TNSListener
net start OracleServiceORCL
net start Oracle ORCL VSS Writer Service
本文转自博客园zhyiwww 的博客,原文链接:http://www.blogjava.net/zhyiwww/,如需转载请自行联系原博主。