Parhaat käytännöt: varmuuskopiointi ja palauttaminen

WP-palvelu.fi:n yksi vanhimpia ominaisuuksia on, että kaikkien asiakkaiden WordPress-sivusto varmuuskopioidaan automaattisesti kerran vuorokaudessa. Varmuuskopio jokaiselta päivältä on tallessa 30 päivän ajalta. Varmuuskopiomme ovat monesti pelastaneet asiakkaitamme suurelta haitalta ja vaivalta. Jaamme tässä artikkelissa parhaat käytännöt varmuuskopiointiin ja palauttamiseen liittyen.

Varmuuskopion tekeminen komentoriviltä

Kaikki WP-palvelu.fi:n automaattiset varmuuskopiot tapahtuvat palvelimen varusohjelmilla. Näin sekä varmuuskopion ottaminen ja ennen kaikkea palauttaminen on täysin riippumatonta siitä, toimiiko WordPress tai muu PHP-koodi. Lisäksi tämä varmuuskopiointimenetelmä antaa lisäturvaa, koska mahdollinen tietoturvamurto WordPress -sivustolle ei automaattisesti tarkoita pääsyä varmuuskopioihin ja mahdollisuutta tuhota niitä.

Varmuuskopiot sisältävät sekä tietokannan että kaikki tiedostot. Automatiikasta riippumatta varmuuskopion voi ajaa myös käsin, suorittamalla SSH-yhteyden yli komentoriviltä:

wp-backup

Tämä komento tekee tuoreen tietokantatulosteen tiedostoon /data/db/esimerkki.sql ja sen jälkeen kopioi kaikki tiedostot (mukana lukien tuoreen tietokantatiedoston) kansioon/data/backups.

Tiedostojen jättäminen varmuuskopion ulkopuolelle

Varmuuskopiokansio itsessään tietysti jää varmuuskopion ulkopuolelle. Jos käyttäjä haluaa, että myös jotain muuta jätetään varmuuskopioimatta, voi sen tiedoston tai hakemistopolun lisätä tiedostoon /data/backups/exclude.filelist.

Varmuuskopioitujen tiedostojen selaaminen

Varmuuskopiointi käyttää rdiff-backup -komentoriviohjelmaa. Kaikki tiedostot sellaisina kuin ne viimeisimmän varmuuskopioinnin ajon aikaan olivat, on selattavissa polussa /data/backups/data. Vanhempien varmuuskopioiden datat on säilötty hakemiston /data/backups/data/rdiff-backup-data/ alle.
Kaikki varmuuskopiot voi listata komennolla:

rdiff-backup -l /data/backups/data/

Esimerkkivastaus:

Found 30 increments:
 increments.2016-01-26T04:16:46+02:00.dir Tue Jan 26 04:16:46 2016
 increments.2016-01-27T04:20:26+02:00.dir Wed Jan 27 04:20:26 2016
 increments.2016-01-28T04:14:48+02:00.dir Thu Jan 28 04:14:48 2016
 increments.2016-01-29T04:19:06+02:00.dir Fri Jan 29 04:19:06 2016
...
Current mirror: Mon Feb 22 18:53:55 2016

Vaihtoehtoisesti voi ajaa komennon siten, että näkee varmuuskopion kokonaislevytilan sekä kussakin varmuuskopiossa havaittujen muutosten tiedostokoon:

rdiff-backup --list-increment-sizes /data/backups/data

Vanhempaa varmuuskopiota pääsee selaamaan ajamalla esimerkiksi:

rdiff-backup -r 2016-01-26 /data/backups/data ~/palautus-2016-01-26

Komennon jälkeen käyttäjän kotihakemistossa on kansio nimeltä palautus-2016-01-26 joka sisältää kansion /data kopion kyseiseltä päivämäärältä. Kansion sisältöä voi sitten rauhassa tutkia ja palauttaa sieltä kaikki tai vain osan tiedostoista.

Varmuuskopion palauttaminen

Jos ajoit yllä olevan komennon ja varmuuskopio tietyltä päivältä löytyy kansiosta ~/palautus-2016-01-26, voit sitten palauttaa sieltä haluamasi tiedostot esim. cp-komennolla. Kansion /data/wordpress palauttamiseksi varmuuskopioista pitää ajaa:

rm -r /data/wordpress
cp -ra ~/palautus-2016-01-26/data/wordpress /data/wordpress

Tietokantaan varmuuskopion voisi palauttaa tässä esimerkissä ajamalla:

wp db import ~/palautus-2016-02-26/db/esimerkki.sql

Ohjelma wp-backup ajaa vastaavasti yllä olevan komennon vastaparia, eli wp db export -komentoa. Tietokannan varmuuskopiota palautettaessa on pidettävä mielessä, että se ylikirjoittaa vanhan tietokannan. Esimerkiksi verkkokaupassa tietokannan palauttaminen on vaarallista, koska varmuuskopion jälkeen tehtyjen tilausten tiedot katoavat tietokannasta.

Tietokantadumpissa /data/db/esimerkki.sql on koko tietokanta, sisältäen kaikki tietokantataulujen määrittelyt ja kaikki tietokantarivit. Jokainen tietokantarivi on omalla rivillään, joten tietokantadumppeja on kätevämpi verrata keskenään esim diff -komentoa käyttäen, tai graafisesti meld -työkalulla.

Varmuuskopion avulla sivuston voi palauttaa paitsi WP-palvelussa, myös missä tahansa muualla. Varmuuskopion tiedostomuoto on avoin eikä millään tavalla toimittajariippuvainen. Jos haluaa sivustolleen lisävarmuutta, kannattaa kopioida /data -kansio erilliselle tietokoneelle säännöllisin väliajoin. Kansiosta löytyvät kaikki tiedostot ja tietokanta viimeisimmän varmuuskopion ottamishetkeltä, joten sitä käyttäen voi WordPress-sivuston pystyttää uudestaan mille tahansa palvelimelle.

Menivätkö komennot jo sekaisin? Asiantuntija-apua tarjolla

Tämän melko teknisen artikkelin avulla on kuka tahansa vapaa hyödyntämään varmuuskopioiden tarjoamia mahdollisuuksia. Seravon asiantuntijat ovat toki myös aina käytettävissä varmuuskopio- ja palautusasioissa tuntityöpohjalta asiakkaiden niin toivoessa. Ja kun sivusto on Seravon ylläpidossa, voi päivittäiset varmuuskopiohuolet jättää meidän harteillemme.

PS. Koska viimeksi varmuuskopioit oman tietokoneesi tai työasemasi?