SQLite » Historie » Version 2
Jeremias Keihsler, 13.01.2017 18:28
| 1 | 1 | Jeremias Keihsler | h1. SQLite |
|---|---|---|---|
| 2 | |||
| 3 | h2. Backup DB |
||
| 4 | |||
| 5 | While SQLite-DB consists of just one file, you shouldn't just copy the file. It might be corrupted by doing so. |
||
| 6 | |||
| 7 | If you want to copy the DB-file you might want to (taken from http://stuvel.eu/blog/55/safely-copy-a-sqlite-database) |
||
| 8 | <pre><code class="bash"> |
||
| 9 | shell$ sqlite3 some.db |
||
| 10 | sqlite> begin immediate; |
||
| 11 | <press CTRL+Z> |
||
| 12 | shell$ cp some.db some.db.backup |
||
| 13 | shell$ exit |
||
| 14 | sqlite> rollback; |
||
| 15 | </code></pre> |
||
| 16 | |||
| 17 | the other way may be dumping the DB. This is easily done by |
||
| 18 | <pre><code class="bash"> |
||
| 19 | sqlite3 sample.db .dump > sample.bak |
||
| 20 | </code></pre> |
||
| 21 | |||
| 22 | based on the rsnapshot-backup-script for postgresql following script might be invoked by rsnapshot |
||
| 23 | <pre> |
||
| 24 | ############################################################################## |
||
| 25 | # backup_sqlite.sh |
||
| 26 | # |
||
| 27 | # by Jeremias Keihsler <j@keihsler.com> |
||
| 28 | # http://www.keihsler.com/ |
||
| 29 | # |
||
| 30 | # based on the backup_pgsql.sh script |
||
| 31 | # by Nathan Rosenquist <nathan@rsnapshot.org> |
||
| 32 | # |
||
| 33 | # This is a simple shell script to backup a SQLite database with rsnapshot. |
||
| 34 | # |
||
| 35 | # The assumption is that this will be invoked from rsnapshot and also that it |
||
| 36 | # will run unattended. |
||
| 37 | # |
||
| 38 | # This script simply needs to dump a file into the current working directory. |
||
| 39 | # rsnapshot handles everything else. |
||
| 40 | ############################################################################## |
||
| 41 | |||
| 42 | umask 0077 |
||
| 43 | |||
| 44 | # backup the database |
||
| 45 | /usr/bin/sqlite3 /var/www/html/owncloud/data/owncloud.db .dump > owncloud_dumpall.sql |
||
| 46 | |||
| 47 | # make the backup readable only by root |
||
| 48 | /bin/chmod 600 owncloud_dumpall.sql |
||
| 49 | </pre> |
||
| 50 | 2 | Jeremias Keihsler | |
| 51 | h2. Restore DB |
||
| 52 | |||
| 53 | <pre><code class="bash"> |
||
| 54 | mv sample.db sample.db.old |
||
| 55 | sqlite3 sample.db < sample.bak |
||
| 56 | </code></pre> |