Руководство:Резервное копирование вики
Важно регулярно делать резервные копии данных в вашей Вики. В этом разделе описывается обзор процесса резервного копирования для типичной Вики на движке MediaWiki. Возможно, вы захотите разработать свой собственный скрипт резервного копирования или график резервного копирования в зависимости от размеров вашей Вики и ваших индивидуальных потребностей.
Contents
Обзор
MediaWiki хранит важные данные в двух местах:
База данных страницы и их содержимое, пользователи и их настройки, метаданные, индекс поиска и другое Файловая система файлы конфигурации, файлы тем, расширения, изображения (включая удаленные изображения) и другое
Необходимо перевести MediaWiki в режим read-only прежде, чем создавать резервную копию — смотри раздел $wgReadOnly . Это будет гарантией того, что все части вашей резервной копии непротиворечивы (некоторые из установленных дополнений могут записывать данные в базу).
Передача файловВам нужно выбрать способ для передачи файлов с сервера, где они находятся:
- Неконфиденциальные данные вы можете просто опубликовать на archive.org или в каталог dumps/ вашего веб-сервера.
- SCP (или WinSCP), SFTP/FTP или любой другой протокол передачи, который вы привыкли использовать.
- Хостинг компания может предоставлять интерфейс файлового менеджера при помощи веб-браузера; свяжитесь с вашим провайдером.
База данных
Большинство критических данных Вики хранятся в базе данных, которая обычно проста для резервного копирования. При использовании MySQL-бэкэнда по-умолчанию, база данных может быть задамплена в скрипт файл, который может быть использован позже, чтобы восстановить базу данных и все данные в ней с нуля.
MySQL AutomysqlbackupСмотри пакет в Debian:
Все ваши базы данных будут сохранены в /var/lib/automysqlbackup/
Резервное копирование вручную:
Восстановление базы данных:
Другие версии смотри на SourceForge.
Получение Mysqldump из командной строкиНаиболее удобный способ для создания файла дампа базы данных — это использовать стандартный инструмент mysqldump. Оно является приложением командной строки. Убедитесь, что используете правильные параметры, в противном случае могут возникнуть трудности при восстановлении базы данных. В зависимости от размера базы данных, создание дампа может занять значительное количество времени.
Сначала вставьте следующую строку в LocalSettings.php
это можно удалить после того, как только создание дампа будет завершено.
Пример команды для запуска на Linux/Unix оболочке:
Substituting hostname , userid , whatever , and dbname as appropriate. All four may be found in your LocalSettings.php (LSP) file. hostname may be found under $wgDBserver ; by default it is localhost. userid may be found under $wgDBuser , whatever may be found under $wgDBTableOptions , where it is listed after DEFAULT CHARSET= . If whatever is not specified mysqldump will likely use the default of utf8, or if using an older version of MySQL, latin1. While dbname may be found under $wgDBname . After running this line from the command line mysqldump will prompt for the server password (which may be found under Manual:$wgDBpassword in LSP).
Смотри страницу mysqldump для того, чтобы узнать все параметры командной строки.
На выходе можно сразу создать архив Wikipedia:ru:gzip, чтобы уменьшить размер
Some newer versions of MySQL might show an error about tablespaces and PROCESS privilege. MediaWiki does not use tablespaces. The solution is to add the --no-tablespaces option to the command:
Похожая команда может быть использована для создания XML файла, если добавить параметр --xml .
и сжать файл используя gzip
Необходимо помнить, что некоторые системные компоненты в виде файлов необходимы всегда, например, изображения, лого и расширения.
Запуск mysqldump при помощи CronCron — классический демон выполнения заданий в unix-подобных ОС. Cron позволяет пользователям создавать задания (на выполнение команд или скриптов), которые нужно выполнять в определённое время или даты.
Пример команды которую вы можете запустить через crontab выглядит так:
nice -n 19 понижает приоритет процесса.
Установите правильные значения для переменных $USER , $PASSWORD , $DATABASE . Будет создан файл ежедневной копии базы данных. Если вы сохраняете файлы и расширения таким образом то вы можете использовать метод предложенный на другой странице.
Внимание: Не используйте для резервного копирования mysqlhotcopy. Табличный формат, используемый MediaWiki не может быть скопирован этой программой, поэтому она сломает резервную копию!
Если Вы хотите добавить задание сохранения базы в планировщик Cron через Cpanel, то вы должны экранировать символ «%»
В противном случае, Вы получите ошибку:
ТаблицыНекоторые выгружаемые столы имеют разную степень временности. Таким образом, для экономии места на диске (помимо gziping), хотя эти таблицы должны присутствовать в правильном дампе, их данные нет. Однако при определенных обстоятельствах недостаток необходимости перестраивать все эти данные может перевесить экономию дискового пространства (например, на большой вики, где скорость восстановления имеет первостепенное значение).
Обратитесь в список рассылки — раздел «mysql5 binary schema» по данному вопросу.
Преобразование кодировки Latin-1 в UTF-8Смотри раздел страницы обновления для того, чтобы узнать, как это делается. Также смотри страницу обсуждения для того, чтобы узнать, как работать с кодировками в целом.
PostgreSQLВы можете использовать утилиту pg_dump для резервного копирования MediaWiki на PostgreSQL. Например:
скопирует базу mywiki в файл mywikdump.sql.
Чтобы восстановиться из копии:
Вы можете также скопировать глобальную информацию, например, пользователей базы:
SQLiteIf your wiki is currently offline, its database can be backed up by simply copying the database file. Otherwise, you should use a maintenance script: php maintenance/SqliteMaintenance.php --backup-to <backup file name> , which will make sure that operation is atomic and there are no inconsistencies. If your database is not really huge and server is not under heavy load, users editing the wiki will notice nothing but a short lag. Users who are just reading will not notice anything in any case.
phpMyAdminЧтобы перевести вики в режим read-only, необходимо добавить строчку $wgReadOnly = 'Сайт недоступен'; в файл LocalSettings.php.
Open the browser to your phpadmin link, login, choose the wiki database. (Check LocalSettings.php if you're not sure). Select Export. Make sure all items under Export are highlighted, and make sure Structure is highlighted (it's important to maintain the table structure). Optionally check Add DROP TABLE to delete existing references when importing. Make sure Data is checked. Select zipped. Then click on GO and save the backup file. [1] Необходимо удалить строку с $wgReadOnly из файла LocalSettings.php
Необходимо помнить, что некоторые системные компоненты в виде файлов необходимы всегда, например, изображения, лого и расширения.
Внешние ссылки- В качестве учебного пособия можно посмотреть MySQL Backup/Restore Tutorial
HeidiSQL — похожая на phpMyAdmin, но менее строгая версия бесплатного phpMyAdmin. HeidiSQL requires a direct database connection, where some hosts may only offer web interfaces (phpMyAdmin) to firewalled databases.
Файловая система
MediaWiki хранит другие компоненты Вики в виде файлов, что более удобно, чем вставка в базу данных. Например, конфигурационные файлы ($1, $2), файлы изображений (включая удалённые, иконки и отрендеренные SVG файлы), изменённые темы, файлы расширений и так далее. The most important of these are LocalSettings.php and uploaded files in the images/ directory (including deleted files, thumbnails, and rendered math and SVG images, if applicable).
Лучшим методом хранения таких файлов — архивы типа tar , которые могут быть сжаты. Для Windows можно использовать такие утилиты, как WinZip или 7-Zip.
Варианты для Linux, если вики хранится в директории /srv/www/htdocs/wiki
Должна быть резервная копия всей папки wiki в директории htdocs, если используется XAMPP.
Configuration filesLocalSettings.php is the most important of these, but a wiki might also have things like .htaccess or other web server configuration files that should be backed up.
Uploaded filesFiles uploaded to the wiki are by default put into the images/ directory, separated into subdirectories such as images/8/8f . There are also other directories such as images/archive/ and images/deleted/ . These should all be backed up.
The images/thumb/ can be backed up along with everything else, but can optionally be excluded in order to save backup space. This directory stores the derived thumbnails of images and other files; generally multiple thumbnails per wiki file. After restoring from backup, these thumbnails will be recreated as required (although depending on $wgGenerateThumbnailOnParse this may need to be a manual process).
Резервная копия содержимого вики (XML dump)
Для дополнения дампа базы данных рекомендуется выполнять XML дапм. В XML дамп входит содержимое wiki-страниц и всех их ревизий (информация о логинаx пользователей, журналы, метаданные изображений в xml дампе не хранятся).
XML dumps are less likely to cause problems with character encoding, as a means of transferring large amounts of content quickly, and can easily be used by third party tools, which makes XML dumps a good fallback should your main database dump become unusable.
Чтобы создать дамп XML, используйте инструмент командной строки dumpBackup.php , расположенный в каталоге maintenance вашей установки MediaWiki. См. Manual:dumpBackup.php для более детальной информации.
Вы также можете создать дамп XML для определенного набора страниц в Интернете, используя Special:Export, хотя попытка выгрузить большое количество страниц через этот интерфейс обычно приводит к тайм-ауту.
Для импорта XML-дампа в wiki используйте инструмент коммандной строки importDump.php . для небольшого набора данных вы можете использовать Special:Import через браузер (по умолчанию эта функция доступна только sysop группе).
Without shell access to the serverIf you have no shell access, use the WikiTeam Python script dumpgenerator.py from a DOS, Unix or Linux command-line. Requires Python v2 (a third-party Python 3.x port has been created, and works with a patch).
To get an XML, with edit histories, dump and a dump of all images plus their descriptions. Without extensions and LocalSettings.php configs.
On MediaWiki 1.27+ you can use --xml --xmlrevisions , which should be faster.