-
Notifications
You must be signed in to change notification settings - Fork 162
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow quick pre-allocation of files on Window, probably via sparse files #719
Comments
This is a good idea. But probably it's better to disable preallocation on
windows, I'm not sure if pre-allocation on sparse files actually works.
Alexander.
…On Fri, 29 Dec 2023 at 13:35 Sergei Kuzmin ***@***.***> wrote:
Right now downloading files onto NTFS in Windows effectively involves
double write. Initially the file is pre-allocated and filled with zeroes,
which involves actual write of zeroes and is slow for large files, and then
the actual download happens.
The ask is to allow creating such files as sparse. Preallocation becomes
instant. Write is the same speed as for normal pre-allocated files
(probably even more efficient for SSD as no trim is necessary). I've tried
the dos commands from here <https://superuser.com/a/314319/1699093>.
Haven't checked c/posix equivalents yet. I checked that such files are
supported by systems with incomplete NTFS support (e.g. Linux routers)
opposing to compressed NTFS files.
What do you think?
—
Reply to this email directly, view it on GitHub
<#719>, or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAHLWXDPJD4LXGD52UIVRKLYL2MG7AVCNFSM6AAAAABBGOTA4SVHI2DSMVQWIX3LMV43ASLTON2WKOZSGA2TSMRZGY2TQMI>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
To be clear, by preallocation I mean the actions like with the above link:
Windows cmd.exe script:
After these command we end up in a file of any wanted size logically filled with zeroes but occupying virtually zero disk space. During parallel downloading (--use-pget-n N) I assume Windows will recognize sequential access and will be allocating large continuous blocks per each stream. The allocation can be checked with I did some experiments by writing random bytes inside the sparse file. Powershell script:
After writing to a specific location, I was checking how allocation looks like. I haven't checked how sectors/clusters are actually allocated on the disk. Do you mean that there is some explicit action by lftp to fill the file with zeros which can be avoided? |
Right now downloading files onto NTFS in Windows effectively involves double write. Initially the file is pre-allocated and filled with zeroes, which involves actual write of zeroes and is slow for large files, and then the actual download happens.
The ask is to allow creating such files as sparse. Preallocation becomes instant. Write is the same speed as for normal pre-allocated files (probably even more efficient for SSD as no trim is necessary). I've tried the dos commands from here. Haven't checked c/posix equivalents yet. I checked that such files are supported by systems with incomplete NTFS support (e.g. Linux routers) opposing to compressed NTFS files.
What do you think?
The text was updated successfully, but these errors were encountered: