git-annex/doc/todo/speed_up_import_tree.mdwn

45 lines
2 KiB
Text
Raw Normal View History

2023-05-30 19:42:34 +00:00
Users sometimes expect `git-annex import --from remote` to be faster than
it is, when importing hundreds of thousands of files, particularly
from a directory special remote.
I think generally, they're expecting something that is not achievable.
It is always going to be slower than using git in a repository with that
many files, because git operates at a lower level of abstraction (the
filesystem), so has more optimisations available to it. (Also git has its
own scalability limits with many files.)
Still, it would be good to find some ways to speed it up.
2023-05-30 19:49:52 +00:00
---
What if it generated a git tree, where each file in the tree is
2023-05-30 19:42:34 +00:00
a sha1 hash of the ContentIdentifier. The tree can just be recorded locally
somewhere. It's ok if it gets garbage collected; it's only an optimisation.
On the next sync, diff from the old to the new tree. It only needs to
import the changed files!
(That is assuming that ContentIdentifiers don't tend to sha1 collide.
If there was a collision it would fail to import the new file. But it seems
reasonable, because git loses data on sha1 collisions anyway, and ContentIdentifiers
are no more likely to collide than the content of files, and probably less
likely overall..)
2023-05-30 19:49:52 +00:00
How fast can a git tree of say, 10000 files be generated? Is it faster than
querying sqlite 10000 times?
2023-05-30 21:19:23 +00:00
Once it knows which files are changed, it still needs to generate the
imported tree, which contains both changed and unchanged files. How to
handle unchanged files when generating that tree? Current method is
to do a database lookup to convert the ContentIdentifier into a Key, and
record that in the tree. But those database lookups are the slow thing that
needs to be avoided. Seems like it will need to either use adjustTree, or a
separate index file. (The index file would make importing a History hard.)
2023-05-30 19:49:52 +00:00
----
2023-05-30 19:42:34 +00:00
Another idea would to be use something faster than sqlite to record the cid
to key mappings. Looking up those mappings is the main thing that makes
import slow when only a few files have changed and a large number have not.
--[[Joey]]