Automatski sigurnosno kopirajte više MySQL ili MariaDB baza podataka

Uvod

U ovom zapisu ćemo proći kroz kako napraviti sigurnosnu kopiju više MySQL ili MariaDB baza podataka koje se nalaze na istom stroju koristeći prilagođenu bash skriptu i postavljanje cron posla.

Sigurnosna kopija(e) baze podataka

Pretpostavit ćemo da imamo tri MySQL baze podataka na našoj Vultr instanci pod nazivom db-vultr-site , db-vultr-blog , db-vultr-app (Ne brinite o stvaranju ovih baza podataka, moći ćete zamijeniti njihova imena za vaše gdje se koriste u skripti u koraku 2 u nastavku) .

  1. Prijavite se na svoju MySQL ili MariaDB bazu podataka i pokrenite upit ispod da biste stvorili korisnika baze podataka db_user_backupsza rukovanje sigurnosnim kopijama

    GRANT LOCK TABLES, SELECT, SHOW VIEW, REPLICATION CLIENT ON *.* TO 'db_user_backups'@'%' IDENTIFIED BY '{COMPLEX-PASSWORD}';
    

    Također pokrenite dolje kako biste bili sigurni da je MySQL konfiguriran za ispravno vraćanje pohranjenih procedura

    SET GLOBAL log_bin_trust_function_creators = 1;
    
  2. Postavite nužnu strukturu direktorija i potrebne datoteke

    # create backup directory with environment and log file
    sudo mkdir /backups && cd /backups
    sudo touch .env db-backup.sh db-backup.log
    sudo chmod -R 775 /backups
    sudo chmod -R g+s /backups
    sudo chmod +x db-backup.sh
    
    # add mysql backup user credentials into environment file
    echo "export MYSQL_USER=db_user_backups" > /backups/.env
    echo "export MYSQL_PASS={COMPLEX-PASSWORD}" >> /backups/.env
    
  3. Otvorite db-backup.sh nano /backups/db-backup.shi zalijepite donji kod unutar njega, a zatim spremite datoteku (Ctrl+X -> Y -> pritisnite Enter) .

    DB_NAMES=( 'db-vultr-site' 'db-vultr-blog' 'db-vultr-app' ) #replace with your own database name(s)
    BKUP_NAMES=()
    BKUP_DIR="/backups"
    
    # get total number of directories
    total_dbs=${#DB_NAMES[@]}
    
    # create backup file names
    for (( i=0; i<${total_dbs}; i++ )); do
        BKUP_NAMES[$i]="`date +%Y%m%d%H%M`-backup-$${DB_NAMES[$i]}.sql.gz"
    done
    
    # get backup users credentials
    source $BKUP_DIR/.env
    
    # create backups
    for (( i=0; i<${total_dbs}; i++ )); do
        # NOTE: --routines flag makes sure stored procedures are also backed up
        mysqldump --routines -u ${MYSQL_USER} -p${MYSQL_PASS} | gzip > ${BKUP_DIR}/${BKUP_NAMES[$i]}
    done
    

    Gornji kod se vrti kroz niz s imenima baze podataka koje želite sigurnosno kopirati i to čini.

Postavljanje Cronjoba

Postavite cronjob za pokretanje svake ponoći koji pokreće skriptu za sigurnosnu kopiju i sprema rezultat/izlaz u zapisnik sigurnosne kopije.

  1. Otvorite crontab

    crontab -e
    
  2. Dodajte donji unos u crontab

    0 0 * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

    Napomena: Tijekom testiranja možete postaviti cronjob da radi svake 1 minute umjesto kao dolje

    * * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

    -ILI- svakih 5 minuta (zamijenite 5 s brojem minuta koji želite)

    */5 * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

Što je sljedeće

Vjerojatno nećete željeti da vaše sigurnosne kopije budu na istim poslužiteljima na kojima se izvodi vaša baza podataka, već umjesto toga na poslužitelju na drugom geografskom mjestu. Postoji nekoliko načina za to, u rasponu od korištenja SFTP-a do korištenja prilagođenih alata koje nudi bezbroj pružatelja usluga pohrane u oblaku koji su dostupni. Jedna dobra alternativa je Rsync kako je ovdje objašnjeno - vultr.com/docs/setup-file-mirroring-using-rsync-in-debian-ubuntu

Napisala Lami Adabonyan

Ostavite komentar

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više