5.4.7 Открытие и закрытие таблиц в MySQL
Параметры table_cache
, max_connections
и max_tmp_tables
задают
максимальное количество файлов, которые сервер держит открытыми. Если
увеличить один или оба этих параметра, то можно столкнуться с
ограничением, накладываемым данной операционной системой на количество
открытых файловых дескрипторов для одного процесса. Во многих системах,
однако, этот предел можно увеличить. Поскольку способы изменения данного
значения для разных систем могут быть совершенно различными, в каждом
конкретном случае вам следует обращаться к документации по своей
операционной системе.
Значения table_cache
и max_connections
взаимосвязаны. Например, для 200
одновременно работающих соединений необходимо иметь кэш для таблиц
размером по меньшей мере 200 * n, где n - максимальное количество
связанных таблиц. Необходимо также зарезервировать несколько
дополнительных файловых дескрипторов для временных таблиц и файлов.
Следует удостовериться, что ваша операционная система способна
обрабатывать такое количество открытых файловых дескрипторов, какое
предполагает данная установка table_cache
. Если устанавливается слишком
высокое значение table_cache
, то MySQL может выйти за пределы допустимого
количества файловых дескрипторов, прервать соединение, не выполнять
запросы и стать очень ненадежным. Необходимо также принять во внимание,
что для обработчика таблиц MyISAM
требуется по два файловых дескриптора
для каждой уникальной открытой таблицы. Допустимое для MySQL количество
файловых дескрипторов можно увеличить с помощью опции запуска
--open-files-limit=#
(see section A.2.16 Не найден файл (File not found
)).
Максимальное количество таблиц в кэше открытых таблиц будет равно
количеству, указанному в table_cache
(по умолчанию - 64; это число можно
изменить с помощью опции -O table_cache=#
для mysqld
). Следует учитывать,
что для выполнения запросов MySQL может временно открыть и больше таблиц.
Неиспользуемая таблица закрывается и удаляется из кэша таблиц в следующих
ситуациях:
-
Когда кэш заполнен и поток старается открыть таблицу, отсутствующую в
этом кэше.
-
Когда кэш содержит более, чем
table_cache
входных величин, и поток
больше не использует таблицу.
-
Когда кто-либо выполняет
mysqladmin refresh
или mysqladmin
flush-tables
.
-
Когда кто-либо выполняет
FLUSH TABLES
.
Когда табличный кэш заполняется, сервер использует следующую процедуру
размещения входных данных кэша для их использования:
-
Не используемые в данное время таблицы освобождаются в порядке
наиболее давнего использования.
-
Если кэш заполнен и ни одна таблица не может быть высвобождена, а
необходимо открыть новую таблицу, то кэш временно расширяется
настолько, насколько необходимо.
-
Если кэш находится во временно расширенном состоянии и таблица
переходит из используемого в неиспользуемое состояние, то такая
таблица закрывается и освобождается из кэша.
Таблица открывается для каждого одновременного доступа. Это означает, что,
если существуют два потока, получающие доступ к одной и той же таблице,
или происходит обращение к этой таблице дважды в одном и том же запросе (с
помощью AS
), то данная таблица должна быть открыта дважды. Для первого
открытия любой таблицы требуется два файловых дескриптора; для каждого
дополнительного использования - только один. Дополнительный дескриптор для
первого открытия используется для индексного файла; этот дескриптор
используется совместно всеми потоками.
При открытии таблицы командой HANDLER table_name OPEN
создается выделенный
табличный объект для данного потока. Этот табличный объект недоступен для
других потоков и не будет закрыт, пока данный поток не вызовет команду
HANDLER table_name CLOSE
или сам поток не уничтожится (see section 6.4.2 Синтаксис оператора HANDLER
). Если это произойдет, то данная таблица помещается обратно в кэш
таблиц (если он не заполнен).
Чтобы узнать, не слишком ли мал кэш таблиц, следует проверить переменную
Opened_tables
. Если ее значение достаточно велико, даже если вы не
выполняли слишком часто команду FLUSH TABLES
, то необходимо увеличить
данный кэш таблиц (see section 4.5.6.3 SHOW STATUS
).