repo-create.rst.inc 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. .. IMPORTANT: this file is auto-generated from borg's built-in help, do not edit!
  2. .. _borg_repo-create:
  3. borg repo-create
  4. ----------------
  5. .. code-block:: none
  6. borg [common options] repo-create [options]
  7. .. only:: html
  8. .. class:: borg-options-table
  9. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  10. | **options** |
  11. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  12. | | ``--other-repo SRC_REPOSITORY`` | reuse the key material from the other repository |
  13. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  14. | | ``--from-borg1`` | other repository is borg 1.x |
  15. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  16. | | ``-e MODE``, ``--encryption MODE`` | select encryption key mode **(required)** |
  17. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  18. | | ``--copy-crypt-key`` | copy the crypt_key (used for authenticated encryption) from the key of the other repo (default: new random key). |
  19. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  20. | .. class:: borg-common-opt-ref |
  21. | |
  22. | :ref:`common_options` |
  23. +-------------------------------------------------------+------------------------------------+------------------------------------------------------------------------------------------------------------------+
  24. .. raw:: html
  25. <script type='text/javascript'>
  26. $(document).ready(function () {
  27. $('.borg-options-table colgroup').remove();
  28. })
  29. </script>
  30. .. only:: latex
  31. options
  32. --other-repo SRC_REPOSITORY reuse the key material from the other repository
  33. --from-borg1 other repository is borg 1.x
  34. -e MODE, --encryption MODE select encryption key mode **(required)**
  35. --copy-crypt-key copy the crypt_key (used for authenticated encryption) from the key of the other repo (default: new random key).
  36. :ref:`common_options`
  37. |
  38. Description
  39. ~~~~~~~~~~~
  40. This command creates a new, empty repository. A repository is a ``borgstore`` store
  41. containing the deduplicated data from zero or more archives.
  42. Repository creation can be quite slow for some kinds of stores (e.g. for ``sftp:``) -
  43. this is due to borgstore pre-creating all directories needed, making usage of the
  44. store faster.
  45. Encryption mode TLDR
  46. ++++++++++++++++++++
  47. The encryption mode can only be configured when creating a new repository - you can
  48. neither configure it on a per-archive basis nor change the mode of an existing repository.
  49. This example will likely NOT give optimum performance on your machine (performance
  50. tips will come below):
  51. ::
  52. borg repo-create --encryption repokey-aes-ocb
  53. Borg will:
  54. 1. Ask you to come up with a passphrase.
  55. 2. Create a borg key (which contains some random secrets. See :ref:`key_files`).
  56. 3. Derive a "key encryption key" from your passphrase
  57. 4. Encrypt and sign the key with the key encryption key
  58. 5. Store the encrypted borg key inside the repository directory (in the repo config).
  59. This is why it is essential to use a secure passphrase.
  60. 6. Encrypt and sign your backups to prevent anyone from reading or forging them unless they
  61. have the key and know the passphrase. Make sure to keep a backup of
  62. your key **outside** the repository - do not lock yourself out by
  63. "leaving your keys inside your car" (see :ref:`borg_key_export`).
  64. The encryption is done locally - if you use a remote repository, the remote machine
  65. never sees your passphrase, your unencrypted key or your unencrypted files.
  66. Chunking and id generation are also based on your key to improve
  67. your privacy.
  68. 7. Use the key when extracting files to decrypt them and to verify that the contents of
  69. the backups have not been accidentally or maliciously altered.
  70. Picking a passphrase
  71. ++++++++++++++++++++
  72. Make sure you use a good passphrase. Not too short, not too simple. The real
  73. encryption / decryption key is encrypted with / locked by your passphrase.
  74. If an attacker gets your key, he can't unlock and use it without knowing the
  75. passphrase.
  76. Be careful with special or non-ascii characters in your passphrase:
  77. - Borg processes the passphrase as unicode (and encodes it as utf-8),
  78. so it does not have problems dealing with even the strangest characters.
  79. - BUT: that does not necessarily apply to your OS / VM / keyboard configuration.
  80. So better use a long passphrase made from simple ascii chars than one that
  81. includes non-ascii stuff or characters that are hard/impossible to enter on
  82. a different keyboard layout.
  83. You can change your passphrase for existing repos at any time, it won't affect
  84. the encryption/decryption key or other secrets.
  85. Choosing an encryption mode
  86. +++++++++++++++++++++++++++
  87. Depending on your hardware, hashing and crypto performance may vary widely.
  88. The easiest way to find out about what's fastest is to run ``borg benchmark cpu``.
  89. `repokey` modes: if you want ease-of-use and "passphrase" security is good enough -
  90. the key will be stored in the repository (in ``repo_dir/config``).
  91. `keyfile` modes: if you want "passphrase and having-the-key" security -
  92. the key will be stored in your home directory (in ``~/.config/borg/keys``).
  93. The following table is roughly sorted in order of preference, the better ones are
  94. in the upper part of the table, in the lower part is the old and/or unsafe(r) stuff:
  95. .. nanorst: inline-fill
  96. +-----------------------------------+--------------+----------------+--------------------+
  97. | Mode (K = keyfile or repokey) | ID-Hash | Encryption | Authentication |
  98. +-----------------------------------+--------------+----------------+--------------------+
  99. | K-blake2-chacha20-poly1305 | BLAKE2b | CHACHA20 | POLY1305 |
  100. +-----------------------------------+--------------+----------------+--------------------+
  101. | K-chacha20-poly1305 | HMAC-SHA-256 | CHACHA20 | POLY1305 |
  102. +-----------------------------------+--------------+----------------+--------------------+
  103. | K-blake2-aes-ocb | BLAKE2b | AES256-OCB | AES256-OCB |
  104. +-----------------------------------+--------------+----------------+--------------------+
  105. | K-aes-ocb | HMAC-SHA-256 | AES256-OCB | AES256-OCB |
  106. +-----------------------------------+--------------+----------------+--------------------+
  107. | authenticated-blake2 | BLAKE2b | none | BLAKE2b |
  108. +-----------------------------------+--------------+----------------+--------------------+
  109. | authenticated | HMAC-SHA-256 | none | HMAC-SHA256 |
  110. +-----------------------------------+--------------+----------------+--------------------+
  111. | none | SHA-256 | none | none |
  112. +-----------------------------------+--------------+----------------+--------------------+
  113. .. nanorst: inline-replace
  114. `none` mode uses no encryption and no authentication. You're advised NOT to use this mode
  115. as it would expose you to all sorts of issues (DoS, confidentiality, tampering, ...) in
  116. case of malicious activity in the repository.
  117. If you do **not** want to encrypt the contents of your backups, but still want to detect
  118. malicious tampering use an `authenticated` mode. It's like `repokey` minus encryption.
  119. To normally work with ``authenticated`` repos, you will need the passphrase, but
  120. there is an emergency workaround, see ``BORG_WORKAROUNDS=authenticated_no_key`` docs.
  121. Creating a related repository
  122. +++++++++++++++++++++++++++++
  123. You can use ``borg repo-create --other-repo ORIG_REPO ...`` to create a related repository
  124. that uses the same secret key material as the given other/original repository.
  125. By default, only the ID key and chunker secret will be the same (these are important
  126. for deduplication) and the AE crypto keys will be newly generated random keys.
  127. Optionally, if you use ``--copy-crypt-key`` you can also keep the same crypt_key
  128. (used for authenticated encryption). Might be desired e.g. if you want to have less
  129. keys to manage.
  130. Creating related repositories is useful e.g. if you want to use ``borg transfer`` later.
  131. Creating a related repository for data migration from borg 1.2 or 1.4
  132. +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  133. You can use ``borg repo-create --other-repo ORIG_REPO --from-borg1 ...`` to create a related
  134. repository that uses the same secret key material as the given other/original repository.
  135. Then use ``borg transfer --other-repo ORIG_REPO --from-borg1 ...`` to transfer the archives.