Thank you for reading this post, don't forget to subscribe!
Когда новый клиент устанавливает соединение с Mysql, Mysql открывает создает новый тред (thread) для этого клиента. В средах с больших количеством клиентов и соединений, создание и удаление тредов становится дорогой операцией. Для того, чтобы оптимизировать этот процесс, существует настройка thread_cache_size. Вместо постоянного создания и удаления, Mysql может сохранять неактивные треды в кеш (и использовать в случае необходимости).
Параметр thread_cache_size определяет максимальное количество тредов в кеше.
По умолчанию, эта настройка выключена. Значение стоит выбирать не менее значения, которое указано в max_connections (устанавливается в my.cnf):
1 2 3 |
max_connections = 128 ... <b>thread_cache_size = 128</b> |
# Значение не меньше max_connections
Этот параметр также можно устанавливать без перезагрузки:
1 |
mysql> SET GLOBAL thread_cache_size = 128; |
Чтобы определить необходимость изменение значения этого параметра, нужно получить значение созданных тредов:
1 |
mysql -e "SHOW GLOBAL STATUS LIKE 'Threads_created';" |
1 2 3 4 5 |
+-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | Threads_created | <b>12</b> | +-----------------+-------+ |
# Threads_created должен быть меньше нескольких сотен
Если значение больше, чем 100, thread_cache_size стоит увеличивать (на 8…16 единиц). Эту проверку стоит периодически повторять.