首页 / C# / c# – 记录Windows服务
c# – 记录Windows服务
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 记录Windows服务,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1916字,纯文字阅读大概需要3分钟。
内容图文
![c# – 记录Windows服务](/upload/InfoBanner/zyjiaocheng/970/382936c39f084cef9087bf8fa7cfcf78.jpg)
我有以下代码用于记录我通过在线研究找到的Windows服务.
它在我的服务类内部完成之前就像在下面初始化一样.
public GBBInvService()
{
InitializeComponent();
if (!System.Diagnostics.EventLog.SourceExists("MyLogSource"))
System.Diagnostics.EventLog.CreateEventSource("MyLogSource",
"MyDoLog");
eventLog1.Source = "MyLogSource";
eventLog1.Log = "MyDoLog";
}
记录时的代码:
eventLog1.WriteEntry("GBBInvService Service Started");
然而,我的顾问却反对我.他的评论如下:
我会避免让服务在运行时创建事件源.这要求服务以高权限运行(即,比实际需要更多地访问计算机).设置Windows事件日志源实际上是一个安装时间作业.您可以将事件日志安装程序添加到项目安装程序文件(以及服务安装程序),然后事件源将始终存在
这个建议的问题是我无法找到在项目安装程序文件中创建日志的任何示例.我也尝试将此日志创建部分移动到我的项目安装程序中,但之后它不会让我从我的Web服务cs页面调用或写入eventlog1.他还建议使用log4net,但这对我来说是一个新的东西,并且很难掌握.刚刚完成我的第一个Windows服务项目,我对Windows服务仍然很陌生,并且非常感谢在项目安装程序中创建日志的任何方向,从我的服务cs页面或在log4net上的任何抬头写入它.
解决方法:
您的顾问是正确的,在服务中这样做是个坏主意.
以下是在安装程序中创建事件源的方法:
http://blogs.msdn.com/b/helloworld/archive/2008/12/11/creating-an-event-log.aspx?Redirected=true
简短版本:子类安装程序,并在子类安装程序的构造函数中创建事件日志源.
UPDATE
从链接:
After the service installer is executed, the log is ‘registered’, but not created yet. To create it, one event must be written. If the service runs using a restricted user account, that account may not have enough security permission to write the first log, as the log need to be created.
示例代码未显示正在编写的一个事件.确保你这样做.
When installing the service, the user must run the installer as Administrator
确保以管理员身份运行安装程序.
来自你的评论:
Service wouldn’t start.
查看事件日志,了解它未启动的原因.也许是抛出一个例外,例如如果您没有在安装程序中编写一个事件,或者您没有以管理员身份运行安装程序.
内容总结
以上是互联网集市为您收集整理的c# – 记录Windows服务全部内容,希望文章能够帮你解决c# – 记录Windows服务所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。