Varnostno kopirajte svoje baze podatkov MySQL prek FTP

Vultr ponuja samodejno varnostno kopiranje kot možnost za vse VPS serije Performance. Ta članek poleg te funkcije ponuja možnost za samodejno ustvarjanje dnevnih varnostnih kopij baze podatkov na strežniku in jih tudi pošiljanje prek FTP na vaš strežnik za varnostno kopiranje ali celo gostitelje datotek.

Pregled
  • Samodejno varnostno kopiranje poteka vsak dan. Čas, ko pride do varnostne kopije, je nastavljiv.
  • Številni gostitelji datotek ponujajo prenos datotek prek FTP, tako da lahko samodejno pošljete svojo bazo podatkov na svoj osebni račun.
  • Po končanem varnostnem kopiranju pošlje e-pošto.

Opis

Najprej ustvarite in preklopite v /backupsimenik.

 mkdir /backups
 cd /backups

Nato z nanoali z vašim najljubšim urejevalnikom ustvarite skriptno datoteko:

nano backupdb.sh

Zdaj kopirajte in prilepite ta skript ter uredite spremenljivke na vrhu glede na vaše nastavitve:

#!/bin/bash

############### Infos - Edit them accordingly  ########################

DATE=`date +%Y-%m-%d_%H%M`
LOCAL_BACKUP_DIR="/backups"
DB_NAME="database_name"
DB_USER="root"
DB_PASSWORD="root_password"

FTP_SERVER="111.111.111.111"
FTP_USERNAME="ftp-user"
FTP_PASSWORD="ftp-pass"
FTP_UPLOAD_DIR="/upload"

LOG_FILE=/backups/backup-DATE.log

############### Local Backup  ########################

mysqldump -u $DB_USER  -p$DB_PASSWORD $DB_NAME | gzip  > $LOCAL_BACKUP_DIR/$DATE-$DB_NAME.sql.gz

############### UPLOAD to FTP Server  ################

ftp -nv $FTP_SERVER << EndFTP
user "$FTP_USERNAME" "$FTP_PASSWORD"
binary
cd $FTP_UPLOAD_DIR
lcd $LOCAL_BACKUP_DIR
put "$DATE-$DB_NAME.sql.gz"
bye
EndFTP

############### Check and save log, also send an email  ################

if test $? = 0
then
    echo "Database Successfully Uploaded to the Ftp Server!"
    echo -e "Database Successfully created and uploaded to the FTP Server!" | mail -s "Backup from $DATE" your_email@email.com

else
    echo "Error in database Upload to Ftp Server" > $LOG_FILE
fi

Ko končate z urejanjem skripta in shranite datoteko, naredimo datoteko izvedljivo z uporabo naslednjega ukaza:

 chmod +x backupdb.sh

Zdaj ga lahko preizkusite tako, da vnesete v terminal.

 /backups/backupdb.sh

... in ko konča izvajanje, vnesite, ls -ada vidite, ali je bila baza podatkov varnostno kopirana. Preverite tudi, ali je bilo poslano na vaš FTP strežnik.

Če je do sedaj vse delovalo dobro, lahko s Crontabom poskrbimo, da se izvaja vsak dan.

Razdelki Crontab

Svoj crontab lahko uredite z naslednjim ukazom:

 crontab -e

To bo odprlo urejevalnik besedil, kamor lahko vnesete svoj urnik z vsakim opravilom v novi vrstici.

Vsak od razdelkov je ločen s presledkom, pri čemer ima zadnji del enega ali več presledkov. Tako je zastavljeno delo cron:

minuta (0-59), ura (0-23, 0 = polnoč), dan (1-31), mesec (1-12), dan v tednu (0-6, 0 = nedelja), ukaz

Torej, v urejevalnik vnesite ali prilepite to vrstico:

 30 02 * * * /backups/backupdb.sh

Zgornji primer se bo izvajal /backups/backupdb.shob 02:30 vsak dan v mesecu. Seveda lahko uro spremenite po želji.

Zdaj samo shranite in zaprite datoteko. Ob načrtovanem času bo varnostno kopiranje izvedeno.

Vodniki za Linux, MySQL in MariaDB, Skrbnik sistema

Pusti komentar

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več