| 12345678910111213141516171819202122232425262728293031323334 | .. include:: global.rst.inc.. _internals:Internals=========This page documents the internal data structures and storagemechanisms of |project_name|. It is partly based on `mailing listdiscussion about internals`_ and also on static code analysis.Borg uses a low-level, key-value store, the :ref:`repository`, andimplements a more complex data structure on top of it, which is madeup of the :ref:`manifest <manifest>`, :ref:`archives <archive>`,:ref:`items <item>` and data :ref:`chunks`.Each repository can hold multiple :ref:`archives <archive>`, whichrepresent individual backups that contain a full archive of the filesspecified when the backup was performed.Deduplication is performed globally across all data in the repository(multiple backups and even multiple hosts), both on data and filemetadata, using :ref:`chunks` created by the chunker using theBuzhash_ algorithm.To actually perform the repository-wide deduplication, a hash of eachchunk is checked against the :ref:`chunks cache <cache>`, which is ahash-table of all chunks that already exist... toctree::    :caption: Contents    internals/security    internals/data-structures    internals/frontends
 |