Backup and restore FAQ: Difference between revisions

From MoodleDocs
(Copied from 4.2 Docs)
 
(41 intermediate revisions by 11 users not shown)
Line 17: Line 17:


For a site administrator, [[Automated course backup|automated course backups]] are more expensive in terms of time, CPU usage and storage. The recovery time to have a site running again takes longer than a site backup. However, teachers and site administrators might find a course backups as a way to create a "fresh" copy of a course that can be re-used (in older versions of Moodle, in newer versions see [[Import course data]]) or as a method to distribute a course(s) to other Moodle sites.
For a site administrator, [[Automated course backup|automated course backups]] are more expensive in terms of time, CPU usage and storage. The recovery time to have a site running again takes longer than a site backup. However, teachers and site administrators might find a course backups as a way to create a "fresh" copy of a course that can be re-used (in older versions of Moodle, in newer versions see [[Import course data]]) or as a method to distribute a course(s) to other Moodle sites.
==Why is my automated course backup much smaller in size than my manual course backup?==
This is an intentional design decision. Because of the way files are stored in Moodle 2.x, there is no need to include the files in the backup if you are planning to restore them to the same Moodle site. Leaving them out saves huge amounts of disk space and makes the backup procedure much faster.


==What data is not contained in course backups?==
==What data is not contained in course backups?==
Line 28: Line 24:
* Scales are only backed up if they are used by at least one activity.
* Scales are only backed up if they are used by at least one activity.
* Users' passwords are not backed up when the "Include enrolled users" option is selected.
* Users' passwords are not backed up when the "Include enrolled users" option is selected.
* Glossary data
* Badges - if they have not been awarded to at least one user and users are not included in the course backup.
==How do I fix backups that lack the student log and participation data?==
In ''Site administration > Courses > Backups > General backup defaults'', there is a setting for "Include logs." By default, this is off.
If you enable this, then the logs from the user activities can be saved as the option "Include course logs" will now appear on the backup menu of items to include in the backup. These logs provide the data that the various reports such as Course participation, Logs, and Activity report, use to produce their reports.
==How do I fix backups that lack the student grade history?==
In ''Site administration > Courses > Backups > General backup defaults'', there is a setting for "Include histories." By default, this is off.
If you enable this, then the logs from the user grade history and its changes made by teachers manually or by certain activities can be saved when performing a Backup. The option "Include grade history" will now appear on the backup menu of items to include in the backup.
==What do the backup file names mean?==
The default backup file name is composed of the following parts:
*backup-moodle2-  :: This tells you that it is backup file of version 2 backup, which have been used since Moodle 2.0, and so it not a Moodle 1 backup file
*course-##-  ::  This tells you it is a course backup and the ## is the internal id number of the course, as seen in the course url
*shortname-  :: Then follows the shortname of the course as set in the course settings
*date-time-  ::  This is the date and time in ISO format when the backup was made
* nu-nf  ::  optional suffixes: If the backup does not contain enrolled users, the -nu will be added; if the backup does not include files, the -nf will be added
*.mbz  :: The file extension stands for "Moodle backup zip" and you can rename to .zip or .gzip (depending on your server OS) to expand it
Example: backup-moodle2-course-27-HISTORY101-20210124-0916-nu-nf.mbz
Deciphered: This is a backup file from Moodle 2 or above of course with id 27 with shortname HISTORY-101 made on Jan 24, 2021 at 09:16 AM with no enrolled users and no files included in it.
==How can I backup or restore a very large course?==
See Backup via CLI in [[Course backup]] and Restore via CLI in [[Course restore]] (new in 3.10 onwards).


==The process ends with: "Error: An error occurred deleting old backup data". What should I do?==
==The process ends with: "Error: An error occurred deleting old backup data". What should I do?==
Line 37: Line 66:
# Delete old files from "moodledata/temp/backup": Delete the dir completely and try again.
# Delete old files from "moodledata/temp/backup": Delete the dir completely and try again.


[[Image:BackupProblem.gif|thumb|Backup error message]]For points 1 & 2, there are various ways of repairing tables, including using MySQL Admin.
[[Image:BackupProblem.gif|thumb|Backup error message]]
For points 1 & 2, there are various ways of repairing tables, including using MySQL Admin.
 
For point 3 see below:
For point 3 see below:


Line 63: Line 94:


