Вопрос "Почему много промахов в кэш MyISAM, когда в БД только InnoDB?" требует внимательного рассмотрения различий между двумя этими типами хранилищ данных MySQL и их влияния на производительность.
MySQL поддерживает два основных типа хранилищ данных: MyISAM и InnoDB.
1. MyISAM:
MyISAM является одним из самых старых и наиболее простых типов хранилищ данных в MySQL. Он поддерживает только блокировку таблицы, что означает, что при запросе на чтение или запись происходит блокировка всей таблицы. Это может привести к конкурентным блокировкам и проблемам параллелизма в многопользовательских системах. Однако, MyISAM имеет кэш индексов и ключей, которые используются для ускорения поиска записей в таблице. Но при частом использовании обновлений, вставок и удалений в таблице, кэш может воздействовать на производительность, так как он может содержать устаревшие данные или просто не успевать обновляться.
2. InnoDB:
InnoDB является современным типом хранилища данных, который предоставляет более широкие возможности и функциональность по сравнению с MyISAM. InnoDB поддерживает транзакции, многоверсионность и механизм блокировки на уровне строк, что позволяет более эффективно управлять конкуренцией при одновременном доступе к данным. Также InnoDB предоставляет кэш буфера, который хранит данные в оперативной памяти и синхронизирует их с диском. В отличие от кэша MyISAM, кэш буфера InnoDB чаще бывает более актуальным, так как он обновляется в реальном времени.
Теперь, если в вашей базе данных используется только InnoDB, то промахи в кэше MyISAM не должны иметь большого значения для производительности системы. Однако, если эти промахи все же наблюдаются, возможно, они могут быть вызваны настройкой конфигурационных параметров MySQL, позволяющей использование кэша MyISAM, даже если в базе данных используется только InnoDB.
Чтобы устранить многочисленные промахи в кэше MyISAM, вы можете проверить конфигурационные параметры MySQL и установить надлежащие параметры размера и стратегию кэширования для InnoDB. Вы также можете выполнить оптимизацию вашей базы данных, чтобы улучшить производительность запросов и уменьшить нагрузку на кэш.
В целом, использование только InnoDB вместо MyISAM является предпочтительным для большинства современных приложений, так как InnoDB предоставляет более продвинутую функциональность и лучшую производительность при работе с транзакциями и параллельным доступом к данным.