Le réseau pour les développeurs > Forums - Accueil > Visual C# General > How to read files that are exclusively locked by other applications?
Poser une questionPoser une question
 

TraitéeHow to read files that are exclusively locked by other applications?

  • vendredi 2 mai 2008 06:11John DeSouza Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     A du code

    Hi,

    I am trying to read log files that are updated by a daemon process on the server. The daemon process is an COM application writing to the files exclusively. How can I read the files? To simulate the workflow, I have created the following snippet, which reproduces the problem I am facing.

    I get the exception : "The process cannot access the file 'C:\\Temp\\FileLockTest1.txt' because it is being used by another process."

     

     

    static void Main(string[] args)  
     
    {  
     
    FileStream exclusiveWriter = new FileStream(@"C:\Temp\FileLockTest1.txt", FileMode.OpenOrCreate, FileAccess.Write, FileShare.None);  
     
    for (byte counter = 0; counter < 100; counter++)  
     
    {  
     
    exclusiveWriter.WriteByte(counter);  
     
    }  
     
    FileStream sharedReader = new FileStream(@"C:\Temp\FileLockTest1.txt", FileMode.Open, FileAccess.Read, FileShare.Read);  
     
    sharedReader.Seek(0, SeekOrigin.Begin);  
     
    for (byte counter = 0; counter < 100; counter++)  
     
    {  
     
    Console.WriteLine(sharedReader.ReadByte());  
     
    }  
     
    exclusiveWriter.Close();  
     
    sharedReader.Close();  
     
    Console.ReadLine();  
     
    }  
     

     

    Thanks in advance,

    - Johnson

    • ModifiéJohn DeSouza mardi 3 juin 2008 09:48Added snipped block
    •  

Réponses

  • vendredi 2 mai 2008 16:34ShellShock Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     Traitée

    I can only see two options:

     

    1 Get the daemon process code changed so it allows read access. This assumes you have access to the source code, or you can get it changed. Why do people write logging code that exclusive locks the log file? This is very bad practice! Maybe they don't want anyone to ever look at the log?

     

    2. Copy the file as you are already doing.

Toutes les réponses

  • vendredi 2 mai 2008 07:12EyalShilony Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     
     John DeSouza wrote:

    Hi,

    I am trying to read log files that are updated by a daemon process on the server. The daemon process is an COM application writing to the files exclusively. How can I read the files? To simulate the workflow, I have created the following snippet, which reproduces the problem I am facing.

    I get the exception : "The process cannot access the file 'C:\\Temp\\FileLockTest1.txt' because it is being used by another process."

     

    static void Main(string[] args)

    {

    FileStream exclusiveWriter = new FileStream(@"C:\Temp\FileLockTest1.txt", FileMode.OpenOrCreate, FileAccess.Write, FileShare.None);

    for (byte counter = 0; counter < 100; counter++)

    {

    exclusiveWriter.WriteByte(counter);

    }

    FileStream sharedReader = new FileStream(@"C:\Temp\FileLockTest1.txt", FileMode.Open, FileAccess.Read, FileShare.Read);

    sharedReader.Seek(0, SeekOrigin.Begin);

    for (byte counter = 0; counter < 100; counter++)

    {

    Console.WriteLine(sharedReader.ReadByte());

    }

    exclusiveWriter.Close();

    sharedReader.Close();

    Console.ReadLine();

    }

     

    Thanks in advance,

    - Johnson

    Try to change FileShare.Read to FileShare.ReadWrite .

     

    Best Regards.

  • vendredi 2 mai 2008 08:23John DeSouza Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     

     

    Hi,

    Thanks for your reply. I tried changing the FileShare to "ReadWrite". But am still getting the same exception!!

     

  • vendredi 2 mai 2008 08:49Sasha GoldshteinMVPMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     
    Of course you are getting the same exception.  If a process opens a file and specifies FileShare.None (which is equivalent to FILE_SHARE_NONE in Win32), then there is no documented way to access the file from another process.  That's the whole idea of the file share enumeration.
  • vendredi 2 mai 2008 10:08John DeSouza Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     

    This is an important business requirement and I've got to implement it anyhow. Is there any "undocumented" way or any workaround to get this done?

    Currently I copy the file to a temp location and read it from there. Not the most elegant solution I know. Any help would be appreciated.

     

    Thanks in advance.

     

     

  • vendredi 2 mai 2008 16:34ShellShock Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     Traitée

    I can only see two options:

     

    1 Get the daemon process code changed so it allows read access. This assumes you have access to the source code, or you can get it changed. Why do people write logging code that exclusive locks the log file? This is very bad practice! Maybe they don't want anyone to ever look at the log?

     

    2. Copy the file as you are already doing.

  • samedi 3 mai 2008 22:25EyalShilony Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     
     ShellShock wrote:

    I can only see two options:

     

    1 Get the daemon process code changed so it allows read access. This assumes you have access to the source code, or you can get it changed. Why do people write logging code that exclusive locks the log file? This is very bad practice! Maybe they don't want anyone to ever look at the log?

     

    2. Copy the file as you are already doing.

     

    1, Not really a bad practice, it might be a requirement to one of the process operations.

     

    2. Not the most elegant solution as the OP said but it should work. Smile

  • vendredi 9 mai 2008 08:29John DeSouza Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     

    Hmm.. I have done it by copying the file locally and works fine for now.

    Thank you all for your time.

     

  • vendredi 9 mai 2008 08:29John DeSouza Médailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateurMédailles de l'utilisateur
     

    Hmm.. I have done it by copying the file locally and works fine for now.

    Thank you all for your time.