Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 1 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 2 | =================== |
| 3 | Backupninja formula |
| 4 | =================== |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 5 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 6 | Backupninja allows you to coordinate system backup by dropping a few simple |
| 7 | configuration files into /etc/backup.d/. Most programs you might use for |
| 8 | making backups don't have their own configuration file format. |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 9 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 10 | Backupninja provides a centralized way to configure and schedule many |
| 11 | different backup utilities. It allows for secure, remote, incremental |
| 12 | filesytem backup (via rdiff-backup), compressed incremental data, backup |
| 13 | system and hardware info, encrypted remote backups (via duplicity), safe |
| 14 | backup of MySQL/PostgreSQL databases, subversion or trac repositories, burn |
| 15 | CD/DVDs or create ISOs, incremental rsync with hardlinking. |
| 16 | |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 17 | |
| 18 | Sample pillars |
| 19 | ============== |
| 20 | |
| 21 | Backup client with ssh/rsync remote target |
| 22 | |
jan kaufman | d631551 | 2016-02-03 21:19:09 +0100 | [diff] [blame] | 23 | .. code-block:: yaml |
| 24 | |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 25 | backupninja: |
| 26 | client: |
| 27 | enabled: true |
| 28 | target: |
| 29 | engine: rsync |
| 30 | host: 10.10.10.208 |
| 31 | user: backupninja |
| 32 | |
| 33 | Backup client with s3 remote target |
| 34 | |
jan kaufman | d631551 | 2016-02-03 21:19:09 +0100 | [diff] [blame] | 35 | .. code-block:: yaml |
| 36 | |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 37 | backupninja: |
| 38 | client: |
| 39 | enabled: true |
| 40 | target: |
Michael KutĂ˝ | 4896b92 | 2016-10-23 22:52:40 +0200 | [diff] [blame] | 41 | engine: dup |
| 42 | url: s3+http://bucket-name/folder-name |
| 43 | auth: |
| 44 | awsaccesskeyid: awsaccesskeyid |
| 45 | awssecretaccesskey: awssecretaccesskey |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 46 | |
jan kaufman | c1b2159 | 2016-01-28 14:03:03 +0100 | [diff] [blame] | 47 | Backup client with webdav target |
| 48 | |
jan kaufman | d631551 | 2016-02-03 21:19:09 +0100 | [diff] [blame] | 49 | .. code-block:: yaml |
| 50 | |
jan kaufman | c1b2159 | 2016-01-28 14:03:03 +0100 | [diff] [blame] | 51 | backupninja: |
| 52 | client: |
| 53 | enabled: true |
| 54 | target: |
Filip Pytloun | 7306f70 | 2016-02-05 17:31:18 +0100 | [diff] [blame] | 55 | engine: dup |
Filip Pytloun | 6ce66eb | 2016-02-05 17:03:00 +0100 | [diff] [blame] | 56 | url: webdavs://backup.cloud.example.com/box.example.com/ |
jan kaufman | 0b9fdb5 | 2016-02-04 15:55:08 +0100 | [diff] [blame] | 57 | auth: |
| 58 | gss: |
| 59 | principal: host/${linux:network:fqdn} |
| 60 | keytab: /etc/krb5.keytab |
jan kaufman | c1b2159 | 2016-01-28 14:03:03 +0100 | [diff] [blame] | 61 | |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 62 | Backup server rsync/rdiff |
| 63 | |
jan kaufman | d631551 | 2016-02-03 21:19:09 +0100 | [diff] [blame] | 64 | .. code-block:: yaml |
| 65 | |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 66 | backupninja: |
| 67 | server: |
| 68 | enabled: true |
| 69 | rdiff: true |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 70 | key: |
| 71 | client1.domain.com: |
Jiri Broulik | 7071533 | 2017-04-27 22:04:41 +0200 | [diff] [blame] | 72 | enabled: true |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 73 | key: ssh-key |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 74 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 75 | |
Andrey | 21ff902 | 2017-10-12 09:54:09 -0500 | [diff] [blame] | 76 | Backup client with local storage |
| 77 | |
| 78 | .. code-block:: yaml |
| 79 | |
| 80 | backupninja: |
| 81 | client: |
| 82 | enabled: true |
| 83 | target: |
| 84 | engine: local |
| 85 | |
Jaroslav Steinhaisl | 5a7068b | 2018-02-22 11:13:02 +0100 | [diff] [blame] | 86 | |
| 87 | Client scheduling in rsync engine |
| 88 | ================================= |
| 89 | |
| 90 | Client run backup at 5am every day. |
| 91 | |
| 92 | .. code-block:: yaml |
| 93 | |
| 94 | backupninja: |
| 95 | client: |
| 96 | enabled: true |
| 97 | target: |
| 98 | engine: rsync |
| 99 | scheduling: |
| 100 | when: |
| 101 | - everyday at 05 |
| 102 | |
| 103 | |
| 104 | Client run backup in mupltiple times. |
| 105 | |
| 106 | .. code-block:: yaml |
| 107 | |
| 108 | backupninja: |
| 109 | client: |
| 110 | enabled: true |
| 111 | target: |
| 112 | engine: rsync |
| 113 | scheduling: |
| 114 | when: |
| 115 | - everyday at 5 |
Jaroslav Steinhaisl | 7bfb0d8 | 2018-03-23 12:52:07 +0100 | [diff] [blame^] | 116 | - Tuesday at 05:30 |
Jaroslav Steinhaisl | 5a7068b | 2018-02-22 11:13:02 +0100 | [diff] [blame] | 117 | - 25 at 23:45 |
| 118 | - hourly |
| 119 | |
| 120 | If multiple "when" options are present, then they all apply. If two configurations files are scheduled to run in the same hour, then we fall back on the alphabetical ordering specified above. |
| 121 | |
| 122 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 123 | More information |
| 124 | ================ |
Filip Pytloun | 311d79c | 2015-10-06 16:28:31 +0200 | [diff] [blame] | 125 | |
| 126 | * https://labs.riseup.net/code/projects/backupninja/wiki/Configuration |
| 127 | * http://www.debian-administration.org/articles/351 |
| 128 | * http://duncanlock.net/blog/2013/08/27/comprehensive-linux-backups-with-etckeeper-backupninja/ |
| 129 | * https://github.com/riseuplabs/puppet-backupninja |
| 130 | * http://www.ushills.co.uk/2008/02/backup-with-backupninja.html |
Filip Pytloun | 68f73d3 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 131 | |
Ales Komarek | 7c8d2c9 | 2017-02-21 12:18:05 +0100 | [diff] [blame] | 132 | |
Filip Pytloun | 68f73d3 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 133 | Documentation and Bugs |
| 134 | ====================== |
| 135 | |
| 136 | To learn how to install and update salt-formulas, consult the documentation |
| 137 | available online at: |
| 138 | |
| 139 | http://salt-formulas.readthedocs.io/ |
| 140 | |
| 141 | In the unfortunate event that bugs are discovered, they should be reported to |
| 142 | the appropriate issue tracker. Use Github issue tracker for specific salt |
| 143 | formula: |
| 144 | |
| 145 | https://github.com/salt-formulas/salt-formula-backupninja/issues |
| 146 | |
| 147 | For feature requests, bug reports or blueprints affecting entire ecosystem, |
| 148 | use Launchpad salt-formulas project: |
| 149 | |
| 150 | https://launchpad.net/salt-formulas |
| 151 | |
| 152 | You can also join salt-formulas-users team and subscribe to mailing list: |
| 153 | |
| 154 | https://launchpad.net/~salt-formulas-users |
| 155 | |
| 156 | Developers wishing to work on the salt-formulas projects should always base |
| 157 | their work on master branch and submit pull request against specific formula. |
| 158 | |
| 159 | https://github.com/salt-formulas/salt-formula-backupninja |
| 160 | |
| 161 | Any questions or feedback is always welcome so feel free to join our IRC |
| 162 | channel: |
| 163 | |
| 164 | #salt-formulas @ irc.freenode.net |