≡ Menu

Backup shell script to backup selected directories and upload securely (gpg) to FTP server

This script requires GNU Privacy Guard – cryptographic software on Linux / UNIX systems. GnuPG encrypts messages using asymmetric keypairs individually generated by GnuPG users. The resulting public keys can be exchanged with other users in a variety of ways, such as Internet key servers. They must always be exchanged carefully to prevent identity spoofing by corrupting public key ↔ ‘owner’ identity correspondences. It is also possible to add a cryptographic digital signature to a message, so the message integrity and sender can be verified, if a particular correspondence relied upon has not been corrupted.

GnuPG does not use patented or otherwise restricted software or algorithms, including the IDEA encryption algorithm which has been present in PGP almost from the beginning. Instead, it uses a variety of other, non-patented algorithms such as CAST5, Triple DES, AES, Blowfish and Twofish. It is still possible to use IDEA in GnuPG by downloading a plugin for it, however this may require getting a license for some uses in some countries in which IDEA is patented.

GnuPG is a hybrid encryption software program in that it uses a combination of conventional symmetric-key cryptography for speed, and public-key cryptography for ease of secure key exchange, typically by using the recipient’s public key to encrypt a session key which is only used once. This mode of operation is part of the OpenPGP standard and has been part of PGP from its first version.

Shell Script

{ 10 comments… add one }
  • altsysrq August 29, 2011, 8:51 pm

    Is there a way to hide or encrypt the passwords instead of leaving them in the script as plain text?

  • Michael Rimbach April 14, 2011, 2:13 pm

    @Jerome: I love your Script – many thanks for that :)

  • thiyagi February 16, 2011, 12:37 pm

    thanks man, the script seems good..

  • Astral God November 21, 2010, 1:41 pm

    Hello.

    There is a way to backup and upload files from an FTP server to an WebDAV server ? (https://) ?

    Thanks.

  • Lion May 31, 2010, 9:42 am

    Great! string with explanation how key can become trusted without signing was ultra helpful, Thanks!

  • Pawel April 13, 2010, 1:36 pm

    Thanks,
    It would by really good to add function to remove from the ftp files older than x days.

  • Saudi Arabia December 5, 2008, 4:15 pm

    Good !

  • Jerome November 5, 2008, 11:33 am

    I have also written a backup script which can
    * Backup a selection of files and/or directories.
    * Dump MySQL databases.
    * Backup hidden configuration files of users’ homes.
    * Backup the list of installed packages (Debian).
    * Encrypt the final archive using GPG.
    * Upload final archive via FTP (using ftp-upload) and/or SCP.

    If someone is interested, then have a look on http://zyxbackup.blogspot.com/

  • vivek June 30, 2008, 11:29 pm

    You need to add code as follows before
    # remove the files
    Add code to copy encrypted file to /home/backups
    /bin/cp $FOUT /home/backups

  • Jordi June 30, 2008, 1:08 am

    What do you do to that script if you want one copy of the generated file somewhere on your system.
    i.e on /home/backups

    Many thanks.

Security: Are you a robot or human?

Leave a Comment