且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

在 Windows 服务中使用 Timer 的问题

更新时间:2022-08-13 19:55:03

 今天开始用C#做一个 Windows 服务,作用是定时像服务器上传本机的外网IP,方便我随时对电脑进行管理。功能很简单,但由于之前没有做过 Windows 服务,所以还是得上网学习一下。在网上很容易找到如何开发一个 Windows 服务的资料,这不,很快就找到了现成的介绍:

1. 新建一个项目 
2. 从一个可用的项目模板列表当中选择Windows服务 
3. 设计器会以设计模式打开 
4. 从工具箱的组件表当中拖动一个Timer对象到这个设计表面上 (注意: 要确保是从组件列表而不是从Windows窗体列表当中使用Timer)
5. 设置Timer属性,Enabled属性为False,Interval属性30000毫秒 
6. 切换到代码视图页(按F7或在视图菜单当中选择代码),然后为这个服务填加功能

这个说明正好适用于我要做的程序,于是照此一步步的操作。在从工具箱添加 Timer1 控件之后,双击它,vs自动生成 timer1_Tick 方法,用于编写定期触发时要执行的代码:

 

在 Windows 服务中使用 Timer 的问题

代码写好后按F5执行,弹出提示:“无法从命令行或调试器启动服务。必须首先安装 Windows 服务(使用 installutil.exe),然后用 ServerExplorer、Windows 服务管理工具或 NET START 命令启动它。”于是以管理员身份运行命令提示符,执行 installutil 加上编译出来的exe路径,安装好该服务。

打开services.msc,果然有我这个小东西在里面,可启动之后却发现它没有按照预定的代码执行,没有写入任何日志信息,用程序监视也发现其没有任何操作。

于是决定调试一下,却发现服务是不能直接在VS中调试的,因为不能直接运行它,必须通过附加到进程的方法来调试,稍微麻烦一点。但调试的结果也令人失望,下的断点一个也没有反应。

最后想到是不是 Timer 并没有启动呢?试着把 Timer 的 Enable 属性设置为 true,再重试还是不行。难道是这个 Timer 压根就不工作吗?

之前了解过,在 .NET 中可以使用三种 Timer:

基于服务的Timer   System.Timers.Timer 
基于线程的Timer   System.Threading.Timer  
基于窗体的Timer   System.Windows.Forms.Timer

是不是我选择了错误的那个 Timer,所以不能工作呢?找到刚才按照教程从工具箱中拖过来的那个 timer1 控件,发现这种方法生成的是 System.Windows.Forms.Timer,但我的确是按照教程,从组件列表中选择的,没有错啊,难道是教程错了吗?

于是果断的删除掉 timer1,再通过代码手动定义一个 System.Timers.Timer:

在 Windows 服务中使用 Timer 的问题

再次尝试,终于看到代码成功执行,生成了需要的日志文件。

看来,学习千万不能依葫芦画瓢啊,特别是网上的知识,获取很方便,但正确程度是不高的,切不可完全相信,需要增强自己的判断能力,去粗取精



本文转自wbpluto 51CTO博客,原文链接:http://blog.51cto.com/wbpluto/612228,如需转载请自行联系原作者