Как увеличить table_open_cache

Как увеличить table_open_cache

Опытным путём пришел к выводу, что значение table_open_cache похоже на то, что это 50% от open_files_limit

Первым делом нужно понять сразу до каких значений нужно увеличивать, чтобы не тратить время на постепенное увеличение как везде рекомендуют. В этом нам поможет формула кеша открытых таблиц:
$calc['table_cache_hit_rate'] = round($stat['Open_tables'] / $stat['Opened_tables'] * 100, 2);

Например, у вас через 11 дней такая ситуация, кеш вымывается:
Opened_tables-994628
Open_tables-196398
Кеш открытых таблиц 19.75%

При этом table_open_cache 65000, по формуле уже сразу видно, что нужно увеличить минимум в пять раз, т.е. до 325 000. Поэтому смело можно увеличивать open_files_limit до 750 000.
Значение выставляем в systemd:
 /etc/systemd/system/mysql.service.d
в файле nofile.conf 

[Service]
LimitNOFILE=750000

После этого периодически  смотрим параметры кеша открытых таблиц, у меня на 28 день было 80%

28 day -80%.png


Ещё статьи:

06.04.2022 Своё АПИ на сайте битрикс без модуля
Искал куда компонент спрятали и нашёл такую реализацию мини АПИ без модуля. ID: 333

18.03.2022 Получение минимальной цены и сохранение в свойство
Пополнение - пример события OnPriceUpdate для получение минимальной цены и сохранения в свойство инфоблока. ID: 332

12.02.2022 Проверка групп пользователя и исключение разделов
Пример события для проверки групп пользователя с целью исключить разделы из общего доступа ID: 331

© 2015-2022 Web админ
Связаться по WhatsApp