| |
Поскольку таблицы MySQL сохранены как файлы, просто делайте копию. Чтобы
получать непротиворечивую копию, скомандуйте LOCK TABLES
на
релевантных таблицах и дополните это командой FLUSH TABLES
для
них, дабы все данные были гарантированно сброшены на диск. Вам нужна только
блокировка записи. Это позволяет другим потокам продолжать делать запросы к
таблицам в то время, как Вы делаете копию файлов в каталоге баз данных.
Команда FLUSH TABLE
необходима, чтобы гарантировать, что все
активные индексные страницы записаны на диск прежде, чем Вы
запускаете процесс копирования.
Если Вы хотите делать копию уровня SQL из таблицы, Вы можете использовать
SELECT INTO OUTFILE
или BACKUP TABLE
. Подробности в
разделе "4.4.2 Синтаксис BACKUP
TABLE
".
Другой способ поддержать базу данных состоит в том, чтобы использовать
программу mysqldump
или скрипт mysqlhotcopy
.
Подробности в разделах
"4.8.5 mysqldump, Дамп структур таблиц и
данных" и "4.8.6 mysqlhotcopy,
Копирование баз данных и таблиц MySQL".
shell> mysqldump --tab=/path/to/some/dir --opt --fullили
shell> mysqlhotcopy database /path/to/some/dirВы можете также просто копировать все файлы таблицы (*.frm, *.MYD и *.MYI), пока сервер что-нибудь не модифицирует. Скрипт
mysqlhotcopy
использует этот метод.
mysqld
запущен, остановите его, а
затем запустите с опцией --log-update[=file_name]
. Подробнее об
этой опции можно узнать в разделе "4.9.3
Файл регистрации модификаций". Файлы протоколов предоставляют Вам
информацию относительно того, что изменилось со времени
последнего вызова mysqldump
.Если Вы должны восстановить что-либо, попробуйте восстанавливать Ваши
таблицы, используя REPAIR TABLE
или myisamchk -r
.
Это эффективно в 99.9% случаев. Если myisamchk
ничего хорошего
не сделал, попробуйте следующую процедуру (это будет работать только, если Вы
запустили MySQL с опцией --log-update
):
mysqldump
.
shell> mysqlbinlog hostname-bin.[0-9]* | mysqlЕсли Вы используете файл регистрации модификации, Вы можете использовать:
shell> ls -1 -t -r hostname.[0-9]* | xargs cat | mysql
ls
используется, чтобы получить все журналы модификации в
правильном порядке.
Вы можете также делать выборочные копии: SELECT * INTO OUTFILE
'file_name' FROM tbl_name
и восстанавливать их: LOAD DATA INFILE
'file_name' REPLACE ...
. Чтобы избежать двойных записей, Вам нужен
PRIMARY KEY
или UNIQUE
в таблице. Ключевое слово
REPLACE
заменяет старые записи на новые, когда новая запись
дублирует старую запись на уникальном значении ключа.
Если Вы получаете проблемы эффективности при создании копий на Вашей системе, можно решить их установкой репликации и созданием копий на подчиненной системе вместо главной. Подробности есть в разделе 4.10.1 Введение в репликацию.
Если Вы используете файловую систему Veritas, Вы можете делать следующее:
FLUSH TABLES WITH READ LOCK
mount vxfs
snapshot
.
UNLOCK TABLES
BACKUP TABLE
BACKUP TABLE tbl_name[,tbl_name...] TO '/path/to/backup/directory'
Эта команда делает копию всех файлов таблицы в резервный каталог, что
является минимумом, необходимым, чтобы восстановить ее. Сейчас это работает
только для таблиц MyISAM
. Для них копируются файлы
.frm
(определение) и .MYD
(данные). Индексный файл
может быть восстановлен из этих двух.
Перед использованием этой команды, пожалуйста, ознакомьтесь с разделом "4.4.1 Резервирование баз данных".
Пока таблица резервируется, она блокируется. Если нужно резервировать
сразу несколько таблиц, выполните команду LOCK TABLES
для каждой
таблицы в этой группе.
Команда возвращает таблицу со следующими столбцами:
Столбец | Значение |
Table | Имя таблицы |
Op | Обязательно ``backup'' |
Msg_type | Одно из status , error ,
info или warning . |
Msg_text | Собственно сообщение. |
Обратите внимание, что команда BACKUP TABLE
доступна только в
MySQL версии 3.23.25 и старше.
RESTORE TABLE
RESTORE TABLE tbl_name[,tbl_name...] FROM '/path/to/backup/directory'
Восстанавливает таблицу из копии, которая была сделана с помощью
BACKUP TABLE
. Существующие таблицы не будут перезаписаны, если
Вы попробуете восстанавливать существующую таблицу, получите ошибку.
Восстановление занимает больше времени, чем резервирование из-за
необходимости сгенерировать индексный файл. Чем больше имеется ключей, тем
дольше система будет его строить. Также, как и BACKUP TABLE
, эта
функция работает только с таблицами MyISAM
.
Команда возвращает таблицу со следующими столбцами:
Столбец | Значение |
Table | Имя таблицы |
Op | Обязательно ``restore'' |
Msg_type | Одно из status , error ,
info или warning . |
Msg_text | Собственно сообщение. |
CHECK TABLE
CHECK TABLE tbl_name[,tbl_name...] [option [option...]] option = QUICK | FAST | MEDIUM | EXTENDED | CHANGED
CHECK TABLE
работает только с таблицами типа
MyISAM
. На них данная команда эквивалентна
myisamchk -m table_name
.
Если Вы не определяете опций, используется MEDIUM
.
Данная команда проверяет таблицу на ошибки. Для таблиц типа
MyISAM
модифицируется статистика ключа. Команда возвращает
таблицу со следующими столбцами:
Столбец | Значение |
Table | Имя таблицы. |
Op | Обязательно ``check''. |
Msg_type | Одно из status , error ,
info или warning . |
Msg_text | Собственно сообщение. |
Обратите внимание, что Вы можете получать много строк информации для
каждой проверенной таблицы. Последняя строка будет иметь тип Msg_type
status
и значение OK
, если все хорошо. Если ответов
OK
или Not checked
нет, Вы должны выполнить ремонт
таблицы. Подробности в разделе "
4.4.6 Использование myisamchk
для устранения повреждений".
Сообщение Not checked
говорит о том, что для данной таблицы
TYPE
сообщил MySQL, что там не было никакой потребности
проверять таблицу.
Различные типы проверки:
Тип | Значение |
QUICK | Не просматривать строки, чтобы проверить неправильные связи. |
FAST | Проверить только те таблицы, которые не были закрыты правильно. |
CHANGED | Проверить только те таблицы, которые не были закрыты правильно, и те, которые изменились со времен последней проверки. |
MEDIUM | Сканировать строки для проверки правильности удаленных связей. Это также вычисляет контрольную сумму ключа для строк и проверяет ее правильность. |
EXTENDED | Выполнить полную проверку всех ключей для всех строк в таблице. Это гарантирует, что таблица на 100% непротиворечива, но требует много времени! |
Для динамических таблиц MyISAM
запущенная проверка будет
всегда использовать опцию MEDIUM
. Для статических строк не
выполняется просмотр строки для режимов QUICK
и
FAST
, поскольку строки очень редко разрушаются.
Вы можете объединять параметры проверки:
CHECK TABLE test_table FAST QUICK;
Это предписывает провести быструю проверку на таблице, если она не была закрыта правильно.
ОБРАТИТЕ ВНИМАНИЕ: в ряде случаев
CHECK TABLE
изменяет таблицу! Это случается, если таблица
отмечена как 'corrupted' (повреждена) или 'not closed properly' (не закрыта
правильно), но команда CHECK TABLE
не нашла проблем в таблице. В
этой ситуации CHECK TABLE
отметит таблицу как ok.
Если таблица разрушена, то наиболее вероятное, что проблема находится в индексах, а не в части данных. Все приведенные выше типы проверки тестируют индексы и должны таким образом найти большинство ошибок.
Если Вы хотите только проверить таблицу, Вы не должны использовать никакие
параметры проверки или опцию QUICK
. Последний должен
использоваться, когда Вы спешите и можете позволить пропустить то малое число
ошибок, которое QUICK
не находит. Например, это ошибка в файле
данных. В большинстве случаев MySQL, при нормальном использовании, должен сам
найти любую ошибку в файле данных. Если это случается, таблица будет отмечена
как 'разрушено', тогда таблица не сможет использоваться, пока ошибка не
восстановлена, чтобы не развалить данные окончательно.
FAST
и CHANGED
обычно предназначены, чтобы
использоваться из скрипта (например, из cron), если Вы хотите проверять
таблицу время от времени. В большинстве случаев FAST
имеет
приоритет перед CHANGED
.
EXTENDED
должен использоваться после того, как Вы выполнили
нормальную проверку, но все еще получаете странные ошибки из таблицы, когда
MySQL пробует модифицировать строку или найти строку по ключу (это ОЧЕНЬ
маловероятно, если нормальная проверка прошла спокойно!).
Некоторые вещи, сообщаемые проверкой таблиц, не могут быть исправлены в автоматическом режиме:
Найденная строка, где столбец auto_increment имеет значение 0
. Это означает, что Вы имеете в таблице строку, где столбец индекса
auto_increment
содержит значение 0. Можно создать такую
конструкцию командой UPDATE
.
Это не ошибка само по себе, но может вызывать проблему, если Вы сбрасываете
таблицу в дамп, а потом восстановите ее оттуда или скомандуете
ALTER TABLE
на таблице. В этом случае столбец auto_increment
изменит значение, согласно правилам auto_increment, что может вызвать
проблемы подобно ошибке дублирования ключа.
Избавиться от предупреждения можно, только выполнив инструкцию
UPDATE
, чтобы установить столбец к некоторому другому значению
(не 0).REPAIR TABLE
REPAIR TABLE tbl_name[,tbl_name...] [QUICK] [EXTENDED]
REPAIR TABLE
тоже работает только на таблицах типа
MyISAM
и аналогичен вызову myisamchk -r table_name
.
Обычно Вам никогда не придется выполнять эту команду, но в случае ошибок
Вы, очень вероятно, вернете все Ваши данные из таблицы MyISAM с помощью
команды REPAIR TABLE
. Если Ваши таблицы разрушаются, Вы должны
попробовать нахйти причину этого! Подробности по этому вопросу есть в разделе
"8.4.1 Что делать, если MySQL рухнул".
REPAIR TABLE
восстанавливает разрушенную таблицу. Команда
возвращает таблицу со следующими столбцами:
Столбец | Значение |
Table | Имя таблицы |
Op | Обязательно ``repair'' |
Msg_type | Одно из status , error ,
info или warning . |
Msg_text | Собственно сообщение. |
Обратите внимание, что Вы можете получать много строк информации для
каждой восстановленной таблицы. Последняя будет иметь тип Msg_type
status
и значение OK
, если все в порядке. Если значение
OK
так и не появилось, Вы должны попробовать восстанавливать
таблицу с помощью myisamchk -o
, поскольку REPAIR
TABLE
еще не выполняет все параметры myisamchk
. В
ближайшем будущем планируется сделать ее более гибкой.
Если задан QUICK
, MySQL пробует делать REPAIR
только для индексного дерева.
Если Вы используете EXTENDED
, MySQL создаст индекс по строкам
вместо того, чтобы создать индекс одновременно с сортировкой: это может быть
лучше, чем сортировка по ключам фиксированной длины, если Вы имеете длинные
ключи типа char()
, которые сжимаются очень хорошо.
myisamchk
для устранения поврежденийНачиная с MySQL 3.23.13, можно проверять таблицы MyISAM
командой CHECK TABLE
. Подробности в разделе
"4.4.4 Синтаксис CHECK TABLE
". Ремонтировать таблицы можно командой REPAIR TABLE
. Она
подробно рассмотрена в разделе "4.4.5
Синтаксис REPAIR TABLE
".
Для проверки и ремонта таблиц MyISAM (файлы с расширениями
.MYI
и .MYD
) можно использовать утилиту
myisamchk
. Для проверки и ремонта таблиц ISAM
(файлы с расширениями .ISM
и .ISD
) следует
пользоваться утилитой isamchk
. Подробности в разделе
"7 Типы таблиц MySQL".
Далее обсуждается myisamchk
, но вся информация также
применима к старой программе isamchk
.
Вы можете использовать myisamchk
, чтобы получать информацию
относительно ваших таблиц базы данных, проверять их, ремонтировать или
оптимизировать. Следующие разделы описывают, как вызвать
myisamchk
(включая описание опций), как установить план
сопровождения таблицы, и как использовать myisamchk
, чтобы
выполнить различные функции.
Вы в большинстве случаев можете также использовать команду OPTIMIZE
TABLES
, чтобы оптимизировать и ремонтировать таблицы, но это не так
быстро и надежно (в случае реальных фатальных ошибок) как
myisamchk
. С другой стороны, OPTIMIZE TABLE
проще.
Подробности в разделе "4.5.1 Синтаксис
OPTIMIZE TABLE
".
myisamchk
myisamchk
вызывается в общем виде так:
shell> myisamchk [options] tbl_name
Здесь options
указывает требуемые действия. Они описаны ниже
(Вы также можете получить список параметров вызовом
myisamchk --help
). Без параметров myisamchk
просто
проверяет таблицу. Чтобы получить большее количество информации или сообщить,
чтобы myisamchk
занимался корректировкой информации, определите
параметры так, как описано ниже в следующих разделах.
tbl_name
таблица базы данных, которую Вы хотите проверять.
Если Вы выполняете myisamchk
не в каталоге баз данных, Вы должны
определить путь к файлу, потому что myisamchk
понятия не имеет,
где размещена база данных. Фактически myisamchk
не заботит,
размещены или нет файлы, на которых Вы работаете, в каталоге баз данных: Вы
можете копировать файлы, которые соответствуют таблице базы данных, в другое
место и выполнять операции восстановления на них там.
Вы можете называть несколько таблиц в командной строке
myisamchk
. Вы можете также указать имя индексного файла (с
суффиксом .MYI), что позволяет Вам определять все таблицы в
каталоге, используя образец *.MYI. Например, если Вы находитесь в
каталоге баз данных, Вы можете проверять все таблицы в каталоге так:
shell> myisamchk *.MYI
Если Вы не в каталоге баз данных, Вы можете проверять все таблицы там, определяя путь к каталогу таким образом:
shell> myisamchk /path/to/database_dir/*.MYI
Вы можете даже проверять все таблицы во всех базах данных, определяя подстановочные знаки в пути к каталогу данных MySQL:
shell> myisamchk /path/to/datadir/*/*.MYI
Для быстрой проверки всех таблиц рекомендуется такой способ:
myisamchk --silent --fast /path/to/datadir/*/*.MYI isamchk --silent /path/to/datadir/*/*.ISM
Если нужно проверить все таблицы и восстановить те из них, которые имеют повреждения, скомандуйте:
myisamchk --silent --force --fast --update-state -O key_buffer=64M \ -O sort_buffer=64M -O read_buffer=1M \ -O write_buffer=1M /path/to/datadir/*/*.MYI isamchk --silent --force -O key_buffer=64M -O sort_buffer=64M \ -O read_buffer=1M -O write_buffer=1M /path/to/datadir/*/*.ISM
Здесь считается, что Вы имеете больше, чем 64 М свободного места.
Обратите внимание, что, если Вы получаете ошибку подобную:
myisamchk: warning: 1 clients is using or hasn't closed the table properly
Это означает, что Вы пробуете проверять таблицу, которая модифицируется
другой программой (подобно серверу mysqld
), которая не закрыла
файл или не может закрыть файл правильно.
Если запущен mysqld
, следует принудительно закрыть и сбросить
на диск все таблицы командой FLUSH TABLES
и гарантировать, что
никто не использует таблицы в то время, как Вы выполняете
myisamchk
. В MySQL Version 3.23 самый простой способ избежать
этой проблемы состоит в том, чтобы использовать CHECK TABLE
вместо myisamchk
, чтобы проверить таблицы.
myisamchk
Утилита myisamchk
поддерживает опции:
-# или --debug=debug_options
debug_options
обычно
является строкой в формате d:t:o,filename
.
-? или --help
-O var=option, --set-variable var=option
myisamchk --help
.
key_buffer_size | 523264 |
read_buffer_size | 262136 |
write_buffer_size | 262136 |
sort_buffer_size | 2097144 |
sort_key_blocks | 16 |
decode_bits | 9 |
key_buffer_size
используется только при проверке таблицы с
опцией --extended-check
или восстановлении с опцией
-o
. sort_buffer_size
используется при
восстановлении таблицы с опцией --recover
.
Если Вы хотите ускорить восстановление, установите вышеупомянутые переменные в 1/4 доступной памяти. Вы можете устанавливать обе переменные в большие значения, так как только один из вышеупомянутых буферов будет использоваться в каждый момент времени. Восстановление через буфер ключей используется в следующих случаях:
--safe-recover
.
CHAR
, VARCHAR
или
TEXT
, поскольку алгоритм сортировки должен сохранять целые ключи
в течение сортировки. Если Вы имеете много свободного места, можно применить
опцию --sort-recover
.-s или --silent
-ss
.
-v или --verbose
-vv
или
-vvv
). Удобно использовать вместе с опциями -d
и
-e
.
-V или --version
myisamchk
.
-w или --wait
mysqld
на таблице с параметром
--skip-locking
, таблица может быть блокирована только другой
командой myisamchk
.myisamchk
-c или --check
myisamchk
никаких параметров, которые ее отменят.
-e или --extended-check
myisamchk
или
myisamchk --medium-check
может выяснить, имеются ли ошибки в
таблице, так что обычно таких крайностей не требуется.
Если Вы используете --extended-check
на машине с большим объемом
памяти, можно увеличить значение key_buffer_size
.
-F или --fast
-C или --check-only-changed
-f или --force
myisamchk
с параметром -r
на
таблице, если myisamchk
находит любые ошибки в таблице.
-i или --information
-m или --medium-check
-U или --update-state
--check-only-changed
, но Вы не должны использовать это,
если mysqld
использует таблицу и запущен с параметром
--skip-locking
.
-T или --read-only
myisamchk
, чтобы проверить таблицу, которая находится в
использовании некоторой другой прикладной программой, которая не использует
блокировку (подобно mysqld --skip-locking
).Следующие параметры используются, если Вы запускаете
myisamchk
с опцией -r
или -o
:
-D # или --data-file-length=#
-e или --extend-check
-f или --force
table_name.TMD
)
вместо прерывания выполнения.
-k # или keys-used=#
#
индексов. Если Вы используете
MyISAM
, сообщает, какие ключи использовать, здесь каждый бит
соответствует ключу (первый ключ в бите 0). Это может использоваться, чтобы
получить ускорение вставки. Дезактивированные индексы могут быть повторно
активизированы, используя myisamchk -r
.
-l или --no-symlinks
myisamchk
восстанавливает таблицу, на которую указывают ссылки.
-r или --recover
-o
. Обратите
внимание, что в том маловероятном случае, когда -r
не может
помочь, файл данных все еще цел). Если Вы имеете много памяти, увеличьте
sort_buffer_size
!
-o или --safe-recover
-r
, но может обрабатывать ряд очень
маловероятных случаев, которые -r
не по зубам. Этот метод
восстановления также использует намного меньше дискового пространства, чем
-r
. Обычно нужно всегда сначала попробовать -r
и
только, если эта попытка провалилась, использовать -o
. Если Вы
имеете много памяти, увеличьте key_buffer_size
!
-n или --sort-recover
--character-sets-dir=...
--set-character-set=name
-t или --tmpdir=path
myisamchk
использует системную переменную TMPDIR
.
-q или --quick
-q
, чтобы myisamchk
изменял первоначальный
файл данных в случае двойных ключей.
-u или --unpack
myisamchk
Другие действия, которые myisamchk
может делать, помимо
ремонта и проверки таблиц:
-a или --analyze
-d или --description
-A или --set-auto-increment[=value]
-S или --sort-index
-R или --sort-records=#
SELECT
и ORDER BY
на этом индексе. Правда,
первая сортировка ОЧЕНЬ медленная. Чтобы узнать индексные числа таблицы,
используйте SHOW INDEX
, эта команда показывает индексы таблицы в
том порядке, в каком их видит myisamchk
. Индексы пронумерованы,
начиная с 1, а не с 0.myisamchk
Распределение памяти важно, когда Вы выполняете myisamchk
.
myisamchk
использует не больше памяти, чем ему разрешено
параметром -O
. Если Вы собираетесь использовать
myisamchk
на очень больших файлах, Вы должны сначала решить,
сколько памяти Вы можете ему выделить (лучше по максимуму). Значение по
умолчанию составляет около 3 мегабайт для исправления ошибок. Используя
большие значения, Вы можете ускорить работу myisamchk
. Например,
если Вы имеете больше, чем 32M RAM, Вы могли бы использовать параметры типа
этих (в дополнение к любым другим параметрам, которые Вы определили):
shell> myisamchk -O sort=16M -O key=16M -O read=1M -O write=1M ...
Использование -O sort=16M
достаточно для большинства случаев.
Знайте, что myisamchk
использует временные файлы в
TMPDIR
. Если TMPDIR
указывает на файловую систему
памяти, Вы можете легко получить ошибку переполнения памяти. Если это
случается, установите TMPDIR
так, чтобы указать на какой-то
каталог с достаточным количеством свободного места, и перезапустите
myisamchk
.
При ремонте myisamchk
также требует много свободного места:
--quick
, так как в этом
случае будет изменен только индексный файл. Это место необходимо выделить на
том диске, где находится первоначальный файл записи!
--recover
или --sort-recover
(но не при использовании --safe-recover
!) понадобиться место для
буфера сортировки. Объем вычисляется по формуле:
(largest_key+row_pointer_length)*number_of_rows*2
. Вы можете
проверять длину ключей и row_pointer_length командой
myisamchk -dv table
. Место будет выделено на временном диске
(определенном через TMPDIR
или через --tmpdir=#
).
Если есть проблемы с местом на диске при ремонте, Вы можете попробовать
использовать --safe-recover
вместо --recover
.
myisamchk
для ремонта
Если Вы выполняете mysqld
с опцией
--skip-locking
(это является значением по умолчанию на некоторых
системах, подобно Linux), Вы не может надежно использовать
myisamchk
, чтобы проверить таблицу, когда mysqld
использует ту же самую таблицу. Если Вы можете убедиться, что никто не
обращается к таблицам через mysqld
в то время, как Вы выполняете
myisamchk
, Вы должны сделать только
mysqladmin flush-tables
прежде, чем начать проверять таблицы.
Если Вы не можете гарантировать вышеупомянутое, следует завершить
mysqld
перед проверкой таблиц. Если Вы выполняете
myisamchk
в то время, как mysqld
модифицирует
таблицы, Вы можете получить предупреждение, что таблица разрушена, даже если
это не так.
Если Вы не используете опцию --skip-locking
, Вы можете
использовать myisamchk
, чтобы проверить таблицы в любое время.
Пока Вы это делаете, вся клиентура, которая пробует модифицировать таблицу,
будет ждать завершения проверки.
Если Вы используете myisamchk
для ремонта или оптимизируете
таблицы, Вы ДОЛЖНЫ всегда гарантировать, что сервер
mysqld
не использует таблицу (это также применяется, если Вы
используете --skip-locking
). Если Вы не завершаете
mysqld
, нужно по крайней мере скомандовать
mysqladmin flush-tables
перед запуском myisamchk
.
Эта глава описывает, как проверять таблицы и иметь дело с нарушением целостности данных (не индексов) в базах данных MySQL. Если Ваши таблицы разрушились, Вы должны попробовать найти причину этого! Подробности в разделе "8.4.1 Что делать, если MySQL рухнул".
Формат файлов, в которых MySQL хранит свои таблицы, очень надежен, но всегда бывают случаи, когда таблицы будут подпорчены:
mysqld
рухнул посреди сеанса записи.
При выполнении восстановления важно понять, что каждая таблица
tbl_name
в базе данных соответствует трем файлам в
каталоге баз данных:
Файл | Зачем он нужен |
tbl_name.frm | Определение таблицы (форма) |
tbl_name.MYD | Данные таблицы |
tbl_name.MYI | Индексный файл таблицы |
Каждый из этих трех файлов портится различными способами, но проблемы происходят наиболее часто в файлах данных и индексных файлах.
myisamchk
работает, создавая копию .MYD (файлов с
данными) строка в строку. Он заканчивает стадию ремонта, удаляя старый файл
.MYD и переименовывая новый файл к первоначальному имени файла.
Если Вы используете опцию --quick
, myisamchk
не
создает временный файл .MYD, а принимает, что файл .MYD
правилен и только генерирует новый индексный файл без того, чтобы затронуть
соответствующий ему файл .MYD. Это безопасно потому, что
myisamchk
автоматически обнаруживает повреждение файла
.MYD и прерывает ремонт в этом случае. Вы можете также давать два
параметра --quick
. В этом случае myisamchk
не
прерывается на некоторых ошибках (подобно двойному ключу), но взамен пробует
решать их, изменяя файл .MYD. Обычно использование двух параметров
--quick
нужно только, если Вы имеете слишком мало свободного
дискового пространства, чтобы выполнить нормальный ремонт. В этом случае Вы
должны по крайней мере сделать копию перед запуском myisamchk
.
Для проверки таблиц MyISAM используйте следующие команды:
myisamchk tbl_name
myisamchk
без параметров или с параметрами
-s
или --silent
.
myisamchk -m tbl_name
myisamchk -e tbl_name
-e
означает "extended
check" или расширенную проверку). Выполняется тестовое чтение каждого ключа
для каждой строки, чтобы проверить, что они в самом деле указывают на
правильную строку. Это может занять МНОГО времени на большой таблице с
богатым ассортиментом ключей. Здесь надо отметить, что myisamchk
будет обычно останавливаться после первой ошибки, которую он найдет. Если Вы
хотите получить большее количество информации, Вы можете добавлять опцию
--verbose
(-v
). Это заставляет
myisamchk
работать первые 20 ошибок. При нормальном
использовании простого вызова myisamchk
(без параметров, кроме
имени таблицы) достаточно.
myisamchk -e -i tbl_name
-i
предписывает, чтобы
myisamchk
напечатал также и некоторую информационную статистику.
Здесь я расскажу о ремонте таблиц системы MyISAM
(расширения
файлов .MYI
и .MYD
). Для этого потребуется
программа myisamchk
. При использовании таблиц системы
ISAM
(их файлы имеют расширения .ISM
и
.ISD
), следует использовать программу isamchk
.
Признаки разрушенной таблицы обычно выглядят как неожиданное завершение работы во время запроса и появление ошибок типа:
perror ###
. Вот наиболее распространенные ошибки и
соответствующие им коды (заметьте, что можно указывать несколько кодов ошибок
подряд, разделяя их пробелами):
shell> perror 126 127 132 134 135 136 141 144 145 126 = Индексный файл разрушен или неверный формат файла 127 = Файл записей разрушен 132 = Старый файл базы данных 134 = Запись уже удалена (возможно, файл записей разрушен) 135 = Нет места в файле записей 136 = Нет места в индексном файле 141 = Дублирование уникального ключа или запрет на запись/обновление 144 = Таблица разрушена, и последний ремонт провалился 145 = Таблица была помечена как разрушеная и успешно отремонтированаВнимаение: ошибка 135 (нет места в файле записей) не может быть устранена простым ремонтом. В случае ее возникновения надо скомандовать:
ALTER TABLE table MAX_ROWS=xxx AVG_ROW_LENGTH=yyy;
Во всех остальных случаях Вы должны отремонтировать Ваши таблицы.
Программа myisamchk
может обычно обнаружить и устранить
большинство встречающихся ошибок.
Процесс ремонта включает до четырех стадий, описанных ниже. Прежде, чем Вы
начнете ремонт, надлежит перейти командой cd
в каталог баз
данных и проверить разрешения файлов таблицы. Удостоверьтесь, что они читаемы
тем пользователем, от имени которого выполняется mysqld
(и Вами
потому, что Вы должны обратиться к файлам, которые Вы проверяете). Если
окажется, что Вы должны изменить файлы, они должны также быть перезаписываемы
Вами, то есть Вы должны иметь право на запись.
Если Вы используете MySQL 3.23.16 и выше, то Вы можете
пользоваться командами CHECK
и REPAIR
для проверки
и восстановления таблиц системы MyISAM
соответственно.
Подробности в разделах "4.4.4 Синтаксис
CHECK TABLE
" и "4.4.5
Синтаксис REPAIR TABLE
".
Раздел об администрировании таблиц включает в себя подробное описание
всех необходимых для ремонта и проверки параметров. Подробности в разделе
"4.4.6 Использование
myisamchk
для устранения повреждений".
Следующий раздел предназначен для случаев, когда вышеупомянутая команда терпит неудачу, или если Вы хотите использовать расширенные свойства, которые предоставляются утилитами isamchk/myisamchk.
Если Вы выполняете ремонт таблиц из командной строки, сначала завершите
сервер mysqld
. Обратите внимание, что, когда Вы даете команду
mysqladmin shutdown
на удаленной системе, mysqld
будет работать некоторое время после mysqladmin
, пока все
запросы не будут остановлены, и все ключи сброшены на диск.
Стадия 1: Проверка Ваших таблиц
Запустите myisamchk *.MYI
или
(myisamchk -e *.MYI
, если Вы имеете много времени). Используйте
опцию -s
(тихий режим работы), чтобы подавить вывод ненужной
технической информации.
Если сервер mysqld выполнен, Вы должны использовать опцию --update, чтобы
myisamchk
отметил таблицу как 'проверено'.
Вы должны ремонтировать только те таблицы, для которых
myisamchk
объявляет ошибку. Для таких таблиц выполните стадию 2.
Если Вы получаете неожиданные ошибки при проверке (типа out of
memory
), или если есть сбои myisamchk
, идите к стадии 3.
Стадия 2: Облегченный ремонт
Замечание: Если Вы хотите, чтобы восстановление шло намного быстрее, Вы
должны добавить: -O sort_buffer=# -O key_buffer=#
(здесь # около
1/4 доступной памяти) ко всем командам isamchk/myisamchk
.
Сначала попробуйте myisamchk -r -q tbl_name
(-r -q
означает "быстрый режим восстановления"). Будет
предпринята попытка отремонтировать индексный файл без того, чтобы затронуть
файл данных. Если файл данных содержит все, что он должен содержать, и
удаленные связи указывают на корректные координаты внутри файла данных, это
должно сработать, и таблица будет выправлена. Если все получилось удачно,
запустите восстанавление следующей таблицы. Иначе, используйте следующую
процедуру ремонта:
myisamchk -r tbl_name
(-r
означает
"режим восстановления"). Это удалит неправильные записи и удаленные записи из
файла данных и восстановит индексный файл.
myisamchk --safe-recover tbl_name
. Безопасный режим
восстановления использует старый метод восстановления, который обрабатывает
несколько случаев, не поддающихся обычной процедуре ремонта (зато работает
куда медленнее).Стадия 3: Трудный ремонт
Если уж Вы дошли до этой стадии, значит первый блок длиной в 16 КБ в индексном файле разрушен или содержит неправильную информацию, или индексный файл отсутствует вообще. В этом случае необходимо создать новый индексный файл. Для этого:
shell> mysql db_name mysql> SET AUTOCOMMIT=1; mysql> TRUNCATE TABLE table_name; mysql> quitЕсли используемая Вами версия языка SQL не поддерживает команду
TRUNCATE TABLE
, используйте вместо нее команду
DELETE FROM table_name
А теперь идите на стадию 2. Теперь myisamchk -r -q
должен бы
сработать нормально (это не должно быть бесконечным циклом).
Стадия 4: Очень трудный ремонт
Если Вы дошли до этой точки, значит файл-описание тоже разрушен. Плохо дело... Этого вообще-то никогда не должно случиться, потому что файл описания после того, как таблица создана, не изменяется.
myisamchk -r
.
Из-за фрагментации записей и удаления данных возникает много пустого
места в файле таблиц. Запустите myisamchk
в режиме
восстановления для его зачистки:
shell> myisamchk -r tbl_name
Вы можете оптимизировать таблицу, используя инструкцию SQL OPTIMIZE
TABLE
. OPTIMIZE TABLE
ремонтирует таблицы, анализирует
ключи и сортирует индексное дерево, чтобы создать более быстрые поисковые
таблицы ключей. Совместная работа утилиты и сервера ничему не повредит, так
как сервер имеет доступ к таблице, а ее сортировка идет в фоновом режиме.
Подробности в разделе "4.5.1 Синтаксис
OPTIMIZE TABLE
".
Утилита myisamchk
также имеет ряд дополнительных параметров,
которые Вы можете использовать, чтобы улучшить эффективность таблицы:
-S, --sort-index
-R index_num, --sort-records=index_num
-a, --analyze
Полное описание опций приведено в разделе
"4.4.6.1 Синтаксис обращения к
myisamchk
".
Начиная с MySQL 3.23.13 Вы можете проверять таблицы
MyISAM командой CHECK TABLE
. Подробности в разделе
"4.4.4 Синтаксис
CHECK TABLE
". Ремонтировать таблицы можно командой
REPAIR TABLE
. Подробности в разделе
"4.4.5 Синтаксис
REPAIR TABLE
".
Неплохо проверять таблицы время от времени в целях профилактики, не
дожидаясь, пока Ваша база данных взорвется. В этих целях рекомендуется
использовать myisamchk -s
для проверки таблиц. Опция
-s
предписывает myisamchk
докладывать только
об ошибках в случае их обнаружения.
Имеет смысл выполнять проверку при запуске сервера. Например, если
компьютер перезагрузили посреди обращения к базе данных, надо при загрузке
сервера проверить все таблицы, на которые можно было бы воздействовать
(известны как ``expected crashed table''). Вы могли бы добавлять тест к
safe_mysqld
, который выполняет myisamchk
, чтобы
проверить все таблицы, которые изменились в течение последних 24 часов, если
имеется старый файл `.pid' (process ID), оставшийся после
перезагрузки. Файл `.pid' создается при запуске mysqld
и автоматически удаляется при нормальном завершении. Присутствие
`.pid' при запуске системы указывает, что mysqld
был
завершен неправильно.
Нужно проверить все таблицы, чье время модификации позже, чем у этого файла `.pid'.
Вы должны также проверять таблицы регулярно при нормальной работе
системы. Например, еженедельную проверку можно поручить планировщику задач
cron
, добавив строку в файл crontab:
35 0 * * 0 /path/to/myisamchk --fast --silent /path/to/datadir/*/*.MYI
Эта команда выведет данные о поврежденных таблицах, так что их можно будет проверить, когда будет такая возможность.
Для полной уверенности рекомендуется командой myisamchk -s
проверять раз в сутки все таблицы, которые изменились за это время.
Чтобы получить описание таблицы или статистику по ней, используйте команды, показанные ниже.
myisamchk -d tbl_name
myisamchk
в режиме описания (``describe mode''),
чтобы произвести описание Вашей таблицы. Если Вы запускаете сервер
MySQL с опцией --skip-locking
,
myisamchk
может выдать ошибку для таблицы, которая
модифицируется во время его выполнения. Однако, поскольку
myisamchk
не вносит изменений в таблицу в режиме описания, то
повредить ее он не может.
myisamchk -d -v tbl_name
myisamchk -eis tbl_name
myisamchk -eiv tbl_name
-eis
, но сообщает Вам, что сделается.MyISAM file: company.MYI Record format: Fixed length Data records: 1403698 Deleted blocks: 0 Recordlength: 226 table description: Key Start Len Index Type 1 2 8 unique double 2 15 10 multip. text packed stripped 3 219 8 multip. double 4 63 10 multip. text packed stripped 5 167 2 multip. unsigned short 6 177 4 multip. unsigned long 7 155 4 multip. text 8 138 4 multip. unsigned long 9 177 4 multip. unsigned long 193 1 text
Пример вывода myisamchk -d -v
:
MyISAM file: company Record format: Fixed length File-version: 1 Creation time: 1999-10-30 12:12:51 Recover time: 1999-10-31 19:13:01 Status: checked Data records: 1403698 Deleted blocks: 0 Datafile parts: 1403698 Deleted data: 0 Datafilepointer (bytes): 3 Keyfile pointer (bytes): 3 Max datafile length: 3791650815 Max keyfile length: 4294967294 Recordlength: 226 table description: Key Start Len Index Type Rec/key Root Blocksize 1 2 8 unique double 1 15845376 1024 2 15 10 multip. text packed stripped 2 25062400 1024 3 219 8 multip. double 73 40907776 1024 4 63 10 multip. text packed stripped 5 48097280 1024 5 167 2 multip. unsigned short 4840 55200768 1024 6 177 4 multip. unsigned long 1346 65145856 1024 7 155 4 multip. text 4995 75090944 1024 8 138 4 multip. unsigned long 87 85036032 1024 9 177 4 multip. unsigned long 178 96481280 1024 193 1 text
Пример вывода myisamchk -eis
:
Checking MyISAM file: company Key: 1: Keyblocks used: 97% Packed: 0% Max levels: 4 Key: 2: Keyblocks used: 98% Packed: 50% Max levels: 4 Key: 3: Keyblocks used: 97% Packed: 0% Max levels: 4 Key: 4: Keyblocks used: 99% Packed: 60% Max levels: 3 Key: 5: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 6: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 7: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 8: Keyblocks used: 99% Packed: 0% Max levels: 3 Key: 9: Keyblocks used: 98% Packed: 0% Max levels: 4 Total: Keyblocks used: 98% Packed: 17% Records: 1403698 M.recordlength: 226 Packed: 0% Recordspace used: 100% Empty space: 0% Blocks/Record: 1.00 Record blocks: 1403698 Delete blocks: 0 Recorddata: 317235748 Deleted data: 0 Lost space: 0 Linkdata: 0 User time 1626.51, System time 232.36 Maximum resident set size 0, Integral resident set size 0 Non physical pagefaults 0, Physical pagefaults 627, Swaps 0 Blocks in 0 out 0, Messages in 0 out 0, Signals 0 Voluntary context switches 639, Involuntary context switches 28966
Пример вывода myisamchk -eiv
:
Checking MyISAM file: company Data records: 1403698 Deleted blocks: 0 - check file-size - check delete-chain block_size 1024: index 1: index 2: index 3: index 4: index 5: index 6: index 7: index 8: index 9: No recordlinks - check index reference - check data record references index: 1 Key: 1: Keyblocks used: 97% Packed: 0% Max levels: 4 - check data record references index: 2 Key: 2: Keyblocks used: 98% Packed: 50% Max levels: 4 - check data record references index: 3 Key: 3: Keyblocks used: 97% Packed: 0% Max levels: 4 - check data record references index: 4 Key: 4: Keyblocks used: 99% Packed: 60% Max levels: 3 - check data record references index: 5 Key: 5: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 6 Key: 6: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 7 Key: 7: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 8 Key: 8: Keyblocks used: 99% Packed: 0% Max levels: 3 - check data record references index: 9 Key: 9: Keyblocks used: 98% Packed: 0% Max levels: 4 Total: Keyblocks used: 9% Packed: 17% - check records and index references [LOTS OF ROW NUMBERS DELETED] Records: 1403698 M.recordlength: 226 Packed: 0% Recordspace used: 100% Empty space: 0% Blocks/Record: 1.00 Record blocks: 1403698 Delete blocks: 0 Recorddata: 317235748 Deleted data: 0 Lost space: 0 Linkdata: 0 User time 1639.63, System time 251.61 Maximum resident set size 0, Integral resident set size 0 Non physical pagefaults 0, Physical pagefaults 10580, Swaps 0 Blocks in 4 out 0, Messages in 0 out 0, Signals 0 Voluntary context switches 10604, Involuntary context switches 122798
Размеры файлов данных и индекса, использованных в этих примерах:
-rw-rw-r-- 1 monty tcx 317235748 Jan 12 17:30 company.MYD -rw-rw-r-- 1 davida tcx 96482304 Jan 12 18:35 company.MYM
Теперь немного о терминологии, использованной в этом выводе. Здесь "keyfile" означает индексный файл. "Record" и "row" являются синонимами.
ISAM file
Isam-version
Creation time
Recover time
Data records
Deleted blocks
Datafile: Parts
Data records
.
Deleted data
Datafile pointer
Keyfile pointer
Max datafile length
.MYD
).
Max keyfile length
.MYI
).
Recordlength
Record format
Фиксированную длину (Fixed length)
. Другие
возможные значения: Сжатый (Compressed)
и Упакованный
(Packed)
.
table description
Key
Start
Len
Index
Уникальный (unique)
или множественный (multip)
.
Указывает, может ли одно значение существовать многократно в этом индексе.
Type
packed
, stripped
или empty
.
Root
Blocksize
Rec/key
myisamchk -a
.
Если это не модифицируется вообще, значение по умолчанию 30.
Keyblocks used
myisamchk
,
значения очень высоки (очень близки к теоретическому максимуму).
Packed
CHAR
/
VARCHAR
/DECIMAL
. Для длинных строк это может
существенно экономить место. В третьем примере выше четвертый ключ длиной 10
символов, и на нем достигнуто уменьшение в 60%.
Max levels
Records
M.recordlength
Packed
Packed
указывает, сколько процентов на этом сэкономлено.
Recordspace used
Empty space
Blocks/Record
myisamchk
. Подробности в разделе
"4.4.6.10 Оптимизация таблиц".
Recordblocks
Deleteblocks
Recorddata
Deleted data
Lost space
Linkdata
Linkdata
равна сумме
памяти, используемой всеми такими указателями.Если таблица была сжата с помощью myisampack
, то команда
myisamchk -d
выведет дополнительную информацию относительно
каждого столбца таблицы. Подробности в разделе
"4.7.4 Генератор сжатых таблиц MySQL
только для чтения".
Закладки на сайте Проследить за страницей |
Created 1996-2025 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |