Skip to main content

A simple backup solution that's light and portable

Project description

Simbak

Simbak is a simple backup solution that is aimed towards individuals who just want a quick and easy way to backup their files. Backups are stored as tar.gz files, so there is no dependence on any application to restore you backups.

Benefits of simbak

  • Simbak uses tar and gzip in order to store the backups, so that recovering the data in backups does not depend on simbak itself.
  • Simbak is also very light, portable, and very easy to use, meaning that there's no large application to install.
  • It's free and open source, meaning anyone can contribute or change simbak to meet their own needs.

Getting started

Note: This is in early development and changes to the API may be frequent. This project uses semantic versioning. The format of versions are {major}.{minor}.{patch}, so so while we are at version 0.x.x assume that each minor release has API changes.

Installation

To install simbak you can simple use pip.

$ pip install simbak

Using simbak

Command line

You can use simbak in many ways, the fastest way would be to use the simbak command in the terminal directly.

$ simbak [...]

You can also use the simbak module itself through the python executable.

$ python3 -m simbak [...]

In Python

You can use simbak within your own python code, and you can make python scripts to use simbak (a python script is prettier than shell script).

import simbak

simbak.backup(...)

Example usages

Each of these examples will achieve the same reults. They will create a backup of /home/projects/my_project/ and /home/docs/important.txt and it will store the backup in /backups/backups and /local/backups. The backup will be a tar.gz file and it will have the name of important--YYYY-MM-DD--hh-mm-ss, the time is stamped at the end of the backup to ensure the file is unique and not conflicting with other backups.

Python script example

# backup.py

import simbak

simbak.backup(
    sources=[
        "/home/projects/my_project/",
        "/home/docs/important.txt",
    ],
    destinations=[
        "/local/backups/",
        "/remote/backups/",
    ],
    name="important"
)

You can then run this script through the terminal using $ python backup.py.

Bash script example

Note: I am using a backslash at the end of each line in order to have a command spread across multiple lines, this helps readability.

# backup.bash

simbak \
    --source \
        "/home/projects/my_project/" \
        "/home/docs/important.txt" \
    --destination \
        "/local/backups/" \
        "/remote/backups/" \
    --name "important"

Terminal

Using simbak directly in the terminal isn't recommended unless you are backing up one directory or file to one location, as you can see the lines can get quite long.

$ simbak -s "/home/projects/my_project/" "/home/docs/important.txt" -d "/local/backups/" "/remote/backups/" --name "important"

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

simbak-0.2.0.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

simbak-0.2.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file simbak-0.2.0.tar.gz.

File metadata

  • Download URL: simbak-0.2.0.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for simbak-0.2.0.tar.gz
Algorithm Hash digest
SHA256 3d7df35e4247d4ba293e8b131379d3b53b7c311c93956268fccf3ee7d219c095
MD5 68d2dbefc59936c7efe882ff2847672e
BLAKE2b-256 cef7d9b6cf3f4a4655b9712cb3ba3647af477722aa8170ed0dc29a4cd5d333c6

See more details on using hashes here.

File details

Details for the file simbak-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: simbak-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for simbak-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1bcf962aa446ff369b63eac92c5a90740020ed4c23843f8bbd7c745f662dcefa
MD5 58666e8ad900941989135174d027beb8
BLAKE2b-256 5dcafd0b55957b8db16519526ef5725b261fd10e668c79102418934250d81ab3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page