太阳当空照-Windows服务化方式sc.exe应用

2023-11-21 06:20

本文主要是介绍太阳当空照-Windows服务化方式sc.exe应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

日常开发工作中,对于已经包含基础功能的系统,需要为前端同事提供测试环境时,常常需要在搭建好测试环境后,保证测试环境的正常运行,如果程序本身是控制台程序,那控制台就需要保证一直开启,关闭控制台程序将影响到测试系统的正常运行,相比于Linux系的相关系统,例如CentosUbuntu,服务化便捷,同时支持也很多,例如SupervisorWindows系统中,就显得比较尴尬,服务化手段较少,而且集中化管理较弱,测试系统演进如下:

  • 人工通过控制台启动

    服务重新部署需要退出控制台,部署后重新打开控制台

  • .bat.cmd脚本启动

    双击脚本(管理员或普通用户),测试系统就启动了,单个系统,单个程序启动忍一忍就过了,辅助的系统和程序一多,维护成本也会逐渐增加

  • 系统服务化启动

    通过注册服务、启动服务、停止服务实现对系统启动细节的忽略,只关心系统的最终执行状态

    ggcy-blog-service-sc-header

sc.exe简述

sc.exe为服务控制管理service control manager,用于对计算机的系统服务进行管理,实现注册,运行,暂停,自启等基础操作,用户能够将符合Windows系统服务化条件的程序进行本地系统后台服务化运行,注册到服务注册表目录下的程序,通过sc的指令实现程序执行状态的切换和管理。

指令清单

指令具体细节内容可以查看官网或笔者的另一篇文章太阳当空照-Windows服务化方式sc.exe指令清单

常用指令

sc create

添加服务信息到注册表中

sc <server> create [service name] [binPath= ] <option1> <option2>...

例如

>sc create sctest binPath=\"E:\Study\Servers\sctest\sctest.exe\”"
sc description

设置服务的描述字符串

sc <server> description [service name] [description]
sc start

启动服务运行

sc <server> start [service name] <arg1> <arg2> ...
sc query

查询服务

sc query [service name] <arg1> <arg2> ...
sc stop

停止服务

sc stop [service name]
sc delete

删除服务注册表信息

sc delete [service name]

示例

服务案例

案例为笔者自己基于C#,在基于Core3.1创建的控制台程序,用于每隔一秒,项当前目录下的日志文件中换行写入小时:分钟:秒,由于是使用符合Windows服务化标准的相关依赖库,此处略过对类库Microsoft.Extensions.Hosting.WindowsServices的介绍和使用,项目源码可通过公众号进行领取,此处程序目前未为x86,也可以依据需求生成x64

打包生成的文件结构如下:

ggcy-service-sctest

创建服务

管理员权限运行cmd,执行创建指令,binPath=<空格>尾部添加对应sctest.exe的绝对路径,避免注册服务过程中,路径中的特殊字符无法被正常识别,可对路径外部添加双引号

sc create sctest binPath=\"E:\Study\Servers\sctest\sctest.exe\”"
[SC] CreateService 成功

查看任务管理器中的服务

ggcy-service-sc-create

打开服务,找到sctest服务,查看属性,会发现,binPath实际就是可执行文件的路径

ggcy-service-sc-server

或者执行query指令

>sc query sctestSERVICE_NAME: sctestTYPE               : 10  WIN32_OWN_PROCESSSTATE              : 1  STOPPEDWIN32_EXIT_CODE    : 1077  (0x435)SERVICE_EXIT_CODE  : 0  (0x0)CHECKPOINT         : 0x0WAIT_HINT          : 0x0

添加描述

创建服务时,如果为通过指令sc create [service name] binPath= 路径 displayname= "描述内容",进行描述设置,可以通过,sc description进行设置

>sc description sctest "this is sctestservice"
[SC] ChangeServiceConfig2 成功

打开服务查看sctest的描述内容如下:

ggcy-service-sc-description

启动服务

方式一

直接使用sc start [service name]进行服务启动,启动成功输出结果如下:

