Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.02.20;
Скачать: CL | DM;

Вниз

Как определить, что файл записан на диск полностью   Найти похожие ветки 

 
-= Demon =-   (2005-02-07 15:12) [0]

Добрый день!
Как решить следующую проблему: при появлении в папке файла нужно произвести с ним определенные действия, но при этом файл должен быть уже ПОЛНОСТЬЮ на диске (копирование больших файлов может занимать долгое время). Как отловить именно момент, когда файл ПОЛНОСТЬЮ записан на диск?
Сейчас для мониторинга папки истользую TRxFolderMonitor


 
Anatoly Podgoretsky ©   (2005-02-07 15:54) [1]

Это определить нельзя, наглядный случай логи.


 
Юрий Зотов ©   (2005-02-07 17:12) [2]

В цикле пытаться захватить файл в монопольном режиме. Когда получится - записывающая программа уже освободила файл.


 
Alexander Panov ©   (2005-02-07 19:26) [3]

Юрий Зотов ©   (07.02.05 17:12) [2]
записывающая программа уже освободила файл.


Это не означаетдля всех случаев жизни, что записывающая программа закончила работать с файлом.


 
Fay ©   (2005-02-07 21:14) [4]

2 Alexander Panov ©   (07.02.05 19:26) [3]
>> Это не означаетдля всех случаев жизни, что записывающая программа закончила работать с файлом.
IMHO, означает. Причём именно "для всех случаев жизни".


 
Alexander Panov ©   (2005-02-07 21:16) [5]

Fay ©   (07.02.05 21:14) [4]
IMHO, означает. Причём именно "для всех случаев жизни".


Думаю, что для программ, которые записывают файлы кусками, такой метод не сработает.
Пример привел Anatoly Podgoretsky ©   (07.02.05 15:54) [1]


 
Fay ©   (2005-02-07 21:22) [6]

2 Alexander Panov ©   (07.02.05 21:16) [5]
Очень необычно звучит - "Полностью записанные логи".
Если программа закрыла файл, значит закончила работу с ним.
Если она потом "захочет" продолжить - это её проблемы.


 
Anatoly Podgoretsky ©   (2005-02-07 22:19) [7]

Юрий Зотов ©   (07.02.05 17:12) [2]
Alexander Panov ©   (07.02.05 19:26) [3]
Fay ©   (07.02.05 21:22) [6]

И смотрим заголовок "файл записан на диск полностью". Лог приведен как наглядный пример, возьмем тогда другой, запись из коммуникационного файла, каждый принятый кусок записывается, файл закрывается и снова открывается для продолжения записи, делают так с целью повышения надежности например на случай сбоя, работы других программ, которым нужен подлинный размер, да мало ли еще для чего.  Определить можно только то, что в файл разрешено писать в данный момент, но не факт полной записи файла.
Файловые Базы данных в конце концов. Можно в одном месте писать, в другом читать, в третьем редактировать существующие.


 
Fay ©   (2005-02-07 22:25) [8]

2 Anatoly Podgoretsky ©   (07.02.05 22:19) [7]
Я не понял, что такое "коммуникационный файл", но хочу сказать, что метод "файл закрывается и снова открывается для продолжения записи" не даёт никакого "повышения надежности например на случай сбоя".

З.Ы.
А что такое "подлинный размер", для получения которого "файл закрывается и снова открывается"?


 
Erik1 ©   (2005-02-08 10:40) [9]

Закрытие файла дает повышение надежности, проверено.


 
Romkin ©   (2005-02-08 11:43) [10]

Вообще говоря, Find...ChangeNotification срабатывает именно когда файл закрывают после записи. То есть, сам факт уже говорит о том, что работа с файлом вроде бы закончена. А вот то, что программа больше не будет писать в файл - никто не гарантирует :)


 
Anatoly Podgoretsky ©   (2005-02-08 12:58) [11]

Fay ©   (07.02.05 22:25) [8]
Размер пишется в таблицу при закрытии файла. В случая сбоя будет неверный размер. Если после записи блока файл переоткрывать, то размер будет более менее правильный.

Неужели никогда не наблюдал при закачки с фтп, размеры значительно более 100% ?

Коммуникационный файл, это виртуальный файл, когда данные поступают например из компорта, или по фтп, при этом размер их заранее неизвестен.

Romkin ©   (08.02.05 11:43) [10]
Ну не только, а например для того чтобы сигнализировать об записи еще одного куска данных, для этого закрыть и открыть повторно.



Страницы: 1 вся ветка

Текущий архив: 2005.02.20;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.04 c
1-1107525031
Alexander Makhanev
2005-02-04 16:50
2005.02.20
узнать время неактивности юзера...


4-1105108052
!
2005-01-07 17:27
2005.02.20
ListBox


3-1106666853
Diks
2005-01-25 18:27
2005.02.20
Тригеры


3-1106304368
Grab3
2005-01-21 13:46
2005.02.20
Mysql и Delphi


6-1102612799
Eraszer
2004-12-09 20:19
2005.02.20
Получение списка локальных IP адресов.





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский