Solved

FileSystemWatcher behavior

Posted on 2006-10-19
11
252 Views
Last Modified: 2012-08-14

I wonder if anyone out there can confirm and explain two of my observations about FileSystemWatcher:

a) if I have a process that is continuously writing to a file for some period of time, it doesn't report an event until the process is done, then it will report a change.
b) it seems to miss file deletes if I delete it from a DOS window, but it will catch the delete if I delete it from Windows Explorer

Thanks...
0
Comment
Question by:riceman0
  • 6
  • 5
11 Comments
 

Author Comment

by:riceman0
ID: 17771692

Addendum: it is because of these two facts that I have changed my watcher mechanism to a timer-based function that continuously checks the file size.  Pretty inelegant, eh?
0
 
LVL 9

Expert Comment

by:jrscherer
ID: 17775074
Hi riceman0
What NotifyFilter do you use?
try  FileSystemWatcher1.NotifyFilter = NotifyFilters.LastWrite
Jack.net
0
 
LVL 9

Expert Comment

by:jrscherer
ID: 17775087
Oh, I forgot,
Yes, I made the same experience. Changes made in a Dos window (CMD) will not trigger the File System Watcher.
Jack.net
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 

Author Comment

by:riceman0
ID: 17775148

I've tried a variety of filters, similar results.  Do you know if it's supposed to catch changes by other processes/apps?  Or just by the user through the windows shell?  MSDN isn't entirely clear on that...
0
 

Author Comment

by:riceman0
ID: 17775244

And... changes made in Notepad DO trigger the FileSystemWatcher... what's the difference?  
0
 
LVL 9

Expert Comment

by:jrscherer
ID: 17776169
I do a lot of inter-process communication using the file system watcher. It works between processes / applications. It also works if the file is altered by a service.
Jack.net
0
 

Author Comment

by:riceman0
ID: 17776215

Any idea why not the DOS window then?  It's just another process, I would think.

Also, seen anything similar to my observation (a)?
0
 
LVL 9

Expert Comment

by:jrscherer
ID: 17776358
a) I found some missing event reporting using the Dos (CMD) window. But I did not follow up on this, since it was not an operational issue.

b) Question: do you close the write process between write statements? It will only report a write event if the write process closes. You can't access a file anyhow as long as the write process is not closed and the file is open for write by your porcess.
0
 

Author Comment

by:riceman0
ID: 17776516

The other process keeps it open and writes to it every cycle until it is done with it.  Actually I've found I can access it (for reading) while it is opened for writing by the other process, if I open it with a shared flag as follows:

Dim fs As New FileStream(FilePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite)
0
 
LVL 9

Accepted Solution

by:
jrscherer earned 500 total points
ID: 17777056
Yes, you can do this with FileShare.ReadWrite, but you have to be aware that you may read incomplete information.

If you keep the file open between writes, the FileSystemWatcher can not be used to check porgress of the write process. Then your file-size method is probably the best alternative.
Jack.net
0
 

Author Comment

by:riceman0
ID: 17777075

Thanks.  You've got at least a share of the points... I'll keep this open a bit to see if anyone has an insight as to why a delete from the DOS window doesn't (and therefore which other programs might not) trigger the FileSystemWatcher...
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Write to file when application closes (by logoff) - VB.NET 1 37
Assigning handler to UserControls in flowlayoutpanel 4 27
Crystal reports vb.net 2 54
Visual studio 2015 1 21
Article by: jpaulino
XML Literals are a great way to handle XML files and the community doesn’t use it as much as it should.  An XML Literal is like a String (http://msdn.microsoft.com/en-us/library/system.string.aspx) Literal, only instead of starting and ending with w…
A while ago, I was working on a Windows Forms application and I needed a special label control with reflection (glass) effect to show some titles in a stylish way. I've always enjoyed working with graphics, but it's never too clever to re-invent …
Microsoft Active Directory, the widely used IT infrastructure, is known for its high risk of credential theft. The best way to test your Active Directory’s vulnerabilities to pass-the-ticket, pass-the-hash, privilege escalation, and malware attacks …
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

808 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question