>sc start sctestSERVICE_NAME: sctestTYPE               : 10  WIN32_OWN_PROCESSSTATE              : 2  START_PENDING(NOT_STOPPABLE, NOT_PAUSABLE, IGNORES_SHUTDOWN)WIN32_EXIT_CODE    : 0  (0x0)SERVICE_EXIT_CODE  : 0  (0x0)CHECKPOINT         : 0x0WAIT_HINT          : 0x7d0PID                : 32296FLAGS              :
方式二

也可以使用net start [service name]进行服务启动

>net start sctest
sctest 服务正在启动 .
sctest 服务已经启动成功。

服务启动成功后,可以看到在sctest.exe同一级别目录下,生成一个[年-月-日].log文件,内容大体如下:

当前时间:Service Start
当前时间:00:29:50
当前时间:00:29:51
.........

停止服务

停止服务可以使用sc,也可以使用net,服务停止后,对应的[年-月-日].log文件内容,也将不再增加

方式一

使用sc stop,在使用sc query查看服务当前状态,或直接去到任务管理器,查看任务页签中服务sctest的状态

>sc stop sctestSERVICE_NAME: sctestTYPE               : 10  WIN32_OWN_PROCESSSTATE              : 3  STOP_PENDING(STOPPABLE, NOT_PAUSABLE, ACCEPTS_SHUTDOWN)WIN32_EXIT_CODE    : 0  (0x0)SERVICE_EXIT_CODE  : 0  (0x0)CHECKPOINT         : 0x0WAIT_HINT          : 0x0>sc query sctestSERVICE_NAME: sctestTYPE               : 10  WIN32_OWN_PROCESSSTATE              : 1  STOPPEDWIN32_EXIT_CODE    : 0  (0x0)SERVICE_EXIT_CODE  : 0  (0x0)CHECKPOINT         : 0x0WAIT_HINT          : 0x0
方式二

使用net stop进行服务停止

>net stop sctest
sctest 服务正在停止.
sctest 服务已成功停止。

删除服务

使用指令sc delete将对应服务进行删除

>sc delete sctest
[SC] DeleteService 成功

关闭任务管理器再次打开,其中将不再能够看到服务sctest,表明服务删除成功

常见问题

服务注册

binPath服务程序执行路径

注册服务时,binPath为必须项,需要指定路径,若是执行文件夹路径包含特殊字符时,需要为路径添加双引号如下:

sc create [service name] binPath= “服务程序绝对路径”

服务启动

启动失败,返回1503

服务注册成功后,启动服务时,服务等待一段时间后,返回程序无响应

[SC] StartService 失败 1053:服务没有及时响应启动或控制请求。

查看Windows自带的事件查看器,在Windows日志系统可以看到来源Service Control Manager的相关错误信息

ggcy-service-sc-log

日志内容如下:

ggcy-service-sc-logdetails

造成此类问题的情况很多,目前笔者摸索到的有以下几类:

  • 目标程序本身,在编码级别,并没有通过编码方式,实现程序自身的Windows服务化,简单来说就是,程序不支持sc方式启动

  • 程序必要的程序启动路径,配置文件加载路径,内部数据输出路径等错误,造成程序执行异常

    服务本身在启动时,默认为独立进程启动,实际上依据sc的管理启动,程序的工作目录并不是在当前服务exe所在目录,所以服务程序相关路径最好是以绝对路径方式配置,或者启动服务时参数传入,同时服务程序如果有对应的日志输出,也可以依据本地日志输出查看对应问题细节

服务删除

无法删除服务,提示服务已暂停

使用sc delete删除对应服务时,提示该服务已暂停,此时需要关闭services.msc,重新启动就可以发现,服务已经不存在

参考链接

【服务器角色命令】https://docs.microsoft.com/zh-cn/windows-server/administration/windows-commands/sc-config

【编写Windows服务】https://www.cnblogs.com/RainFate/p/12095793.html

获取上述内容中的服务测试源码项目,可关注私信或直接评论回复【sc.exe

这篇关于太阳当空照-Windows服务化方式sc.exe应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/400422

相关文章

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Flutter打包APK的几种方式小结

《Flutter打包APK的几种方式小结》Flutter打包不同于RN,Flutter可以在AndroidStudio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式,通... 目录前言1. android原生打包APK方式2. Flutter通过原生工程打包方式3. Futte

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调