【转】如何在命令行脚本中启动带参数的Windows服务

我们有一个自己编写的Windows服务,我们希望该服务在启动时可以根据用户输入的参数实现不同的功能。

要实现这样的需求并不是很难,下面这个例子我用来示范如何编写该服务

 1 using System;
 2 using System.Collections.Generic;
 3 using System.ComponentModel;
 4 using System.Data;
 5 using System.Diagnostics;
 6 using System.Linq;
 7 using System.ServiceProcess;
 8 using System.Text;
 9
10 namespace WindowsServiceSample
11 {
12     public partial class SampleService : ServiceBase
13     {
14         public SampleService()
15         {
16             InitializeComponent();
17         }
18
19         /// <summary>
20         /// 服务启动时触发
21         /// </summary>
22         /// <param name="args">用户可以设置的输入参数</param>
23         protected override void OnStart(string[] args)
24         {
25
26             if (args.Length > 0)
27             {
28                 EventLog.WriteEntry(string.Format("sample service is started with parameter :{0}", string.Join(",", args)));
29             }
30             else
31             {
32                 EventLog.WriteEntry("sample service is started with non parameter");
33             }
34         }
35
36         protected override void OnStop()
37         {
38         }
39     }
40 }

在上述代码中,我区分了带参数启动和不带参数启动两种情况。很显然,在带参数的那种情况下,我们可以根据参数做不同的处理。本文仅为了说明参数问题,并不真的去考虑那些实际应用。我通过写日志的方式来区分即可。

这个服务安装起来之后,在服务控制台中看起来是这样的

如果我们通过手工去启动的话,如何设置参数呢?很简单,双击该服务,在属性对话框中输入参数即可

【注意】是先输入参数,然后点击“Start”

【注意】不同的参数之间用空格隔开

启动成功后,我们在事件日志中可以看到一条日志

这说明,参数确实被捕捉到了。服务正常进行了工作。

还不错对吧?但本文的最大目的并不是解释这个,上面都是铺垫,如果我们是要通过命令行脚本的方式来启动服务,而不是手工启动服务,那么该如何设置参数呢?

我们都知道要在命令行中启动服务,一般都是通过net start命令。这个工具的格式如下

我们可以通过net start sampleservice启动服务

在事件日志中确实看到它是没有带参数启动的

好吧,那么如何传递参数过去呢?

经过研究发现,net 工具要传递参数的话,有一个很特殊的做法

net start sampleservice /a /b /c /d

但是这样启动之后,看日志却发现有一点点特殊

请主要,参数确实传递进来了。但包含了“/”。如果说在程序中识别这个特殊的符号,那么也是没有问题的。只不过,这样就未必是增加了程序的复杂性啦。

那么,有没有更加简单的做法呢?(简单的意思是说与手工操作是一样的,不需要为此去修改代码)

我想起来,除了用net start之外,还可以通过sc start命令来启动服务

这样的命令就直观多了。我们马上来看一下日志文件中的结果吧

很好,这是我们需要的效果。也就是说用sc工具的话,可以很好地传递参数。

【备注】sc的意思是,service controller,关于该工具的详细介绍,请参考 http://www.microsoft.com/resources/documentation/windows/xp/all/proddocs/en-us/sc.mspx?mfr=true

时间: 2025-01-18 04:17:43

【转】如何在命令行脚本中启动带参数的Windows服务的相关文章

线程启动带参数

public void StartThread() { Thread TempThread = new Thread(new ThreadStart(Start)); TempThread.Start(); } 带参数的: public void StartThread() { Thread TempThread = new Thread(new ParameterizedThreadStart(Start)); TempThread.Start(); } public void Start(o

kbmmw 中使用带验证的REST 服务

前面介绍的rest 服务,虽然很方便,但是存在任何人都可以访问的安全问题. 今天说一下,如何在kbmmw 中使用带验证的REST 服务? 首先我们在工程中放一个 认证控件TkbmMWAuthorizationManager. 如图: 设置kbmmwserver 的认证属性 初始化 authmgr AuthMgr.AddRole('AdminRole'); 然后设置 验证 代码 procedure Tdmf.AuthMgrLogin(Sender: TObject; const AActorNam

在JDBC中使用带参数的SQL语句

ADO.Net中,支持带参数的SQL语句,例如:Select * from Tables where [email protected],其中@column1为SQL参数,使用起来非常方便,而JDBC中没有找到此功能,感觉有点不便, 于是想自己实现一个.今天正好看见csdn中有一篇http://blog.csdn.net/wallimn/article/details/3734242 文章,有些感触,于是把自己的实现也写出来. 我的思路: 1: 在SQL语句中找到以@开始,以" ",

python中编写带参数decorator

考察上一节的 @log 装饰器: def log(f): def fn(x): print 'call ' + f.__name__ + '()...' return f(x) return fn 发现对于被装饰的函数,log打印的语句是不能变的(除了函数名). 如果有的函数非常重要,希望打印出'[INFO] call xxx()...',有的函数不太重要,希望打印出'[DEBUG] call xxx()...',这时,log函数本身就需要传入'INFO'或'DEBUG'这样的参数,类似这样:

SC命令---安装、开启、配置、关闭windows服务 bat批处理(转载)

转载:http://www.jb51.net/article/49627.htm 转载:http://blog.csdn.net/c1520006273/article/details/50539057 一.直接使用cmd来进行服务的一些操作 1.安装服务 sc create test3 binPath= "C:\Users\Administrator\Desktop\win32srvDemo\win32srvdemo\Debug\win32srvDemo.exe" 其中:test3为

(转)SC命令---安装、开启、配置、关闭windows服务 bat批处理

本文转载自:http://blog.csdn.net/moruna/article/details/9190733 废话不多说,看命令行更直接! 一.直接使用cmd来进行服务的一些操作 1.安装服务 sc create test3 binPath= "C:\Users\Administrator\Desktop\win32srvDemo\win32srvdemo\Debug\win32srvDemo.exe" 其中:test3为创建的服务名,binPath后面是运行exe文件的所在路径

sql中like带参数的写法

最近学习过程中,用到like语句,但为了防止sql注入,所以得使用sql参数化的方法进行查询.发现使用like语句时,不同于直接的查询.尝试了几次,都没有成功. 直接查询时的写法为: select 字段 from 表 where 字段=@parameter; SqlParameter s1 = new SqlParameter("@parameter",parameter); 而在like语句中为: string sql = "select 字段 from 表 where 字

在PL/SQL中使用带参数的游标

需求:查询并输出部门名称为SALES的员工信息 1 SET serveroutput ON; 2 DECLARE 3 CURSOR c_emp(paramName VARCHAR2) IS 4 SELECT * FROM emp WHERE deptno = (select deptno from dept where dname = paramName); 5 BEGIN 6 FOR e IN c_emp('SALES')loop 7 dbms_output.put_line(e.empno|

jQuery获取URL中所带参数的办法

可以使用正则表达式进行结果的拆分: http://www.cnblogs.com/babycool/p/3169058.html 可以直接进行所需内容的split: http://blog.sciencenet.cn/blog-419883-871644.html 对于http://localhost/test.html?id=1的形式,可以采用 var id = $(location).attr('href').split('?')[1].split('=')[1]; 直接获得: