Forums / Developer / What's the best way to do remote backups ?

What's the best way to do remote backups ?

Author Message

Xavier Dutoit

Sunday 09 October 2005 3:11:16 am

Hi,

I want to remote backup an ez site, but want to be as efficient as possible on the bandwidth and storage (ie don't backup something generated by ez, only the original things).

I have two problems :

1) rsyncing var/cache is going to copy the images variations (_large,_small...).
Do you know a pattern to exclude them ?

2) mysqldump swallows a lot of ressource, and the backup contains lots of datas I don't have to backup (eg the records for the search engine).
Do you know a better alternative ?

My goal is to be able to use it with rsnapshot.

Any idea ? How do you do it ?

X+

P.S. Running a clearcache before the backup isn't a good option, as I want to run the backup often.

http://www.sydesy.com

Kristian Hole

Wednesday 12 October 2005 7:42:30 am

1) You offcourse do not need the /var/cache or /var/myvar/cache. Otherwise you need everything, maybe except the image variations as you suggest. You should be able to figure out which files you dont need with some pattern (not really helping here, am i?)
2). You can skip the ezsession table. On a big site that will be a big table, with information that is not needed in your dump. I dont remember the syntax for skipping a table with mysqldump from the top of my head...

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

Łukasz Serwatka

Wednesday 12 October 2005 11:06:06 am

mysqldump has some disadvantages. First is that mysqldump locking tables when creating database dump, so will lock access to data of database for seconds or minuets, depends how big is database. So here is important time when you doing backups, dont use it when is huge traffic. Second is that mysldump works on MySQL server so doing database dump is slower than using mysqlhotcopy.

If you have enough space on disk you can use more efficient mysqlhotcopy which copy database files, so it is faster since not using connection with MySQL server.

You can use it like:

mysqlhotcopy -u user database destination

You can create shell script which uses standard copy and compress (create tar.gz files) programmes together with mysqlhotcopy.

Personal website -> http://serwatka.net
Blog (about eZ Publish) -> http://serwatka.net/blog

Xavier Dutoit

Wednesday 12 October 2005 12:07:13 pm

Ok, so far I'm backuping:

var/<siteaccess>/storage/original
var/<siteaccess>/images

I have image variations' into /images
toto.jpg
toto_reference.jpg
toto_small.jpg
toto_large.jpg

So I'm not quite sure about what is the purpose of /images-versioned

and even with kristian's useful tips ;) can't imagine any good criteria to avoid them (I could have an original image named xxx_large.jpg for instance).

As for the table, that's a good idea to do a hot copy to avoid the lock of the "main" table, but I'm not that keen on the idea of backuping a binary format as a matter of principle.

As the tables I think I could clean without any problem:
ezsearch_object_word_link
ezsearch_word
ezsession

But I'm not sure that's a big saving so far ;)

What do you think ? I'd really like to find a pattern on how to exclude the images variations.

X+

http://www.sydesy.com

Gabriel Ambuehl

Wednesday 12 October 2005 12:14:13 pm

rsync --exclude="*imagevariationname.jpg" for all imagevariations maybe?

Edit: this obviously wont backup the odd original file that actually is NAMED *imagevariationname ;)

However: this means upon restore, that ezpublish will have to regenerate ALL images likely resulting in pretty horrible performance upon initial page loads.

I'd just bloody do the rsync. The mysqldump compresses *very well* (rsync --compress even does it good there), so I'm not sure if I'd even bother with filtering it.

Around here, we just rsync complete servers at least daily (some much more often). In many cases that means in excess of 1 MILLION files getting synced. ezpublish is a somewhat minor offender in that picture ;).

As for mysql backup, if you can use it (realistically only on a LAN), mysql replication can provide you with damn near zero lag "backup" (it also means that you'll lose all data if you do bad query, though!).

Visit http://triligon.org

Björn Dieding@xrow.de

Wednesday 12 October 2005 7:21:31 pm

2) mysqldump swallows a lot of ressource, and the backup contains lots of datas I don't have to backup (eg the records for the search engine).
Do you know a better alternative ?

Have you ever tried Mysql Administrator?

You can define backup projects with it. those are executed on a remote maschine. It will let you backup just the stuff you want.

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Brendan Pike

Wednesday 12 October 2005 8:10:10 pm