Also, if possible, it's highly recommended to solve those problems in the original course too from Moodle itself. Once "repaired" there, problems will be out if you create new backup files in the future.
Also, if possible, it's highly recommended to solve those problems in the original course too from Moodle itself. Once "repaired" there, problems will be out if you create new backup files in the future.
==The process ends with: "moodle xml not found at root level of zip file". What can I do?==
If you are restoring from a zip file backup make sure the moodle.xml file is at the root level. To ensure this:
#Unzip the backup file of the course (example: mycourse.zip)
#Once the file is unzipped, open the folder (example: mycourse).
#Select the folders within the mycourse folder AND the moodle.xml file and create a zip of those item (example: mycourse_new.zip)
#Upload the new zip file (example: mycourse_new.zip) and restore from that.
If the backup file is guaranteed to be correct, check paths to external files (zip, unzip). Incorrect settings also lead to this error message (see the Using Moodle forum discussion [http://moodle.org/mod/forum/discuss.php?d=140355 moodle.xml not found in root...] and MDL-14812).
==The process ends with: "An error occurred while copying the zip file..."==
This problem is most likely caused by a permissions issue in the destination directory. Backup files are copied to "XXX/backupdata" under your dataroot directory (where XXX is the id of the course being backed up).
The problem could also be caused by a disk being full, though this is far less likely.
To obtain precise information about what's happening, you can enable debug messages in ''Administration > Server > [[Debugging]]'' (select the maximum level - DEVELOPER) and/or check the web server error logs.


==I Still get an XML error. How can I clean the borked XML file?==
==I Still get an XML error. How can I clean the borked XML file?==
Line 85: Line 99:
In some cases XML backup files may contain characters causing the restore process to abort, even after the steps described in the previous question. In such cases you may want to try the following:
In some cases XML backup files may contain characters causing the restore process to abort, even after the steps described in the previous question. In such cases you may want to try the following:


* Download the [http://repository.atlassian.com/atlassian-xml-cleaner/jars/atlassian-xml-cleaner-0.1.jar Atlassian XML Cleaner Utility] from the [http://confluence.atlassian.com/display/JIRA/Removing+invalid+characters+from+XML+backups JIRA Atlassian site].
* Download the [https://confluence.atlassian.com/jira/files/12079/atlassian-xml-cleaner-0.1.jar Atlassian XML Cleaner Utility] from the [http://confluence.atlassian.com/display/JIRA/Removing+invalid+characters+from+XML+backups JIRA Atlassian site].


* Unzip the problematic Moodle backup file under one empty folder. Moodle will create the course file folders as long as the unclean moodle.xml file. Please unzip using the Moodle unzip feature.
* Unzip the problematic Moodle backup file under one empty folder. Moodle will create the course file folders as long as the unclean moodle.xml file. Please unzip using the Moodle unzip feature.
Line 114: Line 128:
==Why are some courses being skipped?==
==Why are some courses being skipped?==


Moodle's ''Course backups'' routines are instructed to automatically skip courses based on three settings in ''Administration > Site administration > Courses > Backups > Automated backup setup.'' The Moodle administrator(s) use those settings to specify whether to ''Skip hidden courses'' (set by default to 'Yes'), ''Skip courses not modified since'' (set by default to '30 days'), and ''Skip courses not modified since previous backup'' (set by default to 'No'). A course which meets any of the enabled criteria will be skipped during the next run of ''Course backups''.
[[Image:autobackup_skip_settings.png|thumb|AutoBackup '''skip''' settings]]Moodle's ''Course backups'' routines are instructed to automatically skip courses based on three settings in ''Administration > Site administration > Courses > Backups > Automated backup setup.'' The Moodle administrator(s) use those settings to specify whether to ''Skip hidden courses'' (set by default to 'Yes'), ''Skip courses not modified since'' (set by default to '30 days'), and ''Skip courses not modified since previous backup'' (set by default to 'No'). A course which meets any of the enabled criteria will be skipped during the next run of ''Course backups''.
 
[[{{ns:file}}:autobackup_skip_settings.png|150px|thumb|right|Administrative 'skip' settings]]


==Why does restore stop, rather than completing?==
==Why does restore stop, rather than completing?==
Line 125: Line 137:


==Restore stops with the message "Trying to restore user xxxx from backup file will cause conflict"==
==Restore stops with the message "Trying to restore user xxxx from backup file will cause conflict"==
[[Image:Moodle 2.0 Restore breaks.png|thumb|Error message in Moodle 2.0]]


This message is displayed when:
This message is displayed when:


# The target site has a user xxxx (xxxx being the username)
# The target site has a user xxxx (xxxx being the username) - often the admin user
# The backup archive being restored also contains a user xxxx (same username)
# The backup archive being restored also contains a user xxxx (same username)
# After various comparisons, Moodle has determined that the target site user xxxx and the backup user xxxx aren't the same person.
# After various comparisons, Moodle has determined that the target site user xxxx and the backup user xxxx aren't the same person, for example: if these users have different email addresses.
 
 
If 1, 2 and 3 are all true, the restore process stops in order to prevent the backup user xxxx's activities (forum posts, quiz attempts, assignment uploads, etc.) from being associated with the target site user xxxx.
 
Here are the possible methods to make the xxxx users match and resolve the conflict:


If 1, 2 and 3 are all true, the restore process stops in order to prevent the backup user xxxx's activities (forum posts, quiz attempts, assignment uploads, etc) from being associated with the target site user xxxx.  
<ol style="list-style-type:lower-alpha">
  <li>Modify the backup archive's '''users.xml''' file and make the ''email'' or ''firstaccess'' fields match the ones in target site. Note that the '''''backup-<...>''.mbz''' is a [https://en.wikipedia.org/wiki/Tar_(computing) tarball] and can be extracted by creating a temporary folder and running '''tar -xzf ''/PATH/TO/backup-<...>''.mbz'''. When editing is complete recompress the file with '''tar -czf ''/PATH/TO/backup-<...>''.mbz *'''.</li>
  <li>Modify the target site and set the user ''email'' or ''firstaccess'' fields to match the ones in '''users.xml'''.</li>
  <li>For admin user conflicts only: enable the setting 'Allow admin conflict resolution' in ''Site administration > Courses > Backups > General import defaults''. This will result in the username in the backup file being renamed to 'admin_xyz'.</li>
</ol>


These checks and behaviour were introduced in Moodle 1.9.x and continue being valid under 2.0. It's common for the user in question to be the "admin" user (which exists in practically all Moodle installations).
==Restored users lose their passwords - How can they reset them?==


There are two possible methods to make the xxxx users match (and avoid the conflict):
When a course is restored with enroled users included, any new users not already in the system will have new accounts created for them. Backups with enroled users do not include the user passwords. Instead, a password of "restored" is placed in the database for such users. When the user attempts to log into the new site, Moodle will recognise they were restored from a course backup and give the user the following message:


a) Modify the backup archive '''users.xml''' file and make the ''email'' or ''firstaccess'' fields match the ones in target site.<br />
<pre>Restored Account.  
b) Modify the '''target site''' and set the user ''email'' or ''firstaccess'' fields to match the ones in backup archive users.xml file.
This account was imported from another server and the password has been lost. To set a new password by email, please click "Continue"</pre>


Method a) is recommended so the restore process will match both xxxx users and all activities in the backup file belonging to xxxx will be associated to the already existing target site user xxxx user.
When the user clicks the "Continue" button, they will then be sent a change password email to the email address associated with the restored account, just as if they had used the normal "Forgotten password" process. This will allow them to set a new password.


  '''NOTE:''' When using method a) be aware that the ''moodle-filename-backup.'''mbz''''' is a zip file and can be renamed to ''moodle-filename-backup.'''zip''''' and unzipped.
If you are the administrator and wish to avoid users getting such emails, remember that you can use the [[Upload users|Upload users tool]] to bulk set new passwords.
  When editing is complete, rezip and then rename using the original file name with the "*.mbz" extention.


==Why are certain course links broken in a restored course?==
==Why are certain course links broken in a restored course?==
Line 154: Line 172:
Any relative URLs e.g. <code>/mod/resource/view.php?id=xxx</code>, <code>../resource/view.php?id=xxx</code> or <code>view.php?id=xxx</code> will result in broken links when the course is restored.
Any relative URLs e.g. <code>/mod/resource/view.php?id=xxx</code>, <code>../resource/view.php?id=xxx</code> or <code>view.php?id=xxx</code> will result in broken links when the course is restored.


==I have a very large course, over 2GB, and the backup process stops.==
==Restoring a course results in broken HTML tags. What can I do?==
 
This has been known to be caused by older versions of   libxml2 and PHP  - try updating them to the latest versions.
Courses over 4GB cannot be backed up without turning on an experimental option. See 'New backup format' below.
 
Below that size, large courses can be restored in Moodle, but sometimes it needs a bit of tweaking to get it right. Moodle backup files are *.mbz fies and can be renamed to zip files. They can be unzipped, then edited, rezipped and restored. It does not matter if you are using a Linux or Windows or Mac server, a local host or anything else, the technique is the same.
 
The editing comes in two different ways, one is the resources, activities, quizzes, images. video files and so on are listed, written and referred to in the moodle.xml file. You can find the starting point and the end point of each resouce that you can delete out of the xml file.
 
The xml might look something like this:
  <file id="111">    <contenthash>b11ac9bc0cebee17acfd28d13b548331f76645bc</contenthash>
    <contextid>21</contextid>
    <component>mod_resource</component>
    <filearea>content</filearea>
    <itemid>0</itemid>
    <filepath>/</filepath>
    <filename>howtomakeatimemachine.flv</filename>
    <userid>4</userid>
    <filesize>1092320586557</filesize>
    <mimetype>video/flv</mimetype>
    <status>0</status>
    <timecreated>12345432123</timecreated>
    <timemodified>12345432123</timemodified>
    <source>howtomakeatimemachine.flv</source>
    <author>Fred Nurks</author>
    <license>allrightsreserved</license>
    <sortorder>0</sortorder>
    <repositorytype>$@NULL@$</repositorytype>
    <repositoryid>$@NULL@$</repositoryid>
    <reference>$@NULL@$</reference>
  </file>
 
When editing, make sure all this is deleted, everything between the <file></file> tags.
 
The second part of editing is locating the actual resouce if it is an image, a separate file or video then deleting it. Really large mbz files tend to have a lot of videos, often flv files, or uncompressed images, like tiffs. They can be found, and deleted easily, in the directory tree of the backup.
 
You can then rezip the edited file, rename it to an mbz and, if you have edited it right, it should restore. You can use the original file to break down really large backups over and over into four or five smaller mbz files, as many as you like.
 
It is recommended that you test the technique first on a smaller file, it is easier to follow and gets you used to xml structuring and so on. Say one course with a couple of pages, a number of different image types, a couple of videos will help you immensely. 
 
You do not have to worry about permissions in Windows or Xos servers, or concern yourself with editing rights usually. However, you may be required to ensure you are the owner fo the files being edited.
 
  '''NOTE:''' Before re-zipping, check to make sure you have removed all references to the pages/files/resources you have deleted in the moodle-backup.xml file as well. here msay be none, but check anyway.
 
== Using the new backup format (experimental) ==
{{New features}}
 
If you have large courses you may find it useful to turn on an experimental option introduced in Moodle 2.6, 'Enable new backup format' (on the admin menu under Development/Experimental/Experimental settings).
 
This option selects a different internal backup format. Without this option, you cannot back up courses larger than 4GB.
 
You can change this option at any time. Whatever the option is set to, restore works for both the old and new format. The option only affects newly-created backups.
 
When you use this option, backup files still have the .mbz extension and work the same way, but there are some differences:
 
* There is no limit on total backup size. (We have tested with courses up to about 10GB.)
* Files may be slightly smaller.
* If you need to edit this type of backup file manually, you will need to rename the .mbz file to .tar.gz, instead of .zip. You may need to use different software to extract and recompress this type of file. We have tested using GNU tar on Windows and Linux.
 
The new backup format is experimental, but is being used in some large sites and may be enabled as default in a future Moodle version. If you find problems with it, please report them in the Moodle tracker.


==How can I extract original files from a Moodle backup file?==
==How can I extract original files from a Moodle backup file?==
If you really want to get original files from the backup file (an ".mbz" file) you downloaded (using the backup and restore feature), you can do so in much the same way as is suggested above.  
If you really want to get original files from the backup file (an .mbz file) you downloaded (from the course's restore page), you can do so in much the same way as is suggested above.  


The backup file can actually be opened with any zip/unzip program you can download. Once you open the file, you need to extract:
The backup file can be opened with the command '''tar -xzf ''/PATH/TO/backup-<...>''.mbz'''. Create a temporary folder to extract the backup's files into.


    The files.xml file.
Next step would be to open the '''files.xml''' file in a text editor, and:
    The files directory (folder).


Next step would be to open the "files.xml" file in a text editor, and:
# Search for the name of each file you want to get.
# Take note of the value of the corresponding contenthash tag.
# In the '''files''' folder you extracted, locate the file whose name is the same as the value of the contenthash and which will be located in a folder whose name corresponds to the two first characters of the file name.


    Search for the name of each file you want to get.
    Take note of the value of the corresponding contenthash tag.
    In the "files" folder you extracted, locate the file whose name is the same as the value of the contenthash and which will always be located in a folder whose name corresponds to the two first characters of the file name.


For example, let's assume there is a "backup_courses-120730.mbz" file of which the "files.xml" file and the "files" folder have been extracted. There is a PDF file named "Leadership.pdf" that is required for another purpose.
For example, let's assume there is a '''backup_courses-120730.mbz''' file of which the '''files.xml''' file and the '''files''' folder have been extracted. There is a PDF file named '''Leadership.pdf''' that is required for another purpose.


Open the files.xml file and:
Open the '''files.xml''' file and:


1. Search for the string "Leadership.pdf", which in this case is found under the following &lt;file id...&gt; group tag:
1. Search for the string '''Leadership.pdf''', which in this case is found under the following &lt;file id...&gt; group tag:


   &lt;file id="12345"&gt;
   &lt;file id="12345"&gt;
   &lt;contenthash&gt;fb6cf43a9b2d432403c70a2cb4c340dbb6225631&lt;/contenthash&gt;
   &lt;contenthash&gt;fb6cf43a9b2d432403c70a2cb4c340dbb6225631&lt;/contenthash&gt;
                 :
                
   &lt;filename&gt;Leadership.pdf&lt;/filename&gt;
   &lt;filename&gt;Leadership.pdf&lt;/filename&gt;
                 :
                
   &lt;license&gt;allrightsreserved&lt;/license&gt;
   &lt;license&gt;allrightsreserved&lt;/license&gt;
   &lt;sortorder&gt;1&lt;/sortorder&gt;
   &lt;sortorder&gt;1&lt;/sortorder&gt;
Line 245: Line 204:
2. Take note of the corresponding contenthash value: fb6cf43a9b2d432403c70a2cb4c340dbb6225631.
2. Take note of the corresponding contenthash value: fb6cf43a9b2d432403c70a2cb4c340dbb6225631.


3. As the first two characters of the contenthash are "fb", open the "fb" folder inside the "files" directory (which was previously extracted), and there is a file named "fb6cf43a9b...". Rename that file as "Leadership.pdf", and then move it to another location. Repeat this for all the files required, using the correct contenthash value of course.
3. As the first two characters of the contenthash are "fb", open the '''fb''' subfolder inside the '''files''' folder, and there is a file named '''fb6cf43a9b...'''. Rename that file as '''Leadership.pdf''' and move it to the desired location. Repeat this for all the files required, using the corresponding contenthash value each time.
 
==MySQL dmlwriteexception error when restoring a course==
 
If you obtain a  dmlwriteexception error when restoring a course, it is recommended that InnoDB tables are converted to the Barracuda file format. See the section 'Converting InnoDB tables to Barracuda' in [[Administration via command line]] for details of why this is recommended plus information on a tool for converting tables.
 
==What is the default format used in Moodle backup files?==
The default format in Moodle backups is [https://en.wikipedia.org/wiki/Gzip TGZ].
If you make a backup,
and examine the file with an HEX file viewer,
you can see that the file starts with #1F8B (gzip file marker).
 
But,  if you add the following line to your config.php file:
$CFG->usezipbackups = true;
and examine the file with an HEX file viewer,
you will see that the file starts with #504B0304 ([https://en.wikipedia.org/wiki/ZIP_(file_format) zip] file marker)
 
==Any further questions?==
 
Please post in the [http://moodle.org/mod/forum/view.php?f=128 Backup and restore forum] on moodle.org.
 
== See also ==
== See also ==


*Using Moodle [http://moodle.org/mod/forum/view.php?f=128 Backup and Restore forum]
*[http://www.databasejournal.com/features/mysql/article.php/10897_3300511_2 databasejournal.com article on repairing database corruption in MySQL]
* [[Site backup]]
* [[Site backup]]
* [[Moodle migration]]
* [[Moodle migration]]
* [[Beginning Moodle 2.0 Administration]]


Using Moodle forum discussions:
Moodle forum discussions:
*[http://moodle.org/mod/forum/discuss.php?d=142720 Trying to restore user 'admin' from backup file will cause conflict]
*[https://moodle.org/mod/forum/discuss.php?d=345466 Backing up and restoring course eliminates gradebook categories and items]
*[http://moodle.org/mod/forum/discuss.php?d=167471 Where is the Moodle 2.0 "Course Backup Filearea"?]


[[Category:FAQ]]
[[Category:FAQ]]


[[es:FAQ Backup]]
[[es:Respaldo y restauración FAQ]]
[[pl:Backup FAQ]]
[[pl:Backup FAQ]]
[[fr:FAQ de sauvegarde]]
[[fr:FAQ de sauvegarde]]
[[ja:バックアップFAQ]]
[[ja:バックアップFAQ]]
[[pt:FAQ sobre cópias de segurança]]
[[pt:FAQ sobre cópias de segurança]]
[[de:Sicherung und Wiederherstellung FAQ]]

Latest revision as of 21:44, 16 September 2023

How do I backup a course?

See Course backup and Automated backup setup.

How do I restore a course?

See Course restore.

How do I backup my site?

See Site backup.

What are the pros and cons of course versus site backups?

Site backups are recommended in order to have all data saved with the best confidence and the shortest recovery time.

For a site administrator, automated course backups are more expensive in terms of time, CPU usage and storage. The recovery time to have a site running again takes longer than a site backup. However, teachers and site administrators might find a course backups as a way to create a "fresh" copy of a course that can be re-used (in older versions of Moodle, in newer versions see Import course data) or as a method to distribute a course(s) to other Moodle sites.

What data is not contained in course backups?

By selecting all the options when setting up the backup you can include almost all the data in the course. However you should be aware of the fact that some things are not backed up:

  • Quiz questions are only backed up if at least one question from their category has been added to a quiz.
  • Scales are only backed up if they are used by at least one activity.
  • Users' passwords are not backed up when the "Include enrolled users" option is selected.
  • Glossary data
  • Badges - if they have not been awarded to at least one user and users are not included in the course backup.

How do I fix backups that lack the student log and participation data?

In Site administration > Courses > Backups > General backup defaults, there is a setting for "Include logs." By default, this is off.

If you enable this, then the logs from the user activities can be saved as the option "Include course logs" will now appear on the backup menu of items to include in the backup. These logs provide the data that the various reports such as Course participation, Logs, and Activity report, use to produce their reports.

How do I fix backups that lack the student grade history?

In Site administration > Courses > Backups > General backup defaults, there is a setting for "Include histories." By default, this is off.

If you enable this, then the logs from the user grade history and its changes made by teachers manually or by certain activities can be saved when performing a Backup. The option "Include grade history" will now appear on the backup menu of items to include in the backup.

What do the backup file names mean?

The default backup file name is composed of the following parts:

  • backup-moodle2-  :: This tells you that it is backup file of version 2 backup, which have been used since Moodle 2.0, and so it not a Moodle 1 backup file
  • course-##-  :: This tells you it is a course backup and the ## is the internal id number of the course, as seen in the course url
  • shortname-  :: Then follows the shortname of the course as set in the course settings
  • date-time-  :: This is the date and time in ISO format when the backup was made
  • nu-nf  :: optional suffixes: If the backup does not contain enrolled users, the -nu will be added; if the backup does not include files, the -nf will be added
  • .mbz  :: The file extension stands for "Moodle backup zip" and you can rename to .zip or .gzip (depending on your server OS) to expand it

Example: backup-moodle2-course-27-HISTORY101-20210124-0916-nu-nf.mbz

Deciphered: This is a backup file from Moodle 2 or above of course with id 27 with shortname HISTORY-101 made on Jan 24, 2021 at 09:16 AM with no enrolled users and no files included in it.

How can I backup or restore a very large course?

See Backup via CLI in Course backup and Restore via CLI in Course restore (new in 3.10 onwards).

The process ends with: "Error: An error occurred deleting old backup data". What should I do?

This part of the backup (or restore) procedure tries to delete old info, used in previous executions, performing the following tasks:

  1. Delete old records from "backup_ids" table: Check the table exists, repair it and try again.
  2. Delete old records from "backup_files" table: Check the table exists, repair it and try again.
  3. Delete old files from "moodledata/temp/backup": Delete the dir completely and try again.
Backup error message

For points 1 & 2, there are various ways of repairing tables, including using MySQL Admin.

For point 3 see below:

The error message states that the "directory not empty" and gives the path to that directory. If you go there with an FTP program you can see what is there and clean up. It could be just some empty subfolders that were leftover. Deleting these has been able to help. One can also delete the dir "moodledata/temp/backup" completely. That can take a bit longer but may solve several problems at once.

The process ends with: "XML error: not well-formed (invalid token) at line YYYY". What can I do?

This problem can appear at any point in the restore process. It's caused when the XML parser detects something incorrect in the backup file that prevent correct operation. Usually, it's caused by some "illegal" characters added in the original course due to some copy/paste of text containing them (control characters, or invalid sequences...).

The best method to handle this issue is:

  • Unzip the problematic backup file under one empty folder.
  • Open the moodle.xml with Firefox. It will show you where (exact char) the problem is happening.
  • Edit the moodle.xml file with some UTF8-compatible editor and delete such characters. Save changes.
  • Test the moodle.xml file again with Firefox until no error was displayed.
  • Zip everything again (all the folder contents but not the folder itself!).
  • Restore the course. It should work now.
  • Restore still not working? See the next question.

Also, if possible, it's highly recommended to solve those problems in the original course too from Moodle itself. Once "repaired" there, problems will be out if you create new backup files in the future.

I Still get an XML error. How can I clean the borked XML file?

In some cases XML backup files may contain characters causing the restore process to abort, even after the steps described in the previous question. In such cases you may want to try the following:

  • Unzip the problematic Moodle backup file under one empty folder. Moodle will create the course file folders as long as the unclean moodle.xml file. Please unzip using the Moodle unzip feature.
  • Rename the unclean moodle.xml file to moodle-unclean.xml.
  • If you don't have access to your Moodle server's command prompt, using the Moodle zip feature, zip the moodle-unclean.xml file only, download the zip file locally and unzip it. It is very important to download the xml file in zipped format to avoid unwanted character encoding when transferring from an operating system to another.
  • Move the downloaded Atlassian XML Cleaner Utility in the same folder where is your moodle-unclean.xml file.
  • Issue the following command from the command prompt:
java -jar atlassian-xml-cleaner-0.1.jar moodle-unclean.xml > moodle.xml
  • If you launched the utility on your local computer, zip the just created (and hopefully cleaned) moodle.xml file and upload it in the same place from where you downloaded the moodle-unclean.xml file. Once uploaded, unzip it using the Moodle unzip feature.
  • Zip everything again (all the folder contents but the folder itself!).
  • Restore the course. It should work now.

What does "Some of your courses weren't saved!!" mean?

There are three possible causes of this problem:

  1. Error - this happens when the backup procedure has found an error and so hasn't finished the backup of a particular course. These are "controlled" errors and the scheduled backup continues with the next course.
  2. Unfinished - this happens when the backup procedure dies without knowing why. When the cron is next executed it detects that the last execution went wrong, and continues skipping the problematic course. A possible solution would be to raise the PHP/Apache limit in your installation (memory, time of execution...). By taking a look to your log tables you should be able to see if the "crash" is happening at exact time intervals (usually a problem with the max_execution_time php's variable), or if there is some exact point were all the courses are breaking.
  3. Skipped - this happens when a course is unavailable to students and has not been changed in the last month (31 days). This isn't an error situation - it's a feature, especially useful for sites with many unavailable old courses, saving process time.

Why are some courses being skipped?

AutoBackup skip settings

Moodle's Course backups routines are instructed to automatically skip courses based on three settings in Administration > Site administration > Courses > Backups > Automated backup setup. The Moodle administrator(s) use those settings to specify whether to Skip hidden courses (set by default to 'Yes'), Skip courses not modified since (set by default to '30 days'), and Skip courses not modified since previous backup (set by default to 'No'). A course which meets any of the enabled criteria will be skipped during the next run of Course backups.

Why does restore stop, rather than completing?

Attempting to restore a course to an older version of Moodle than the one the course was backed up on can result in the restore process failing to complete. To ensure a successful restore, make sure that the version of Moodle you are restoring the course to is the same, or newer, than the one the course was backed up on.

If it stop unexpectedly with no errors shown try again with Debugging switched on. Any errors you now see can help experts in the support forums diagnose your problem. You can also check the discussion links in the See also section below for further advice.

Restore stops with the message "Trying to restore user xxxx from backup file will cause conflict"

This message is displayed when:

  1. The target site has a user xxxx (xxxx being the username) - often the admin user
  2. The backup archive being restored also contains a user xxxx (same username)
  3. After various comparisons, Moodle has determined that the target site user xxxx and the backup user xxxx aren't the same person, for example: if these users have different email addresses.


If 1, 2 and 3 are all true, the restore process stops in order to prevent the backup user xxxx's activities (forum posts, quiz attempts, assignment uploads, etc.) from being associated with the target site user xxxx.

Here are the possible methods to make the xxxx users match and resolve the conflict:

  1. Modify the backup archive's users.xml file and make the email or firstaccess fields match the ones in target site. Note that the backup-<...>.mbz is a tarball and can be extracted by creating a temporary folder and running tar -xzf /PATH/TO/backup-<...>.mbz. When editing is complete recompress the file with tar -czf /PATH/TO/backup-<...>.mbz *.
  2. Modify the target site and set the user email or firstaccess fields to match the ones in users.xml.
  3. For admin user conflicts only: enable the setting 'Allow admin conflict resolution' in Site administration > Courses > Backups > General import defaults. This will result in the username in the backup file being renamed to 'admin_xyz'.

Restored users lose their passwords - How can they reset them?

When a course is restored with enroled users included, any new users not already in the system will have new accounts created for them. Backups with enroled users do not include the user passwords. Instead, a password of "restored" is placed in the database for such users. When the user attempts to log into the new site, Moodle will recognise they were restored from a course backup and give the user the following message:

Restored Account. 
This account was imported from another server and the password has been lost. To set a new password by email, please click "Continue"

When the user clicks the "Continue" button, they will then be sent a change password email to the email address associated with the restored account, just as if they had used the normal "Forgotten password" process. This will allow them to set a new password.

If you are the administrator and wish to avoid users getting such emails, remember that you can use the Upload users tool to bulk set new passwords.

Why are certain course links broken in a restored course?

Inter-activity links must be absolute (full) URLs e.g. http://site.com/mod/resource/view.php?id=xxx in order to be processed properly during backup and restore.

Any relative URLs e.g. /mod/resource/view.php?id=xxx, ../resource/view.php?id=xxx or view.php?id=xxx will result in broken links when the course is restored.

Restoring a course results in broken HTML tags. What can I do?

This has been known to be caused by older versions of libxml2 and PHP - try updating them to the latest versions.

How can I extract original files from a Moodle backup file?

If you really want to get original files from the backup file (an .mbz file) you downloaded (from the course's restore page), you can do so in much the same way as is suggested above.

The backup file can be opened with the command tar -xzf /PATH/TO/backup-<...>.mbz. Create a temporary folder to extract the backup's files into.

Next step would be to open the files.xml file in a text editor, and:

  1. Search for the name of each file you want to get.
  2. Take note of the value of the corresponding contenthash tag.
  3. In the files folder you extracted, locate the file whose name is the same as the value of the contenthash and which will be located in a folder whose name corresponds to the two first characters of the file name.


For example, let's assume there is a backup_courses-120730.mbz file of which the files.xml file and the files folder have been extracted. There is a PDF file named Leadership.pdf that is required for another purpose.

Open the files.xml file and:

1. Search for the string Leadership.pdf, which in this case is found under the following <file id...> group tag:

 <file id="12345">
 <contenthash>fb6cf43a9b2d432403c70a2cb4c340dbb6225631</contenthash>
               ⋮
 <filename>Leadership.pdf</filename>
               ⋮
 <license>allrightsreserved</license>
 <sortorder>1</sortorder>
 </file>

2. Take note of the corresponding contenthash value: fb6cf43a9b2d432403c70a2cb4c340dbb6225631.

3. As the first two characters of the contenthash are "fb", open the fb subfolder inside the files folder, and there is a file named fb6cf43a9b.... Rename that file as Leadership.pdf and move it to the desired location. Repeat this for all the files required, using the corresponding contenthash value each time.

MySQL dmlwriteexception error when restoring a course

If you obtain a dmlwriteexception error when restoring a course, it is recommended that InnoDB tables are converted to the Barracuda file format. See the section 'Converting InnoDB tables to Barracuda' in Administration via command line for details of why this is recommended plus information on a tool for converting tables.

What is the default format used in Moodle backup files?

The default format in Moodle backups is TGZ. If you make a backup, and examine the file with an HEX file viewer, you can see that the file starts with #1F8B (gzip file marker).

But, if you add the following line to your config.php file:

$CFG->usezipbackups = true;

and examine the file with an HEX file viewer, you will see that the file starts with #504B0304 (zip file marker)

Any further questions?

Please post in the Backup and restore forum on moodle.org.

See also

Moodle forum discussions: