zoukankan      html  css  js  c++  java
  • VS2013创建Windows服务与调试服务

    1、创建Windows服务

    说明:

      

     a)Description 服务描述,直接显示到Windows服务列表中的描述;

      b)DisplayName 服务显示名称,直接显示到Windows服务列表中的名称;

      c)ServiceName 服务进程名称,安装与卸载服务时的唯一标识。

    单击“serviceProcessInstaller1”,在其属性窗口中设置Account帐号方式,建议为LocalService(当然也可以Account属性改为 LocalSystem,这样,不论是以哪个用户登录的系统,服务总会启动)。

    编写安装和卸载脚本,并将放在bin/debug或bin/Release文件夹下。

    安装脚本

    %SystemRoot%Microsoft.NETFrameworkv4.0.30319installutil.exe %~dp0exe程序的名称.exe
    Net Start 服务名称
    sc config 服务名称 start= auto
    pause

    这里注意,在exe程序的名称前面有 %~dp0 这是代表当前位置

    服务名称 对应 上面我们创建服务时ServerName的名称

    卸载脚本

    %SystemRoot%Microsoft.NETFrameworkv4.0.30319installutil.exe /u %~dp0exe程序的名称.exe
    pause

    同时还要注意一下,本人用的.NET4.0的版本,所以Microsoft.NETFrameworkv4.0.30319installutil.exe 这一段要根据你机器安装.NET的版本来定。

    其实脚本主要是通过installutil.exe 来进行安装和卸载服务的,同时此处涉及的批处理命令不多。

    2、调试windows服务

    在项目中不用启动windows服务项目,而是直接附加进程来进行调试。

    在可用进程中,查找到你刚才通过脚本安装的服务就可以了。 

     再发一个写入服务代码的Demo

    public partial class MMSServer : ServiceBase
        {
            private Timer time = new Timer();
            public MMSServer()
            {
                InitializeComponent();
            }
    
            protected override void OnStart(string[] args)
            {
    #if DEBUG
                if (!Debugger.IsAttached)
                    Debugger.Launch();
                Debugger.Break();
    #endif
                WriteLog("服务启动,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ");
                time.Elapsed += new ElapsedEventHandler(MethodEvent);
                time.Interval = 3 * 1000;
                time.Start();
            }
    
            protected override void OnPause()
            {
    #if DEBUG
                if (!Debugger.IsAttached)
                    Debugger.Launch();
                Debugger.Break();
    #endif
                WriteLog("服务暂停,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ");
                base.OnPause();
            }
            protected override void OnContinue()
            {
    #if DEBUG
                if (!Debugger.IsAttached)
                    Debugger.Launch();
                Debugger.Break();
    #endif
                WriteLog("服务恢复,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ");
                base.OnContinue();
            }
    
            protected override void OnShutdown()
            {
                WriteLog("计算机关闭,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ");
                base.OnShutdown();
            }
    
            private void MethodEvent(object source, System.Timers.ElapsedEventArgs e)
            {
                time.Enabled = false;
                string result = string.Empty;
                try
                {
                    //.........
                    result = "执行成功,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ";
                }
                catch (Exception ex)
                {
                    result = "执行失败,原因:" + ex.Message + "
    ";
                }
                finally
                {
                    WriteLog(result);
                    time.Enabled = true;
                }
            }
            protected override void OnStop()
            {
    #if DEBUG
                if (!Debugger.IsAttached)
                    Debugger.Launch();
                Debugger.Break();
    #endif
                WriteLog("服务停止,时间:" + DateTime.Now.ToString("HH:mm:ss") + "
    ");
            }
            /// <summary>
            /// 日志记录
            /// </summary>
            /// <param name="logInfo"></param>
            private void WriteLog(string logInfo)
            {
                try
                {
                    string logDirectory = AppDomain.CurrentDomain.BaseDirectory + "\Logs";
                    if (!Directory.Exists(logDirectory))
                    {
                        Directory.CreateDirectory(logDirectory);
                    }
                    string filePath = logDirectory + "\" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt";
                    File.AppendAllText(filePath, logInfo);
                }
                catch
                {
    
                }
            }
        }
  • 相关阅读:
    线段树、最短路径、最小生成树、并查集、二分图匹配、最近公共祖先--C++模板
    数据结构中各种树
    你必须知道的基本位运算技巧(状压DP、搜索优化都会用到)
    memset为int型数组初始化问题
    Dev-C++添加代码格式化(format source code)工具Artistic Style
    让vs IIS Express支持本地静态Json文件
    什么是「供给侧改革」? 原标题:中央提的“供给侧改革”是啥意思?有谁能解说下吗?
    PowerDesigner用法和技巧
    php 调用 web Server(短信接口示例)
    sae相关配置
  • 原文地址:https://www.cnblogs.com/yunfeng83/p/6375078.html
Copyright © 2011-2022 走看看