1
0
mirror of https://github.com/deajan/obackup.git synced 2025-01-12 15:13:53 +01:00

Merge branch 'master' of github.com:deajan/obackup

This commit is contained in:
deajan 2013-06-14 22:30:57 +02:00
commit b263f77805
2 changed files with 74 additions and 0 deletions

60
README.md Normal file
View File

@ -0,0 +1,60 @@
obackup
=======
A file & database backup script tailored for multiple virtualhost backups locally or remotely via ssh.
Yet it actually works for a lot of backup tasks.
## About
OBackup is designed from ground to make the backup process as reliable as possible.
It divides the whole backup process into tasks, allowing each task to execute for a certain amount of time.
If a task doesn't finish in time, it's stopped and the next task is processed.
Before a task gets stopped, a first warning message is generated telling the task takes too long.
Every action gets logged, and at the end of the backup process, if there was a warning,
a stopped task or an error an alert email will be sent.
OBackup can enumerate and backup all MariaDB / MySQL databases present on a server
It can also enumarate all subdirectories of a given path and process them as separate tasks (usefull for multiple vhosts).
It will do several checks before launching a backup like execution checks, dryruns,
checking backup size and available local disk space.
Obackup will work well to backup to a snapshot aware filesystem like ZFS or btrfs.
In case you don't work with one of these, it may also rotate backups for you.
As of today, obackup has been tested successfully on RHEL / CentOS 5, CentOS 6, Debian 6.0.7 and Linux Mint 14
but should basically run on your favorite linux flavor. It relies on well known programs like rsync, ssh, mysqldump along
with other great GNU coreutils.
## Installation
You can download the latest obackup script from authors website.
You may also clone this git which will maybe have some recent bugfixes.
$ git clone git://github.com/deajan/obackup.git
$ chmod +x ./obackup.sh
Once you have grabbed a copy of Obackup, just edit it with your favorite text editor to setup your environment
and you're ready to run. A detailled documentation can be found in the CONFIG.TXT file.
You can run multiple instances of obackup scripts with different backup environments. Just copy the script to another
filename, edit it's environment and you're ready to run concurrently.
## Usage
MariaDB / MySQL backups are consistent because dumps are done with the --single-transaction option.
File backups can be done directly of the data won't change while backing up but a snapshot of the actual data to backup
is preferable as it will stay consistent (LVM, zfs or btrfs snapshots will do fine).
$ ./obackup.sh TASKNAME --dry
$ ./obackup.sh TASKNAME
## Author
Orsiris "Ozy" de Jong.

14
TODO.list Normal file
View File

@ -0,0 +1,14 @@
## Main version 1.82 build 30052013
Upcomming features:
- Check for environment sanity before execution
- Local disk space check triggers an error if backup size is bigger than a given value but should also trigger an alert if space is lower than a given value.
Bugs not yet addressed:
- Recursive task creation doesn't include files, it should
Future plans:
- Conquest world :)