【转】如何在命令行脚本中启动带参数的Windows服务
我们有一个自己编写的Windows服务,我们希望该服务在启动时可以根据用户输入的参数实现不同的功能。
要实现这样的需求并不是很难,下面这个例子我用来示范如何编写该服务
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Linq;
using System.ServiceProcess;
using System.Text; namespace WindowsServiceSample
{
public partial class SampleService : ServiceBase
{
public SampleService()
{
InitializeComponent();
} /// <summary>
/// 服务启动时触发
/// </summary>
/// <param name="args">用户可以设置的输入参数</param>
protected override void OnStart(string[] args)
{ if (args.Length > )
{
EventLog.WriteEntry(string.Format("sample service is started with parameter :{0}", string.Join(",", args)));
}
else
{
EventLog.WriteEntry("sample service is started with non parameter");
}
} protected override void OnStop()
{
}
}
}
在上述代码中,我区分了带参数启动和不带参数启动两种情况。很显然,在带参数的那种情况下,我们可以根据参数做不同的处理。本文仅为了说明参数问题,并不真的去考虑那些实际应用。我通过写日志的方式来区分即可。
这个服务安装起来之后,在服务控制台中看起来是这样的
如果我们通过手工去启动的话,如何设置参数呢?很简单,双击该服务,在属性对话框中输入参数即可
【注意】是先输入参数,然后点击“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
【转】如何在命令行脚本中启动带参数的Windows服务的更多相关文章
- kbmmw 中使用带验证的REST 服务
前面介绍的rest 服务,虽然很方便,但是存在任何人都可以访问的安全问题. 今天说一下,如何在kbmmw 中使用带验证的REST 服务? 首先我们在工程中放一个 认证控件TkbmMWAuthoriza ...
- ThreadStart中如何带参数
1.ThreadStart 线程执行带参数的方法,new Thread(new ThreadStart(delegate { ThreadTask(firstPage, lastPage); })); ...
- C# ThreadStart中如何带参数
1.ThreadStart 线程执行带参数的方法,new Thread(new ThreadStart(delegate { ThreadTask(firstPage, lastPage); })); ...
- PYTHON 中 SQL 带参数
使用 PYTHON 的字符串填充方式 import mysql.connector sql = 'select \* from school.student where age > {age} ...
- [转]SSIS OLE DB Source中执行带参数的存储过程
本文转自:http://www.cnblogs.com/michaelxu/archive/2009/10/21/1587450.html 问题描述:执行一个存储过程得到一个多条记录的结果集,然后循环 ...
- python中编写带参数decorator
考察上一节的 @log 装饰器: def log(f): def fn(x): print 'call ' + f.__name__ + '()...' return f(x) return fn 发 ...
- 在 Linux 命令行脚本中执行 sudo 时自动输入密码
使用 expect 实现自动登录的脚本的原理. 脚本代码如下: ############################################## #!/usr/bin/expect set ...
- 用命令行(CMD)中启动和关闭ORACLE服务
lsnrctl start开启监听 lsnrctl stop停止监听 net start oracleserviceoracle开启oracle服务 net stop oracleserviceora ...
- devilbox(三):在docker中启动带密码的redis数据库
背景概述: 之前是使用docker搭建了一套集成的开发环境devilbox,也说了这个环境可以自定义.其实搭建这个环境一是为了练习docker使用,二是搭建我们测试环境,主要用到各种数据库,然而安装教 ...
随机推荐
- 为什么wait,notify和notifyAll要与synchronized一起使用?
https://blog.csdn.net/qq_39907763/article/details/79301813 Object.wait(),Object.notify(),Object.noti ...
- the little schemer 笔记(9)
第九章 ...and Again, and Again, and, Again, ... 你想来点鱼子酱吗? 那就去找它吧. (looking a lat)是什么,其中a是 caviar, lat是( ...
- css新奇技术及其未来发展
1.图像替换技术: 图像替换技术是指使用图像替换页面中文本的功能,类似与在页面中插入图像,只是这种方法更为方便,易于代码管理.通常来说,设计者习惯使用有意义的图像去替换一些标题,logo和某些特定的页 ...
- D. Black Hills golden jewels 二分答案 + 二分判定
http://codeforces.com/gym/101064/problem/D 题目是给定一个数组,如果两两组合,有C(n, 2)种结果,(找出第一个大于等于第k大的结果) 思路, 二分答案va ...
- 在虚拟机里安装windows或Linux系统时,安装窗口过大按钮有时点不到解决办法(图文详解)
不多说,直接上干货! 问题详情 解决办法 很简单快捷的解决办法,就是快捷键ALT+F7,可以拖动窗口的位置. 成功!
- Properties没有被注意的地方
源起: 今天阅读源码时发现一个地方不理解: 为什么以下代码第10行 get() 之后value为null时还去 getProperty() 呢? org.springframework.util.Co ...
- 边框圆角值的问题、white-space、word-wrap、margin对布局的影响
1.边框圆角(border-radius)值的问题 border-radius : 7px 7px 7px 0; 四个值的顺序是左上.右上.右下.左下 2.white-space 规定段落中的文本不换 ...
- checkbox:click事件触发span元素内容改变
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- coursera网站中的VTT字幕的使用
coursera网站中的VTT字幕的使用 1.https://www.coursera.org/learn/os-virtsecurity/lecture/xuWgP/1-3-cao-zuo-xi-t ...
- VBA 连接sql server的用法
cnnstr = "Provider=sqloledb;Data Source=192.211.21.8;Initial Catalog=pub;UID=账号;PWD=密码" VB ...