This is an intersting topic we have been looking into also.

Can you tell me is it safe to simply rsync live mysql databases or could you do nightly dumps gzip them and rsync those?

www.dbinformatics.com.au

We are always interested in hearing from experienced eZ PHP programmers and eZ template designers interested in contract work.

Gabriel Ambuehl

Wednesday 12 October 2005 11:34:05 pm

rsyncing live database files is a rather bad idea. They aren't at all guaranteed to be in a consistent state while you read them.

If your site isn't huge, mysqldump won't take that long. Otherwise, do research mysqlhotcopy but it still seems in BETA.

Visit http://triligon.org

Ole Morten Halvorsen

Thursday 13 October 2005 12:18:06 am

Gabriel Ambuehl: If your site isn't huge, mysqldump won't take that long.

You are right. Dumping ez.no (which results in a 2.3GB .sql file) takes just less than 3 minutes.

Senior Software Engineer - Vision with Technology

http://www.visionwt.com
http://www.omh.cc
http://www.twitter.com/omh

eZ Certified Developer
http://ez.no/certification/verify/358441
http://ez.no/certification/verify/272578

Alexandre Abric

Thursday 13 October 2005 12:25:55 am

I would also go for mysql replication + mysqldump + tgz of the dump.

Gabriel Ambuehl

Thursday 13 October 2005 12:26:36 am

Most would consider that huge, even ;)

That comes down to somewhere around 13MB/s which is pretty fast (unless you get mighty fast SCSI drives ;) especially on disks that do other things.

If you leave the dumps in plain text (could of course also just feed them thru gzip to save space in the first place), rsync's delta algorithm will save you LOTS of transfer time.

Visit http://triligon.org

Lazaro Ferreira

Thursday 13 October 2005 9:47:49 am

Hi,

I would recomend you rdiff-backup, it is based on rsync syncro algorithm but it has some advantages like increments backups

http://www.nongnu.org/rdiff-backup/

For live MySQL Databases backup you can go with mysqlhotcopy, we have been using it for a while without problems

If you are interested in some automation tool then you can checkup backupninja a nice backup tool that automate backup calling the tools mentioned above to do real job

http://dev.riseup.net/backupninja/

Note: I'm assumed this is for a *nix environment

Lazaro
http://www.mzbusiness.com

Xavier Dutoit

Thursday 13 October 2005 12:02:25 pm

Hi,

Didn't know these tools. What I usualy use is rsnapshot, that sits on the top of rsync+ssh+hardlinks.

Highly appreciated, and for the devs, you don't bother anymore to backup your files before doing changes, you try and if screw it too badly, you retrieve a previous version and that's it.

Still looking for a pattern to avoid the imagevariation that works everytime. I'm afraid it implies changing things on the kernel.

X+

http://www.sydesy.com

eZ debug

Timing: Jan 20 2025 16:54:29
Script start
Timing: Jan 20 2025 16:54:29
Module start 'content'
Timing: Jan 20 2025 16:54:30
Module end 'content'
Timing: Jan 20 2025 16:54:30
Script end

Main resources:

Total runtime1.0882 sec
Peak memory usage4,096.0000 KB
Database Queries238

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0062 587.8438180.8125
Module start 'content' 0.00620.8833 768.6563953.6563
Module end 'content' 0.88940.1987 1,722.3125357.3047
Script end 1.0881  2,079.6172 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00360.3290210.0002
Check MTime0.00130.1218210.0001
Mysql Total
Database connection0.00080.069710.0008
Mysqli_queries0.956087.85402380.0040
Looping result0.00290.27022360.0000
Template Total1.060797.520.5304
Template load0.00210.190720.0010
Template processing1.058697.282120.5293
Template load and register function0.00020.020910.0002
states
state_id_array0.00080.070410.0008
state_identifier_array0.00060.057420.0003
Override
Cache load0.00190.1776890.0000
Sytem overhead
Fetch class attribute can translate value0.00190.1764100.0002
Fetch class attribute name0.00110.1047170.0001
XML
Image XML parsing0.01321.2144100.0013
class_abstraction
Instantiating content class attribute0.00000.0025190.0000
General
dbfile0.01931.7722470.0004
String conversion0.00000.000430.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
6content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
13content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
19content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 49
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs