我有一个用VB.NET编写的服务,它在本地系统帐户下运行。
我使用以下代码写入日志文件:
Dim logDirectory As String = Settings.baseDirectory
If Settings.loggingDirectory <> "\" Then
logDirectory &= Settings.loggingDirectory
End If
moFileStream = New FileStream(logDirectory & "Log.txt", FileMode.OpenOrCreate, FileAccess.Write)
moStreamWriter = New StreamWriter(moFileStream)
moStreamWriter.BaseStream.Seek(0, SeekOrigin.End)
moStreamWriter.Write(Now.ToLongDateString & vbTab & Now.ToLongTimeString & vbTab & sTekst & ControlChars.NewLine)
moStreamWriter.Flush()其中baseDirectory和loggingDirectory都是从配置文件中读取的参数。它们被正确读取,当我调试时,logDirectory保持正确的位置。
但是,当服务写入日志文件时,它总是写入sysWOW64。我已经在服务器机器上测试过这个文件夹的几个权限。甚至让每个人都有满足感,但出于某种原因,它继续给sysWOW64写信。
有人知道这会是什么吗?
发布于 2014-02-17 16:29:00
首先,关闭您的StreamWriter!
其次,尝试在moFileStream = New FileStream行上放置一个断点,并检查logDirectory在运行时等于什么。
此外,值得一提的是,您实际上并不需要使用额外的FileStream。您只需在创建新StreamWriter时指定路径即可。请参阅:http://msdn.microsoft.com/en-us/library/f5f5x7kt(v=vs.110).aspx
发布于 2014-02-18 09:06:43
filestream和streamwriter是在OnStart创建的。由于某些原因,这使得服务无法写入日志文件。
https://stackoverflow.com/questions/21833945
复制相似问题