Разрешения Django слишком сильно используют базу данных
Мы начали исследование нашей базы данных, поскольку она является менее масштабируемым компонентом нашей инфраструктуры. Я проверил таблицу pg_stat_statements нашей базы данных Postgresql с помощью следующего запроса:
SELECT userid, calls, total_time, rows, 100.0 * shared_blks_hit /
nullif(shared_blks_hit + shared_blks_read, 0) AS hit_percent, query
FROM pg_stat_statements ORDER BY total_time DESC LIMIT 5;
Каждый раз один и тот же запрос оказывается первым в списке:
16386 | 21564 | 4077324.749363 | 1423094 | 99.9960264252721535 |
SELECT DISTINCT "auth_user"."id", "auth_user"."password", "auth_user"."last_login",
"auth_user"."is_superuser", "auth_user"."username", "auth_user"."first_name",
"auth_user"."last_name", "auth_user"."email", "auth_user"."is_staff",
"auth_user"."is_active", "auth_user"."date_joined" FROM "auth_user"
LEFT OUTER JOIN "auth_user_groups" ON ("auth_user"."id" = "auth_user_groups"."user_id")
LEFT OUTER JOIN "auth_group" ON ("auth_user_groups"."group_id" = "auth_group"."id")
LEFT OUTER JOIN "auth_group_permissions" ON ("auth_group"."id" = "auth_group_permissions"."group_id")
LEFT OUTER JOIN "auth_user_user_permissions" ON ("auth_user"."id" = "auth_user_user_permissions"."user_id")
WHERE ("auth_group_permissions"."permission_id" = $1 OR "auth_user_user_permissions"."permission_id" = $2)
Это звучит как проверка разрешений, и, как я понимаю, она кэшируется на уровне запроса. Интересно, сделал ли кто-нибудь пакет для их кэширования, например, в memcached, или нашел решение для уменьшения количества запросов, выполняемых для проверки этих разрешений?
Я проверил все индексы и они кажутся правильными. Запрос немного медленный, в основном потому, что у нас много разрешений, но все равно, количество вызовов просто сумасшедшее.