[Bug 10380] New: Non-Nested Folder Optimisation

samba-bugs at samba.org samba-bugs at samba.org
Tue Jan 14 10:22:13 MST 2014


https://bugzilla.samba.org/show_bug.cgi?id=10380

           Summary: Non-Nested Folder Optimisation
           Product: rsync
           Version: 3.1.0
          Platform: All
        OS/Version: All
            Status: NEW
          Severity: enhancement
          Priority: P5
         Component: core
        AssignedTo: wayned at samba.org
        ReportedBy: me at haravikk.com
         QAContact: rsync-qa at samba.org


One handy feature of most (all?) unix file systems is that if the contents of a
folder are changed, then the folder's modified time will be updated as well,
which presents an opportunity for optimised comparisons.

Quite simply, if a folder's modified time is the same as the corresponding
folder in the destination, then no comparison of its contents needs to be
performed.
At least, that is true if the folder doesn't contain any nested folders, as
modifications to these do not affect the parent folder's modified time.

What I would like to propose is that when rsync begins generating a file list
for a destination directory, that it should attempt to mark any directories
that do no contain nested directories. When it comes time to compare such a
directory, the comparison can be done using only the modified times (if rsync
is operating in that mode), and only needs to compare file lists if these times
differ. Provided rsync is able to generate enough of the destination file-list
in advance, then this should allow many unchanged folders to be skipped in
their entirety, without having to delve further into their contents.

This feature could be enhanced by the use of a metadata file (see bug 10379) by
storing a flag in a destination folder if it contains no nested directories.
This way, so long as the metadata file is valid, there is no need to process
the directory's file-list before an optimised comparison is performed.

-- 
Configure bugmail: https://bugzilla.samba.org/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are the QA contact for the bug.


More information about the rsync mailing list