A modern Python-based backup tool for MySQL databases
Project description
sqlBackup
sqlBackup is a modern Python-based backup tool for MySQL databases. It supports advanced features such as multiple archiving formats, multi-channel notifications (Telegram, Email, Slack, SMS via Twilio, Viber, etc.), and remote uploads via protocols like SFTP, FTP, or SCP. This project is a significant upgrade from the original BackupSQL shell script.
Features
-
MySQL Database Backup:
Dumps databases usingmysqldumpwith support for routines and events. -
Flexible Archiving:
Archive your backups in various formats:none(plain SQL dump)gz(gzip-compressed)xz(xz-compressed)tar.xz(tar archive compressed with xz)zip(ZIP archive)rar(RAR archive)
-
Multi-Channel Notifications:
Send notifications via:- Telegram
- Slack
- SMS (via Twilio)
- Viber
- Messenger (stub, to be implemented)
-
Remote Uploads:
Optionally upload backups to a remote server using SFTP, FTP, or SCP with configurable scheduling (daily, first day, last day, specific weekday, or a numeric day of the month). -
Wildcard Support for Ignored Databases:
Use wildcard patterns (e.g.,projekti_*) inignored_databasesto skip databases by name pattern. -
Modular & Maintainable:
Code is organized into multiple modules (configuration, backup logic, notifications, remote upload) for easier maintenance and extensibility. -
Graceful Interruption:
Handles CTRL+C gracefully, providing a user-friendly exit message. -
Comprehensive Logging:
Professional logging system with:- Colored console output with different levels (DEBUG, INFO, WARNING, ERROR, CRITICAL)
- File logging with automatic rotation (10MB max, 5 backup files)
- Detailed logging for debugging and audit trails
- Configurable log levels and output destinations
-
Configuration Validation:
Robust validation system that:- Validates all configuration parameters with detailed error messages
- Checks file paths, email formats, phone numbers, and URL formats
- Ensures required sections and fields are present
- Validates data types and allowed values
- Provides helpful warnings for potential issues
- Includes a standalone validation tool for testing configurations
Table of Contents
Documentation
For Users
- Installation Guide - Quick setup instructions
- Configuration Guide - Complete configuration reference
- Tutorials - Step-by-step tutorials for common tasks
- Configuration Validation - Validate your setup
For Developers
- API Documentation - Complete API reference and code documentation
- Developer Guide - Development setup, architecture, and contribution guidelines
- Code Examples - Practical examples and extension patterns
- Testing Guide - Testing strategies and examples
Installation
Prerequisites
- Python 3.6+ is required.
- MySQL or MariaDB client tools installed (e.g.,
mysql,mysqldump).
Step-by-Step Installation (Debian 11 Example)
-
Install Python 3 and pip
sudo apt update sudo apt install python3 python3-pip
-
Clone or copy the sqlBackup project
git clone https://github.com/klevze/sqlBackup.git cd sqlBackup
-
Install dependencies
pip3 install -r requirements.txt
-
Copy and edit the configuration file
cp config.ini.default config.ini nano config.ini
Edit
config.inito match your environment (database credentials, backup paths, notification settings, remote upload, etc.).Important: Update any placeholder paths (e.g.,
[remote].key_file) to real files on your server. -
(Optional) Install as a package
-
For development:
pip3 install -e .
-
For production:
pip3 install .
-
-
Run sqlBackup
-
From the project directory:
python3 -m sql_backup
-
Or, if installed as a package:
sql-backup
-
Tip: If you see an error about a missing private key or other file, check your config.ini paths.
Alternative installation options:
-
Quick install script (Linux/macOS):
chmod +x install.sh ./install.sh
-
Windows:
install.bat
Required dependencies:
requests: For HTTP requests (used in notifications and remote uploads).paramiko: For SFTP uploads.twilio: For sending SMS notifications.
Project Structure:
The project is organized as a modern Python package:
sqlBackup/
├── setup.py # Package installation and metadata
├── requirements.txt # Runtime dependencies
├── requirements-dev.txt # Development dependencies
├── config.ini.default # Default configuration template
├── example.py # Usage examples
├── validate_config.py # Standalone validation tool
├── sql_backup/ # Main package
│ ├── __init__.py # Package initialization
│ ├── __main__.py # Module execution support
│ ├── main.py # Application entry point
│ ├── backup.py # Database backup functionality
│ ├── config.py # Configuration management
│ ├── config_validator.py # Configuration validation
│ ├── logger.py # Logging system
│ ├── notifications.py # Multi-channel notifications
│ └── remote_upload.py # Remote upload capabilities
├── tests/ # Comprehensive test suite
│ └── test_*.py # Individual test modules
└── docs/ # Complete documentation
├── API.md # API reference
├── DEVELOPER_GUIDE.md # Development guide
├── EXAMPLES.md # Code examples
└── TUTORIALS.md # User tutorials
Logging
The application uses a comprehensive logging system that provides:
- Console Logging: Colored output with different levels (DEBUG, INFO, WARNING, ERROR, CRITICAL)
- File Logging: Automatic log rotation with 10MB max file size and 5 backup files
- Configurable Levels: Control logging verbosity via configuration
Log files are stored in the logs/ directory by default and include detailed information for debugging and audit trails.
Configuration Validation
The tool includes a standalone configuration validator that checks your configuration before running backups:
# Validate the default config file
python validate_config.py
# Validate a specific config file
python validate_config.py --config path/to/your/config.ini
# Verbose output showing all checks
python validate_config.py --verbose
The validator will check:
- Required sections and parameters are present
- Data types are correct (integers, booleans, emails, URLs)
- File and directory paths exist and are accessible
- Email formats are valid
- Phone number formats are correct for SMS notifications
- URL formats are valid for webhooks
- Cross-dependencies between configuration options
Configuration Parameters
The config.ini file is the central configuration file for sqlBackup. It is divided into several sections:
[backup]
- backup_dir: Directory where backup files will be stored.
- backup_retention_days: Number of days to retain backups.
- archive_format: Archive format to use. Options:
none,gz,xz,tar.xz,zip,rar.
[mysql]
- user, password, host: MySQL credentials.
- mysql_path: Path to the MySQL client.
- mysqldump_path: Path to the mysqldump utility.
- ignored_databases: Comma-separated list of databases to skip.
- Now supports wildcards: e.g.
sys, mysql, projekti_*. Any database name matchingprojekti_*will be ignored (e.g.,projekti_alpha,projekti_1).
- Now supports wildcards: e.g.
[telegram]
- enabled: Enable or disable Telegram notifications.
- telegram_token: Your Telegram Bot API token.
- telegram_chatid: Chat ID for notifications.
- telegram_serverid: A friendly name for your server (used in messages).
[email]
- enabled: Enable or disable email notifications.
- smtp_server, smtp_port: SMTP server details.
- username, password: SMTP credentials.
- from_address: Sender email address.
- to_addresses: Comma-separated recipient email addresses.
[slack]
- enabled: Enable or disable Slack notifications.
- webhook_url: Slack webhook URL for notifications.
[sms]
- enabled: Enable or disable SMS notifications.
- provider: Currently supports "twilio".
- account_sid, auth_token: Twilio credentials.
- from_number: Twilio phone number.
- to_numbers: Comma-separated list of recipient phone numbers.
[viber]
- enabled: Enable or disable Viber notifications.
- auth_token: Your Viber bot authentication token.
- receiver_id: Viber receiver ID (the user ID to send messages to).
- sender_name: (Optional) Sender name; defaults to "BackupBot" if not provided.
[messenger]
- enabled: Enable or disable Messenger notifications.
- page_access_token, recipient_id: Messenger API credentials (currently not implemented).
[notification]
- channels: Comma-separated list of notification channels to use (e.g.,
telegram, email, slack, sms, viber).
[export]
- include_routines: Include stored procedures and functions.
- include_events: Include scheduled events.
- column_statistics: If set to false, the script adds
--column-statistics=0to the dump command (helpful for older servers).
[logging]
- level: Logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL).
- enable_console: Enable or disable colored console output.
- enable_file_logging: Enable or disable file logging with automatic rotation.
- log_directory: Directory where log files will be stored (created automatically).
[remote]
- upload_enabled: Enable or disable remote upload of backups.
- protocol: Upload protocol (
sftp,ftp, orscp). - host, port: Remote server details.
- username, password: Remote server credentials.
- remote_directory: Remote directory where backups will be stored.
- upload_schedule: When to perform the upload (e.g.,
daily,first_day,last_day, weekday, or a specific day). - key_file, key_passphrase: (Optional) For SFTP public key authentication.
Usage
To run sqlBackup, you have several options depending on how you installed it:
Console Script (After pip install):
# Primary command
sql-backup
# Alternative name (backward compatibility)
sqlbackup
Module Execution:
# Run as Python module
python -m sql_backup
Development/Direct Execution:
# From source directory (development)
python -m sql_backup
# Standalone validation tool
python validate_config.py config.ini
Programmatic Usage:
# Import and use programmatically
from sql_backup import main
from sql_backup.backup import MySQLBackup
from sql_backup.config import load_config
# Run complete backup process
main()
# Or use individual components
config = load_config()
backup = MySQLBackup(config)
The script will:
- Connect to MySQL and dump databases (skipping those in
ignored_databases, including wildcards). - Archive each dump according to the specified format.
- Display a summary table with database name, backup status, elapsed time, dump size, and archive size.
- Send notifications via the enabled channels.
- Upload backups to a remote server if enabled and if the schedule condition is met.
Contributing
Contributions are welcome! Feel free to fork the repository, open issues, and submit pull requests. Please follow the existing code style and include tests for new features.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sqlbackup-0.2.2.tar.gz.
File metadata
- Download URL: sqlbackup-0.2.2.tar.gz
- Upload date:
- Size: 47.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e676be1e7d2867d40a0d34b53d0f91a347b73c013109998780d6ac3c4bba3198
|
|
| MD5 |
5408638639517c2efc317979fbb110eb
|
|
| BLAKE2b-256 |
87d6059642dd265f2c479a68b5cbc2111f9202b2f152b37e5f6385a57428b14e
|
Provenance
The following attestation bundles were made for sqlbackup-0.2.2.tar.gz:
Publisher:
publish-to-pypi.yml on klevze/sqlBackup
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sqlbackup-0.2.2.tar.gz -
Subject digest:
e676be1e7d2867d40a0d34b53d0f91a347b73c013109998780d6ac3c4bba3198 - Sigstore transparency entry: 316988755
- Sigstore integration time:
-
Permalink:
klevze/sqlBackup@6b5930a2ee1b56f3f0d8533b203d81930b423b3f -
Branch / Tag:
refs/tags/v0.2.2 - Owner: https://github.com/klevze
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@6b5930a2ee1b56f3f0d8533b203d81930b423b3f -
Trigger Event:
release
-
Statement type:
File details
Details for the file sqlbackup-0.2.2-py3-none-any.whl.
File metadata
- Download URL: sqlbackup-0.2.2-py3-none-any.whl
- Upload date:
- Size: 48.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ffea9ad060ca8b8a41b7fe4bd27b4081f636b2506a7ad1c019c46651d2a368b9
|
|
| MD5 |
80a9f42dd91c6c8169cc21edd24b666a
|
|
| BLAKE2b-256 |
d97a5ff2ac056b9064b2415b3c05a644699f7b308dba44ed67360917ad2c02d1
|
Provenance
The following attestation bundles were made for sqlbackup-0.2.2-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on klevze/sqlBackup
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sqlbackup-0.2.2-py3-none-any.whl -
Subject digest:
ffea9ad060ca8b8a41b7fe4bd27b4081f636b2506a7ad1c019c46651d2a368b9 - Sigstore transparency entry: 316988779
- Sigstore integration time:
-
Permalink:
klevze/sqlBackup@6b5930a2ee1b56f3f0d8533b203d81930b423b3f -
Branch / Tag:
refs/tags/v0.2.2 - Owner: https://github.com/klevze
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@6b5930a2ee1b56f3f0d8533b203d81930b423b3f -
Trigger Event:
release
-
Statement type: