{"id":483138,"date":"2026-06-10T10:58:29","date_gmt":"2026-06-10T10:58:29","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=483138"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=483138","title":{"rendered":"\u0412\u0430\u0448\u0438 \u0442\u0435\u0441\u0442\u044b \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0435 \u043d\u0435 \u0438\u0437-\u0437\u0430 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445. \u042f \u0438\u0437\u043c\u0435\u0440\u0438\u043b"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<blockquote>\n<p><strong>\u0414\u0438\u0441\u043a\u043b\u0435\u0439\u043c\u0435\u0440.<\/strong> \u042d\u0442\u043e \u043d\u0435 \u00ab\u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0432\u0435\u0440\u043d\u044b\u0439 \u043f\u0443\u0442\u044c\u00bb, \u0430 \u043a\u0435\u0439\u0441 \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430: \u0431\u044d\u043a\u0435\u043d\u0434 \u043d\u0430 Litestar + SQLAlchemy + Postgres + Redis, 3316 \u0442\u0435\u0441\u0442\u043e\u0432, \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435, \u0445\u043e\u0434\u044f\u0442 \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0411\u0414. \u0412\u0441\u0435 \u0437\u0430\u043c\u0435\u0440\u044b \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435, \u043d\u0430 \u043c\u043e\u0451\u043c \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435 \u2014 \u043d\u0435 \u0432 CI. \u0420\u0430\u043d\u043d\u0435\u0440\u043e\u0432 \u0443 \u043d\u0430\u0441 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438 \u043e\u043d\u0438 \u0440\u0430\u0437\u043d\u044b\u0435 \u043f\u043e \u0436\u0435\u043b\u0435\u0437\u0443, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0435 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0443 \u0432\u0430\u0441 \u0431\u0443\u0434\u0443\u0442 \u0434\u0440\u0443\u0433\u0438\u043c\u0438; \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, <em>\u0432\u043e \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437<\/em> \u0441\u0442\u0430\u043b\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u0437\u0430 \u0441\u0447\u0451\u0442 \u0447\u0435\u0433\u043e. \u0421\u043a\u0440\u0438\u043f\u0442\u044b \u0434\u043b\u044f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u2014 \u0432 \u043a\u043e\u043d\u0446\u0435 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<\/blockquote>\n<p>\u0415\u0441\u0442\u044c \u0443\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u043e\u0435 \u043f\u043e\u0432\u0435\u0440\u044c\u0435: \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435 \u0442\u0435\u0441\u0442\u044b \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0435, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0445\u043e\u0434\u044f\u0442 \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0431\u0430\u0437\u0443. \u00ab\u041f\u043e\u0434\u043d\u0438\u043c\u0438 SQLite \u0432 \u043f\u0430\u043c\u044f\u0442\u0438\u00bb, \u00ab\u0437\u0430\u043c\u043e\u043a\u0430\u0439 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438\u00bb, \u00ab\u043d\u0435 \u0433\u043e\u043d\u044f\u0439 Postgres \u0432 CI\u00bb \u2014 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0441\u043e\u0432\u0435\u0442\u043e\u0432. \u041c\u043e\u043a\u0430\u0442\u044c \u044f \u043d\u0435 \u043b\u044e\u0431\u043b\u044e \u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1034864\/\" rel=\"noopener noreferrer nofollow\">\u0443\u0436\u0435 \u043f\u0438\u0441\u0430\u043b \u043f\u043e\u0447\u0435\u043c\u0443<\/a>, \u043d\u043e \u043a\u0440\u044b\u0442\u044c \u0443\u043f\u0440\u0451\u043a \u00ab\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0430\u044f \u0431\u0430\u0437\u0430 \u2014 \u044d\u0442\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u00bb \u0431\u044b\u043b\u043e \u043d\u0435\u0447\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0441\u0435\u043b, \u0441\u043f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043b \u0438 \u043f\u043e\u043c\u0435\u0440\u0438\u043b. \u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0432\u0440\u0435\u043c\u044f \u0441\u044a\u0435\u0434\u0430\u043b\u0430 \u043e\u0434\u043d\u0430 \u043f\u0440\u0430\u0432\u043a\u0430 \u043f\u0440\u043e \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b. \u0410 \u043d\u0430\u0440\u043e\u0434\u043d\u044b\u0439 \u0441\u043e\u0432\u0435\u0442 \u00ab\u0447\u0438\u0441\u0442\u0438 \u0431\u0430\u0437\u0443 \u0447\u0435\u0440\u0435\u0437 TRUNCATE, \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 DELETE\u00bb \u0443 \u043c\u0435\u043d\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0440\u043e\u0432\u043d\u043e \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u2014 \u0447\u0442\u043e \u043e\u0431\u0438\u0434\u043d\u043e \u0432\u0434\u0432\u043e\u0439\u043d\u0435: \u044d\u0442\u0430 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0443\u0436\u0435 \u043b\u0435\u0436\u0430\u043b\u0430 \u0432 \u0447\u0435\u0440\u043d\u043e\u0432\u0438\u043a\u0435 \u043c\u043e\u0435\u0439 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0438 \u043f\u0440\u043e pytest. \u041f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u043d\u043e\u0432\u0438\u043a.<\/p>\n<p>\u0421\u044c\u044e\u0442 \u0448\u0451\u043b \u224830 \u043c\u0438\u043d\u0443\u0442 (1795 \u0441). \u0421\u0442\u0430\u043b \u2014 \u043c\u0435\u043d\u044c\u0448\u0435 \u0434\u0432\u0443\u0445 \u043c\u0438\u043d\u0443\u0442 (109 \u0441). \u0411\u0435\u0437 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u043d\u0438\u044f \u0442\u0435\u0441\u0442\u043e\u0432, \u0442\u0440\u0435\u043c\u044f \u043f\u0440\u0430\u0432\u043a\u0430\u043c\u0438 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b. \u041d\u0438\u0436\u0435 \u2014 \u043a\u0430\u043a \u044f \u0438\u0441\u043a\u0430\u043b \u0443\u0437\u043a\u0438\u0435 \u043c\u0435\u0441\u0442\u0430 \u0438 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0430\u043b\u0430 \u043a\u0430\u0436\u0434\u0430\u044f \u043f\u0440\u0430\u0432\u043a\u0430.<\/p>\n<p>\u0415\u0441\u043b\u0438 \u0443\u0437\u043d\u0430\u0451\u0442\u0435 \u0441\u0432\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u0445\u043e\u0442\u044f \u0431\u044b \u0432 \u043e\u0434\u043d\u043e\u043c \u043f\u0443\u043d\u043a\u0442\u0435 \u2014 \u0434\u0430\u043b\u044c\u0448\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u043e:<\/p>\n<ul>\n<li>\n<p>async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b (engine, redis, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435) \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d\u044b \u0431\u0435\u0437 <code>scope=<\/code> \u2014 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442;<\/p>\n<\/li>\n<li>\n<p>\u0432 \u0442\u0435\u0441\u0442\u0430\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0431\u043e\u0435\u0432\u043e\u0439 \u0445\u0435\u0448 \u043f\u0430\u0440\u043e\u043b\u044f (argon2\/bcrypt) \u0441 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438;<\/p>\n<\/li>\n<li>\n<p>\u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u0431\u0430\u0437\u0430 \u0447\u0438\u0441\u0442\u0438\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 <code>DELETE<\/code>\/<code>TRUNCATE<\/code>, \u0438 \u0435\u0441\u0442\u044c \u043f\u043e\u0434\u043e\u0437\u0440\u0435\u043d\u0438\u0435, \u0447\u0442\u043e \u00ab\u0432\u043e\u0442 \u044d\u0442\u043e \u0438 \u0442\u043e\u0440\u043c\u043e\u0437\u0438\u0442\u00bb;<\/p>\n<\/li>\n<li>\n<p>\u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043c\u0438\u043d\u0443\u0442\u044b (\u0430 \u0442\u043e \u0438 \u0434\u0435\u0441\u044f\u0442\u043a\u0438), \u0432 CI \u2014 \u043a\u0440\u0430\u0442\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u0438 \u0442\u043e\u0447\u043d\u043e\u0433\u043e \u043e\u0442\u0432\u0435\u0442\u0430 \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb \u043d\u0435\u0442.<\/p>\n<\/li>\n<\/ul>\n<hr\/>\n<h3>\u041e\u0442\u043f\u0440\u0430\u0432\u043d\u0430\u044f \u0442\u043e\u0447\u043a\u0430: 3316 \u0442\u0435\u0441\u0442\u043e\u0432 \u0438 \u043f\u043e\u043b\u0447\u0430\u0441\u0430 \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f<\/h3>\n<p>\u0422\u0435\u0441\u0442\u044b \u043d\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0447\u0435\u0441\u0442\u043d\u044b\u0435: \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435, \u0445\u043e\u0434\u044f\u0442 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 Postgres \u0438 Redis \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 ASGI-\u0441\u0435\u0440\u0432\u0435\u0440.<\/p>\n<p>\u041f\u043e\u043a\u0430 \u0438\u0445 \u043d\u0435\u043c\u043d\u043e\u0433\u043e, \u0432\u0441\u0451 \u0438\u0434\u0451\u0442 \u0431\u044b\u0441\u0442\u0440\u043e: \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e, \u0432 CI \u0447\u0443\u0442\u044c \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435. \u0422\u0435\u0440\u043f\u0438\u043c\u043e. \u041c\u043e\u0436\u043d\u043e \u0434\u0430\u0436\u0435 \u0441 \u043b\u0451\u0433\u043a\u043e\u0439 \u0438\u0440\u043e\u043d\u0438\u0435\u0439 \u043f\u043e\u0433\u043b\u044f\u0434\u044b\u0432\u0430\u0442\u044c \u043d\u0430 \u0442\u0435\u0445, \u0443 \u043a\u043e\u0433\u043e \u00ab\u0442\u0435\u0441\u0442\u044b \u043f\u043e \u043f\u043e\u043b\u0447\u0430\u0441\u0430\u00bb. \u041f\u043e\u0442\u043e\u043c \u043f\u0440\u043e\u0433\u043e\u043d \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 5 \u043c\u0438\u043d\u0443\u0442. \u041f\u043e\u0442\u043e\u043c 10. \u041f\u043e\u0442\u043e\u043c 15 \u2014 \u043d\u0443 \u0442\u0430\u043a \u0442\u0435\u0441\u0442\u043e\u0432 \u0436\u0435 \u0441\u0442\u0430\u043b\u043e \u0431\u043e\u043b\u044c\u0448\u0435. \u0423\u0445\u043e\u0434\u0438\u0448\u044c \u043d\u0430 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0448\u044c\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0440\u0443 \u043d\u0435\u0434\u0435\u043b\u044c \u2014 \u043f\u043e\u043b\u0447\u0430\u0441\u0430. 1795 \u0441\u0435\u043a\u0443\u043d\u0434 \u043d\u0430 3316 \u0442\u0435\u0441\u0442\u043e\u0432.<\/p>\n<p>\u041b\u043e\u043a\u0430\u043b\u044c\u043d\u043e \u044d\u0442\u043e \u0431\u043e\u043b\u044c. \u0412 CI \u0445\u0443\u0436\u0435: \u043a\u0430\u0436\u0434\u044b\u0439 \u043f\u0443\u0448 \u0441\u0442\u043e\u0438\u0442 \u043e\u043a\u043e\u043b\u043e \u0447\u0430\u0441\u0430.<\/p>\n<p>\u0427\u0438\u043d\u0438\u0442\u044c \u043d\u0430\u0443\u0433\u0430\u0434 \u0434\u043e\u0440\u043e\u0433\u043e \u2014 \u043c\u043e\u0436\u043d\u043e \u043d\u0435\u0434\u0435\u043b\u044e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432 \u0441\u0443\u043c\u043c\u0435 \u0434\u0430\u044e\u0442 2 % \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u0434\u043e \u043f\u043e\u043d\u044f\u0442\u044c, \u043a\u0443\u0434\u0430 \u0443\u0445\u043e\u0434\u0438\u0442 \u0432\u0440\u0435\u043c\u044f.<\/p>\n<h3>\u041f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435: \u0433\u0434\u0435 \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0433\u043e\u0440\u0438\u0442<\/h3>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d \u0432 pytest:<\/p>\n<pre><code class=\"bash\">pytest --durations=0    # \u0432\u0441\u0435 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438; --durations=25 \u2014 \u0442\u043e\u043f-25<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418 \u043f\u0435\u0440\u0432\u044b\u0439 \u0441\u044e\u0440\u043f\u0440\u0438\u0437: \u0432\u0438\u043d\u043e\u0432\u0430\u0442\u043e\u0433\u043e \u0442\u0435\u0441\u0442\u0430 \u043d\u0435\u0442. \u041d\u0435\u0442 \u0434\u0435\u0441\u044f\u0442\u0438 \u0442\u044f\u0436\u0451\u043b\u044b\u0445 \u0442\u0435\u0441\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u0441\u0451 \u043f\u043e\u0440\u0442\u044f\u0442, \u2014 \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d\u043e \u0440\u043e\u0432\u043d\u044b\u043c \u0441\u043b\u043e\u0435\u043c \u043f\u043e \u0432\u0441\u0435\u043c 3316. \u042d\u0442\u043e \u043d\u0430\u043b\u043e\u0433, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043b\u0430\u0442\u0438\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043d\u0430 \u0432\u0445\u043e\u0434\u0435. <code>--durations<\/code> \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442, <em>\u043a\u0430\u043a\u0438\u0435<\/em> \u0442\u0435\u0441\u0442\u044b \u0434\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043a\u043e\u0433\u0434\u0430 \u0434\u043e\u043b\u044c\u0448\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0432\u0441\u0435 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e, \u043e\u043d \u043d\u0435 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441 \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb.<\/p>\n<p>\u0414\u043b\u044f \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb \u043d\u0443\u0436\u0435\u043d \u043f\u0440\u043e\u0444\u0430\u0439\u043b\u0435\u0440 \u0443\u0440\u043e\u0432\u043d\u0435\u043c \u043d\u0438\u0436\u0435:<\/p>\n<pre><code class=\"bash\">python -m cProfile -o profile_v0.out -m pytest .\/tests -p no:randomly -q<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041e\u0433\u043e\u0432\u043e\u0440\u043a\u0430: <a href=\"https:\/\/docs.python.org\/3\/library\/profile.html\" rel=\"noopener noreferrer nofollow\">cProfile<\/a> \u043d\u0435 \u043b\u0443\u0447\u0448\u0438\u0439 \u0434\u0440\u0443\u0433 async-\u043a\u043e\u0434\u0430 \u2014 \u0432\u0440\u0435\u043c\u044f \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0432 <code>await<\/code> \u043e\u043d \u0440\u0430\u0437\u043c\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u043f\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u0430, \u0438 \u0434\u043b\u044f \u043a\u0440\u0430\u0441\u0438\u0432\u044b\u0445 flame-\u0433\u0440\u0430\u0444\u043e\u0432 \u0431\u043e\u043b\u044c\u0448\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0442 <a href=\"https:\/\/github.com\/benfred\/py-spy\" rel=\"noopener noreferrer nofollow\">py-spy<\/a> \u0438\u043b\u0438 <a href=\"https:\/\/github.com\/joerick\/pyinstrument\" rel=\"noopener noreferrer nofollow\">pyinstrument<\/a>. \u041c\u043d\u0435 \u0445\u0432\u0430\u0442\u0438\u043b\u043e \u0433\u0440\u0443\u0431\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0438 \u043f\u043e \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u043c\u0443 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043d\u043e \u0437\u043d\u0430\u0442\u044c \u043f\u0440\u043e \u044d\u0442\u043e \u0441\u0442\u043e\u0438\u0442.<\/p>\n<p>\u0424\u0430\u0439\u043b \u043f\u0440\u043e\u0444\u0438\u043b\u044f \u2014 186 \u043c\u043b\u043d \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0438 \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u0442\u044b\u0441\u044f\u0447 \u0441\u0442\u0440\u043e\u043a \u043f\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c (\u0441\u043d\u0438\u043c\u0430\u043b \u043d\u0430 \u043f\u043e\u0434\u0432\u044b\u0431\u043e\u0440\u043a\u0435 \u0442\u0435\u0441\u0442\u043e\u0432: \u043f\u043e\u043b\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u043f\u043e\u0434 cProfile \u0432 \u043d\u0435\u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u043d\u0435\u0432\u044b\u043d\u043e\u0441\u0438\u043c\u043e \u0434\u043e\u043b\u0433\u0438\u0439). \u0413\u043b\u0430\u0437\u0430\u043c\u0438 \u0442\u0430\u043a\u043e\u0435 \u043d\u0435 \u043e\u0442\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u044e\u0442 \u2014 \u043b\u0435\u0433\u043a\u043e \u0437\u0430\u0446\u0435\u043f\u0438\u0442\u044c\u0441\u044f \u0437\u0430 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443 \u0438 \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u0442\u044c \u0443\u0437\u043a\u043e\u0435 \u043c\u0435\u0441\u0442\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0435\u0442. \u042f \u0441\u043a\u043e\u0440\u043c\u0438\u043b <code>profile_v0.out<\/code> LLM \u0441 \u043e\u0434\u043d\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435\u0439: \u0441\u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0438 \u043e\u0442\u0440\u0430\u043d\u0436\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u043e \u0441\u043e\u0432\u043e\u043a\u0443\u043f\u043d\u043e\u043c\u0443 tottime. \u0422\u043e\u0442 \u0436\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0434\u0430\u043b\u0438 \u0431\u044b <a href=\"https:\/\/jiffyclub.github.io\/snakeviz\/\" rel=\"noopener noreferrer nofollow\">snakeviz<\/a> \u0438\u043b\u0438 <a href=\"https:\/\/github.com\/jrfonseca\/gprof2dot\" rel=\"noopener noreferrer nofollow\">gprof2dot<\/a> \u043f\u043b\u044e\u0441 \u043f\u0430\u0440\u0430 \u0447\u0430\u0441\u043e\u0432 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u2014 \u043c\u043d\u0435 \u0431\u044b\u043b\u043e \u043b\u0435\u043d\u044c. \u0420\u0435\u0448\u0430\u0435\u0442 \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0437\u0430\u043c\u0435\u0440, \u043f\u0440\u043e\u0444\u0430\u0439\u043b\u0435\u0440 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442, \u043a\u0443\u0434\u0430 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c.<\/p>\n<p>\u0413\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430\u0441\u044c \u0442\u0430\u043a\u0430\u044f:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">\u0413\u0440\u0443\u043f\u043f\u0430 \u0440\u0430\u0441\u0445\u043e\u0434\u043e\u0432<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0414\u043e\u043b\u044f<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041e\u0436\u0438\u0434\u0430\u043d\u0438\u0435 I\/O \u043d\u0430 \u0441\u043e\u043a\u0435\u0442\u0430\u0445 (\u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 Postgres\/Redis)<\/p>\n<\/td>\n<td>\n<p align=\"left\"><strong>64 %<\/strong><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 event loop \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">5,6 %<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041e\u0442\u043a\u0440\u044b\u0442\u0438\u0435 \u043d\u043e\u0432\u044b\u0445 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 (<code>asyncpg.connect<\/code>)<\/p>\n<\/td>\n<td>\n<p align=\"left\">3,7 %<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0425\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u0430\u0440\u043e\u043b\u0435\u0439 (<code>argon2<\/code>)<\/p>\n<\/td>\n<td>\n<p align=\"left\">2,3 %<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b \u0411\u0414 (<code>create_all<\/code>, DDL)<\/p>\n<\/td>\n<td>\n<p align=\"left\">1,2 %<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">greenlet-\u043c\u043e\u0441\u0442 async\u2194sync SQLAlchemy<\/p>\n<\/td>\n<td>\n<p align=\"left\">0,7 %<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u0427\u0442\u043e \u0438\u0437 \u044d\u0442\u043e\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u0435\u0442.<\/p>\n<p>\u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0441\u044c\u044e\u0442 I\/O-bound: 64 % \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0440\u043e\u0441\u0442\u043e \u0436\u0434\u0451\u0442 \u0441\u043e\u043a\u0435\u0442\u044b. CPU \u043f\u043e\u0447\u0442\u0438 \u043f\u0440\u043e\u0441\u0442\u0430\u0438\u0432\u0430\u0435\u0442 \u2014 \u0442\u0435\u0441\u0442\u044b \u043d\u0435 \u00ab\u0441\u0447\u0438\u0442\u0430\u044e\u0442\u00bb, \u043e\u043d\u0438 \u043e\u0431\u0449\u0430\u044e\u0442\u0441\u044f \u0441 Postgres \u0438 Redis. \u042d\u0442\u043e \u043d\u0435 \u043b\u0435\u0447\u0438\u0442\u0441\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043a\u043e\u0434\u0430 \u0442\u0435\u0441\u0442\u043e\u0432; \u0432\u043e\u043f\u0440\u043e\u0441 \u0432 \u0442\u043e\u043c, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u043c\u044b \u0437\u0430 \u044d\u0442\u043e \u043e\u0431\u0449\u0435\u043d\u0438\u0435 \u043f\u043b\u0430\u0442\u0438\u043c.<\/p>\n<p>\u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0437\u0430\u043c\u0435\u0442\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u2014 \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u044b\u0439 setup \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0442\u0435\u0441\u0442\u0435: \u043d\u043e\u0432\u044b\u0439 event loop (5,6 %), \u043d\u043e\u0432\u044b\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f (3,7 %), \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b (1,2 %). \u041d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u0435\u0440\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u041f\u0440\u0438\u0447\u0451\u043c \u0441\u0430\u043c\u0438 \u043f\u0435\u0440\u0435\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0438 <code>CREATE TABLE<\/code> \u0442\u043e\u0436\u0435 \u0438\u0434\u0443\u0442 \u043f\u043e \u0441\u043e\u043a\u0435\u0442\u0443, \u0442\u043e \u0435\u0441\u0442\u044c \u0440\u0430\u0437\u0434\u0443\u0432\u0430\u044e\u0442 \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 64 %. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 <code>create_all<\/code> \u0438 \u043d\u0435 \u0442\u043e\u0440\u0447\u0438\u0442 \u0432 \u043f\u0440\u043e\u0444\u0438\u043b\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u043c \u0441\u0442\u043e\u043b\u0431\u0438\u043a\u043e\u043c \u2014 \u0435\u0433\u043e \u0446\u0435\u043d\u0430 \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d\u0430 \u043f\u043e I\/O.<\/p>\n<p>\u0412-\u0442\u0440\u0435\u0442\u044c\u0438\u0445, \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u0411\u0414 \u0432 \u0442\u043e\u043f\u0435 \u043d\u0435\u0442. \u0421\u043f\u043e\u0441\u043e\u0431 \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 (\u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 <code>TRUNCATE<\/code>) \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u043b \u0432 \u0437\u043d\u0430\u0447\u0438\u043c\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u2014 \u043d\u0430 \u044d\u0442\u043e\u0439, \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041a \u043e\u0447\u0438\u0441\u0442\u043a\u0435 \u0435\u0449\u0451 \u0432\u0435\u0440\u043d\u0451\u043c\u0441\u044f.<\/p>\n<p>\u041f\u043e\u0434\u043e\u0437\u0440\u0435\u0432\u0430\u0435\u043c\u044b\u0439 \u043d\u0430\u0437\u0432\u0430\u043d: \u043c\u044b \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0432\u0435\u0441\u044c \u043c\u0438\u0440 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442. \u0414\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0431\u0443\u0434\u0435\u043c \u0437\u0430\u043c\u0435\u0440\u043e\u043c.<\/p>\n<h3>\u041a\u0430\u043a \u043c\u0435\u0440\u0438\u0442\u044c, \u0447\u0442\u043e\u0431\u044b \u0441\u0435\u0431\u0435 \u043d\u0435 \u0441\u043e\u0432\u0440\u0430\u0442\u044c<\/h3>\n<p>\u0413\u043b\u0430\u0432\u043d\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430 \u2014 \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0435\u0449\u0435\u0439 \u0441\u0440\u0430\u0437\u0443 \u0438 \u0440\u0430\u0434\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e\u0439 \u0446\u0438\u0444\u0440\u0435: \u0442\u0430\u043a \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u043e, \u0430 \u0447\u0442\u043e \u043f\u043b\u0430\u0446\u0435\u0431\u043e. \u041f\u0440\u0430\u0432\u0438\u043b\u0430:<\/p>\n<ul>\n<li>\n<p>\u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044e \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u044f \u043f\u043e \u043e\u0447\u0435\u0440\u0435\u0434\u0438 \u0438 \u0437\u0430\u043c\u0435\u0440\u044f\u044e \u043f\u043e\u0441\u043b\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e;<\/p>\n<\/li>\n<li>\n<p><code>-p no:randomly<\/code> \u2014 \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0441\u0442\u043e\u0438\u0442 <a href=\"https:\/\/github.com\/pytest-dev\/pytest-randomly\" rel=\"noopener noreferrer nofollow\">pytest-randomly<\/a>, \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435 \u0431\u043b\u0430\u0433\u043e, \u0434\u043b\u044f \u0437\u0430\u043c\u0435\u0440\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0448\u0443\u043c;<\/p>\n<\/li>\n<li>\n<p>\u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0433\u043e\u043d\u043e\u0432 \u0438 \u043c\u0435\u0434\u0438\u0430\u043d\u0430: \u043f\u0435\u0440\u0432\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a \u0433\u0440\u0435\u0435\u0442 \u043a\u044d\u0448\u0438, \u0441\u043e\u0441\u0435\u0434 \u0434\u0451\u0440\u043d\u0443\u043b \u0434\u0438\u0441\u043a \u2014 \u0432\u043e\u0442 \u0432\u0430\u043c \u00ab\u0440\u0435\u0433\u0440\u0435\u0441\u0441\u0438\u044f\u00bb \u043d\u0430 \u0440\u043e\u0432\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435;<\/p>\n<\/li>\n<li>\n<p>\u043e\u0442\u043a\u0430\u0442 \u2014 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u043c, \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u2014 <code>git checkout<\/code>. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0430\u0432\u043e\u043a \u0440\u0443\u043a\u0430\u043c\u0438, \u0438\u043d\u0430\u0447\u0435 \u043d\u0435 \u043e\u0442\u043b\u0438\u0447\u0438\u0448\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043e\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u043d\u0435\u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0432\u0441\u0451 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e, \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u0438 \u0442\u043e\u043c \u0436\u0435 \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435, \u043f\u0440\u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u043c\u043e\u0439 \u0444\u043e\u043d\u043e\u0432\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0435. \u0426\u0438\u0444\u0440\u044b \u0438\u0437 CI \u0437\u0434\u0435\u0441\u044c \u043d\u0435 \u0444\u0438\u0433\u0443\u0440\u0438\u0440\u0443\u044e\u0442 \u0441\u043e\u0437\u043d\u0430\u0442\u0435\u043b\u044c\u043d\u043e: \u0440\u0430\u043d\u043d\u0435\u0440\u044b \u0440\u0430\u0437\u043d\u044b\u0435, \u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u0438\u0445 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439 \u0431\u0435\u0441\u0441\u043c\u044b\u0441\u043b\u0435\u043d\u043d\u043e.<\/p>\n<\/li>\n<\/ul>\n<p>\u0423\u0441\u043b\u043e\u0432\u0438\u044f \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430, \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u0441 \u0447\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">Python<\/p>\n<\/td>\n<td>\n<p align=\"left\">3.13<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0424\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a<\/p>\n<\/td>\n<td>\n<p align=\"left\"><a href=\"https:\/\/litestar.dev\/\" rel=\"noopener noreferrer nofollow\">Litestar<\/a> 2.20 (async ASGI), DI \u2014 <a href=\"https:\/\/github.com\/reagento\/dishka\" rel=\"noopener noreferrer nofollow\">Dishka<\/a><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0411\u0414<\/p>\n<\/td>\n<td>\n<p align=\"left\">PostgreSQL 18 \u2014 \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u043e\u0431\u0440\u0430\u0437 \u0432 Docker, \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e; <a href=\"https:\/\/www.sqlalchemy.org\/\" rel=\"noopener noreferrer nofollow\">SQLAlchemy<\/a> 2.0.46 + <a href=\"https:\/\/github.com\/MagicStack\/asyncpg\" rel=\"noopener noreferrer nofollow\">asyncpg<\/a> 0.31, \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 <a href=\"https:\/\/alembic.sqlalchemy.org\/\" rel=\"noopener noreferrer nofollow\">Alembic<\/a><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041a\u044d\u0448 \/ \u0431\u0440\u043e\u043a\u0435\u0440<\/p>\n<\/td>\n<td>\n<p align=\"left\">Redis 8 \u0438 <a href=\"https:\/\/nats.io\/\" rel=\"noopener noreferrer nofollow\">NATS<\/a> 2.10 (<a href=\"https:\/\/github.com\/ag2ai\/faststream\" rel=\"noopener noreferrer nofollow\">FastStream<\/a>) \u2014 \u0442\u043e\u0436\u0435 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0435, \u0432 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u0445<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0422\u0435\u0441\u0442\u044b<\/p>\n<\/td>\n<td>\n<p align=\"left\">pytest 9.0 + <a href=\"https:\/\/pytest-asyncio.readthedocs.io\/\" rel=\"noopener noreferrer nofollow\">pytest-asyncio<\/a> 1.3; 3316 \u0442\u0435\u0441\u0442\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 ASGI-\u0441\u0435\u0440\u0432\u0435\u0440<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0416\u0435\u043b\u0435\u0437\u043e<\/p>\n<\/td>\n<td>\n<p align=\"left\">MacBook Pro (M4 Max, 36 \u0413\u0411); \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u0432 Docker Desktop \u043d\u0430 macOS \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u0432\u043d\u0443\u0442\u0440\u0438 Linux-VM, \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u043f\u043e TCP \u043d\u0430 <a href=\"http:\/\/localhost\" rel=\"noopener noreferrer nofollow\">localhost<\/a><\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u041f\u0440\u043e macOS \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e: Docker \u0437\u0434\u0435\u0441\u044c \u2014 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043c\u0430\u0448\u0438\u043d\u0430, \u0438 \u0432\u0435\u0441\u044c \u0442\u0440\u0430\u0444\u0438\u043a \u0434\u043e \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432 \u0438\u0434\u0451\u0442 \u0447\u0435\u0440\u0435\u0437 \u043f\u0440\u043e\u0431\u0440\u043e\u0441 \u043f\u043e\u0440\u0442\u043e\u0432 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438. \u0414\u043b\u044f I\/O-bound \u0441\u044c\u044e\u0442\u0430 \u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u043a\u043e\u043d\u0441\u0435\u0440\u0432\u0430\u0442\u0438\u0432\u043d\u044b \u2014 \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u043c Linux \u0431\u0443\u0434\u0435\u0442 \u0431\u044b\u0441\u0442\u0440\u0435\u0435. \u041d\u043e \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0448\u0430\u0433\u043e\u0432 \u043e\u0442 \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f, \u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442 \u043d\u0430\u0441 \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u043d\u043e.<\/p>\n<pre><code class=\"python\"># benchmark\/apply_variant.py \u2014 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442def function_scope() -&gt; None:    \"\"\"\u0412\u0435\u0440\u043d\u0443\u0442\u044c \u0432\u0441\u0451 \u043a function-scope \u2014 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 '\u0434\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438'.\"\"\"    replace(        PYPROJECT,        'asyncio_default_fixture_loop_scope = \"session\"',        'asyncio_default_fixture_loop_scope = \"function\"',    )    # ...\u0438 \u0442\u0430\u043a \u0434\u043b\u044f \u0412\u0421\u0415\u0425 session-scoped \u0444\u0438\u043a\u0441\u0442\u0443\u0440 \u0432 plugins\/instances (\u0443 \u043c\u0435\u043d\u044f \u0438\u0445 29).    # \u041f\u043e\u043b\u0443\u043c\u0435\u0440\u044b \u043d\u0435 \u0433\u043e\u0434\u044f\u0442\u0441\u044f: \u043e\u0441\u0442\u0430\u0432\u0438\u0448\u044c \u0445\u043e\u0442\u044c \u043e\u0434\u043d\u0443 session-scoped async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u0443 \u043f\u0440\u0438    # function loop scope \u2014 pytest-asyncio \u043f\u0430\u0434\u0430\u0435\u0442 \u0441\u043e ScopeMismatch \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0442\u0435\u0441\u0442\u0435.<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h3>\u041f\u0440\u0430\u0432\u043a\u0430 1. Session-scope \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b \u0438 \u043e\u0431\u0449\u0438\u0439 event loop<\/h3>\n<p>\u042d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u00ab\u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0432\u0435\u0441\u044c \u043c\u0438\u0440 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442\u00bb. \u0414\u0435\u0444\u043e\u043b\u0442 <code>pytest-asyncio<\/code> \u0441 <code>asyncio_mode = \"auto\"<\/code>: \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 event loop. \u0410 \u0440\u0430\u0437 \u043d\u043e\u0432\u044b\u0439 loop \u2014 \u0437\u0430\u043d\u043e\u0432\u043e \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u043a Postgres, \u043f\u0443\u043b Redis, \u0438\u043d\u0441\u0442\u0430\u043d\u0441 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438, \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u0441\u0445\u0435\u043c\u0430 \u0411\u0414. \u042d\u0442\u043e\u0442 \u043d\u0430\u043b\u043e\u0433 \u043f\u043b\u0430\u0442\u0438\u0442\u0441\u044f 3316 \u0440\u0430\u0437 \u0437\u0430 \u043f\u0440\u043e\u0433\u043e\u043d:<\/p>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ad7\/e19\/b99\/ad7e19b99c291c3a6280002fbfd74957.png\" alt=\"\u0414\u043e: \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043f\u043b\u0430\u0442\u0438\u0442 \u0437\u0430 event loop, \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0438 \u0441\u0445\u0435\u043c\u0443; \u043f\u043e\u0441\u043b\u0435: \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043d\u0430 \u043f\u0440\u043e\u0433\u043e\u043d\" width=\"1560\" height=\"795\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/ad7\/e19\/b99\/ad7e19b99c291c3a6280002fbfd74957.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ad7\/e19\/b99\/ad7e19b99c291c3a6280002fbfd74957.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u0414\u043e: \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043f\u043b\u0430\u0442\u0438\u0442 \u0437\u0430 event loop, \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0438 \u0441\u0445\u0435\u043c\u0443; \u043f\u043e\u0441\u043b\u0435: \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043d\u0430 \u043f\u0440\u043e\u0433\u043e\u043d<\/figcaption><\/div>\n<\/figure>\n<p>\u041b\u0435\u0447\u0438\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u043e\u0439 \u0438 <code>scope=\"session\"<\/code> \u043d\u0430 \u0434\u043e\u0440\u043e\u0433\u0438\u0445 \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u0430\u0445:<\/p>\n<pre><code># pyproject.toml[tool.pytest.ini_options]asyncio_mode = \"auto\"asyncio_default_fixture_loop_scope = \"session\"asyncio_default_test_loop_scope = \"session\"<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<pre><code class=\"python\">@pytest.fixture(scope=\"session\")async def engine(db_config: DatabaseConfig) -&gt; AsyncIterator[AsyncEngine]:    # create_engine \u2014 \u043d\u0430\u0448\u0430 \u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u043d\u0430\u0434 create_async_engine (\u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u044b\u0439 \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440)    async with create_engine(dsn=str(db_config.dsn), ...) as engine:        async with engine.begin() as conn:            await conn.run_sync(BaseTable.metadata.drop_all)            await conn.run_sync(BaseTable.metadata.create_all)        yield engine                       # \u0441\u0445\u0435\u043c\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u041e\u0414\u0418\u041d \u0440\u0430\u0437 \u043d\u0430 \u0441\u0435\u0441\u0441\u0438\u044e<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u043e\u0434\u0432\u043e\u0445: session-scope async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b \u0442\u0435\u043f\u0435\u0440\u044c \u0436\u0438\u0432\u0443\u0442 \u0432\u0435\u0441\u044c \u043f\u0440\u043e\u0433\u043e\u043d, \u0438 \u0435\u0441\u043b\u0438 \u0432 \u043d\u0438\u0445 \u043a\u043e\u043f\u0438\u0442\u0441\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u2014 \u043e\u043d\u043e \u043f\u0440\u043e\u0442\u0435\u0447\u0451\u0442 \u0432\u043e \u0432\u0441\u0435 \u0442\u0435\u0441\u0442\u044b. \u0418\u0437\u043e\u043b\u044f\u0446\u0438\u044e \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u0435\u043b\u0430\u0435\u043c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u043e\u0447\u0438\u0441\u0442\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438, \u0430 \u043d\u0435 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435\u043c \u0432\u0441\u0435\u0433\u043e \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f.<\/p>\n<p>\u0417\u0430\u043c\u0435\u0440: <strong>1795 \u0441 (\u224830 \u043c\u0438\u043d) \u2192 221 \u0441<\/strong>. \u041c\u0438\u043d\u0443\u0441 88 %, \u0432 8 \u0440\u0430\u0437. \u041d\u0438 \u043e\u0434\u0438\u043d \u0442\u0435\u0441\u0442 \u043d\u0435 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043d \u2014 \u043c\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u043b\u0438 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435 3316 \u0440\u0430\u0437. \u041f\u043e \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u044e \u0446\u0435\u043d\u044b \u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u044d\u0442\u043e, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0441\u0430\u043c\u0430\u044f \u043d\u0435\u0434\u043e\u043e\u0446\u0435\u043d\u0451\u043d\u043d\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u0434\u043b\u044f async-\u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432.<\/p>\n<h3>\u041f\u0440\u0430\u0432\u043a\u0430 2. TRUNCATE \u2192 DELETE: \u043a\u043e\u043d\u0442\u0440\u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u044e\u0440\u043f\u0440\u0438\u0437<\/h3>\n<p>\u041e\u0447\u0438\u0441\u0442\u043a\u0430 \u0411\u0414 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0431\u044b\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u043d\u0430 \u00ab\u043a\u0430\u043a \u043f\u0440\u0438\u043d\u044f\u0442\u043e\u00bb \u2014 \u043e\u0434\u043d\u0438\u043c <code>TRUNCATE ... RESTART IDENTITY CASCADE<\/code> \u043d\u0430 \u0432\u0441\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u041e\u0434\u0438\u043d \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u0440\u0438\u0434\u0446\u0430\u0442\u0438, \u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0436\u0435. \u041d\u0430 \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u0435\u0451 \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u043b \u2014 \u043e\u043d\u0430 \u0442\u043e\u043d\u0443\u043b\u0430 \u0432 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f.<\/p>\n<p>\u041d\u043e \u043f\u0440\u043e\u0433\u043e\u043d \u0443\u0436\u0435 \u043d\u0435 30 \u043c\u0438\u043d\u0443\u0442, \u0430 \u0442\u0440\u0438 \u0441 \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u043e\u0439. \u041f\u0435\u0440\u0435\u043c\u0435\u0440\u044f\u044e \u2014 \u0438 \u0442\u0435\u043f\u0435\u0440\u044c, \u043a\u043e\u0433\u0434\u0430 \u043a\u0440\u0443\u043f\u043d\u043e\u0435 \u0443\u0431\u0440\u0430\u043d\u043e, \u043e\u0447\u0438\u0441\u0442\u043a\u0430 \u0441\u0442\u0430\u043b\u0430 \u0437\u0430\u043c\u0435\u0442\u043d\u043e\u0439 \u0434\u043e\u043b\u0435\u0439. \u041f\u0440\u043e\u0431\u0443\u044e \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u043e\u0434\u0438\u043d <code>TRUNCATE<\/code> \u043d\u0430 \u043f\u0430\u0447\u043a\u0443 <code>DELETE<\/code> \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438:<\/p>\n<pre><code class=\"python\"># \u0431\u044b\u043b\u043e: \u043e\u0434\u0438\u043d TRUNCATE ... CASCADE \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442# \u0441\u0442\u0430\u043b\u043e: DELETE \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0432 \u043f\u043e\u0440\u044f\u0434\u043a\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439, \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438_DELETE_STATEMENTS = tuple(    text(f'DELETE FROM \"{t.name}\"') for t in reversed(BaseTable.metadata.sorted_tables))<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0417\u0430\u043c\u0435\u0440: <strong>221 \u0441 \u2192 125 \u0441 (\u221243 %)<\/strong>. \u0422\u0440\u0438\u0434\u0446\u0430\u0442\u044c <code>DELETE<\/code> \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0437\u0430\u043c\u0435\u0442\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u043e\u0434\u043d\u043e\u0433\u043e <code>TRUNCATE<\/code>. \u041c\u0430\u043b\u043e \u0442\u043e\u0433\u043e, TRUNCATE \u0431\u044b\u043b \u0435\u0449\u0451 \u0438 \u0434\u0438\u043a\u0438\u043c \u043f\u043e \u0440\u0430\u0437\u0431\u0440\u043e\u0441\u0443: \u043e\u0442 \u043f\u0440\u043e\u0433\u043e\u043d\u0430 \u043a \u043f\u0440\u043e\u0433\u043e\u043d\u0443 \u0434\u0430\u0432\u0430\u043b \u043e\u0442 152 \u0434\u043e 254 \u0441\u0435\u043a\u0443\u043d\u0434 (\u0441\u043c. CSV \u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438), \u0442\u043e\u0433\u0434\u0430 \u043a\u0430\u043a DELETE \u0434\u0435\u0440\u0436\u0430\u043b\u0441\u044f \u0440\u043e\u0432\u043d\u043e, \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u0435\u043a\u0443\u043d\u0434.<\/p>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u0442\u0430\u043a. <a href=\"https:\/\/www.postgresql.org\/docs\/current\/sql-truncate.html\" rel=\"noopener noreferrer nofollow\"><code>TRUNCATE<\/code><\/a> \u2014 \u044d\u0442\u043e \u043d\u0435 \u00ab\u0431\u044b\u0441\u0442\u0440\u044b\u0439 DELETE\u00bb, \u0430 DDL-\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f: \u043e\u043d\u0430 \u0431\u0435\u0440\u0451\u0442 <code>ACCESS EXCLUSIVE<\/code> \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0443 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u0441 <code>CASCADE<\/code> \u043e\u0431\u0445\u043e\u0434\u0438\u0442 \u0434\u0435\u0440\u0435\u0432\u043e \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439, \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043d\u043e\u0432\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442 \u043a\u0430\u0442\u0430\u043b\u043e\u0433 \u2014 \u0438 \u0442\u0430\u043a \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0438\u0437 3316 \u0432\u044b\u0437\u043e\u0432\u043e\u0432. \u0421\u0442\u043e\u0438\u043c\u043e\u0441\u0442\u044c \u044d\u0442\u043e\u0433\u043e \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u0438 \u0444\u0430\u0439\u043b\u043e\u0432\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u2014 \u043e\u0442\u0441\u044e\u0434\u0430 \u0438 \u043d\u0435\u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0441\u0442\u044c. <code>DELETE<\/code> \u0438\u0437 \u043f\u043e\u0447\u0442\u0438 \u043f\u0443\u0441\u0442\u044b\u0445 \u0442\u0430\u0431\u043b\u0438\u0446 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u2014 \u044d\u0442\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0443\u043b\u044f \u0441\u0442\u0440\u043e\u043a: \u0434\u0451\u0448\u0435\u0432\u043e \u0438 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e.<\/p>\n<p>\u0412\u0430\u0436\u043d\u0430\u044f \u043e\u0433\u043e\u0432\u043e\u0440\u043a\u0430: \u044d\u0442\u043e \u043d\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u043e\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u00abDELETE \u0431\u044b\u0441\u0442\u0440\u0435\u0435 TRUNCATE\u00bb. \u041d\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 \u0441 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430\u043c\u0438 \u0441\u0442\u0440\u043e\u043a TRUNCATE \u0432\u044b\u0438\u0433\u0440\u0430\u0435\u0442 \u0441 \u0440\u0430\u0437\u0433\u0440\u043e\u043c\u043d\u044b\u043c \u0441\u0447\u0451\u0442\u043e\u043c \u2014 \u043e\u043d \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0438 \u0441\u0434\u0435\u043b\u0430\u043d. \u041c\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u2014 \u043f\u0440\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0439: \u043e\u0447\u0438\u0441\u0442\u043a\u0430 \u043f\u043e\u0447\u0442\u0438 \u043f\u0443\u0441\u0442\u044b\u0445 \u0442\u0430\u0431\u043b\u0438\u0446, \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u043c\u0430\u044f \u0442\u044b\u0441\u044f\u0447\u0438 \u0440\u0430\u0437 \u043f\u043e\u0434\u0440\u044f\u0434. \u0417\u0434\u0435\u0441\u044c \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b TRUNCATE (\u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0438, \u043a\u0430\u0442\u0430\u043b\u043e\u0433, \u0444\u0430\u0439\u043b\u044b) \u043f\u043b\u0430\u0442\u044f\u0442\u0441\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0432\u044b\u0437\u043e\u0432\u0435, \u0430 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c DELETE \u2014 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0441\u0442\u0440\u043e\u043a \u2014 \u043f\u043e\u0447\u0442\u0438 \u043d\u0443\u043b\u0435\u0432\u0430\u044f. \u0412\u0435\u0440\u0441\u0438\u0438 \u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f \u0441\u0442\u0435\u043d\u0434\u0430 \u2014 \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 \u0432\u044b\u0448\u0435.<\/p>\n<p>\u041e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0443\u0440\u043e\u043a \u2014 \u043f\u0440\u043e \u0438\u0442\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c. \u041d\u0430 \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 \u044d\u0442\u0430 \u043f\u0440\u0430\u0432\u043a\u0430 \u043d\u0435 \u0434\u0430\u043b\u0430 \u0431\u044b \u043d\u0438\u0447\u0435\u0433\u043e: \u0435\u0451 \u0432\u044b\u0438\u0433\u0440\u044b\u0448 \u0443\u0442\u043e\u043d\u0443\u043b \u0431\u044b \u0432 \u043f\u043e\u043b\u0443\u0447\u0430\u0441\u043e\u0432\u043e\u043c \u043f\u0440\u043e\u0433\u043e\u043d\u0435 \u043a\u0430\u043a \u0448\u0443\u043c, \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u0435\u0433\u043e \u0438 \u043d\u0435 \u0432\u0438\u0434\u0435\u043b. \u041e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043c\u0435\u043d\u044f\u0435\u0442 \u0442\u043e, \u0447\u0442\u043e \u0432\u0430\u0436\u043d\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043c\u0435\u0440\u0438\u0442\u044c \u043d\u0430\u0434\u043e \u043f\u043e\u0441\u043b\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043a\u0440\u0443\u043f\u043d\u043e\u0433\u043e \u0448\u0430\u0433\u0430, \u0430 \u043d\u0435 \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0432 \u043d\u0430\u0447\u0430\u043b\u0435.<\/p>\n<h3>\u041f\u0440\u0430\u0432\u043a\u0430 3. \u0411\u044b\u0441\u0442\u0440\u044b\u0439 argon2 \u2014 \u0434\u043e\u0431\u0438\u0432\u0430\u0435\u043c \u043e\u0441\u0442\u0430\u0442\u043e\u043a<\/h3>\n<p>\u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435, \u0447\u0442\u043e \u043f\u043e\u0434\u0441\u0432\u0435\u0442\u0438\u043b \u043f\u0440\u043e\u0444\u0438\u043b\u044c, \u2014 \u043a\u0440\u0438\u043f\u0442\u043e\u0433\u0440\u0430\u0444\u0438\u044f. <a href=\"https:\/\/github.com\/P-H-C\/phc-winner-argon2\" rel=\"noopener noreferrer nofollow\">argon2<\/a> \u043d\u0430\u043c\u0435\u0440\u0435\u043d\u043d\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0439, \u044d\u0442\u043e \u0435\u0433\u043e \u0440\u0430\u0431\u043e\u0442\u0430: \u043e\u0434\u0438\u043d \u0445\u0435\u0448 \u043d\u0430 \u0431\u043e\u0435\u0432\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u0445 \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434, \u0438 \u0434\u043b\u044f \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d\u0430 \u044d\u0442\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e. \u041d\u043e \u0432 \u0442\u0435\u0441\u0442\u0430\u0445 \u043a\u0440\u0438\u043f\u0442\u043e\u0441\u0442\u043e\u0439\u043a\u043e\u0441\u0442\u044c \u043d\u0435 \u043d\u0443\u0436\u043d\u0430 \u2014 \u043d\u0443\u0436\u0435\u043d round-trip \u00ab\u0437\u0430\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u2192 \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043b\u0438\u00bb, \u0430 \u0442\u0435\u0441\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u043e\u0437\u0434\u0430\u044e\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0438 \u043b\u043e\u0433\u0438\u043d\u044f\u0442\u0441\u044f, \u043e\u0447\u0435\u043d\u044c \u043c\u043d\u043e\u0433\u043e.<\/p>\n<p>\u0421\u0431\u0438\u0432\u0430\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0434\u043e \u043c\u0438\u043d\u0438\u043c\u0443\u043c\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u043e\u0432:<\/p>\n<pre><code class=\"python\"># tests\/conftest.pyimport passlib.hashpasslib.hash.argon2.default_rounds = 1passlib.hash.argon2.default_memory_cost = 8passlib.hash.argon2.default_parallelism = 1<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>(\u0414\u0430, <a href=\"https:\/\/passlib.readthedocs.io\/\" rel=\"noopener noreferrer nofollow\">passlib<\/a> \u0434\u0430\u0432\u043d\u043e \u043d\u0435 \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u2014 \u043c\u044b \u0432 \u043a\u0443\u0440\u0441\u0435 \u0438 \u0432 \u043f\u0440\u043e\u0434\u0435 \u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b; \u043d\u0430 \u043c\u0435\u0445\u0430\u043d\u0438\u043a\u0443 \u044d\u0442\u043e\u0439 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u044d\u0442\u043e \u043d\u0435 \u0432\u043b\u0438\u044f\u0435\u0442, \u0442\u043e\u0442 \u0436\u0435 \u043f\u0440\u0438\u0451\u043c \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441 \u043b\u044e\u0431\u043e\u0439 \u043e\u0431\u0451\u0440\u0442\u043a\u043e\u0439 \u043d\u0430\u0434 argon2\/bcrypt.)<\/p>\n<p>\u0417\u0430\u043c\u0435\u0440: <strong>125 \u0441 \u2192 109 \u0441 (\u221213 %)<\/strong>. \u041d\u0435\u043c\u043d\u043e\u0433\u043e, \u043d\u043e \u044d\u0442\u043e \u0431\u0435\u0441\u043f\u043b\u0430\u0442\u043d\u044b\u0435 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u043f\u0440\u043e\u0433\u043e\u043d\u0435, \u043e\u0434\u043d\u043e\u0439 \u043f\u0440\u0430\u0432\u043a\u043e\u0439 \u0432 <code>conftest.py<\/code>.<\/p>\n<h3>\u0427\u0435\u0433\u043e \u0437\u0434\u0435\u0441\u044c \u043d\u0435\u0442 \u2014 \u0438 \u043f\u043e\u0447\u0435\u043c\u0443<\/h3>\n<p>\u0422\u0440\u0438 \u0432\u0435\u0449\u0438, \u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u044b, \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0443\u0436\u0435 \u0445\u043e\u0442\u0438\u0442\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445.<\/p>\n<p><strong>\u0422\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044f \u0441 rollback \u0432\u043c\u0435\u0441\u0442\u043e \u043e\u0447\u0438\u0441\u0442\u043a\u0438.<\/strong> \u041a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d: \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u0432 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0432 \u043a\u043e\u043d\u0446\u0435 rollback, \u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043d\u0430\u0434\u043e. \u041d\u0430\u043c \u043e\u043d \u043d\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 \u043e\u0441\u043e\u0437\u043d\u0430\u043d\u043d\u043e: \u0447\u0430\u0441\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u043f\u043e\u043b\u043d\u044b\u0439 \u043f\u0443\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u0440\u043e\u0443\u0442\u044b \u0438 \u0445\u0435\u043d\u0434\u043b\u0435\u0440\u044b \u0441 \u0447\u0435\u0441\u0442\u043d\u044b\u043c \u043a\u043e\u043c\u043c\u0438\u0442\u043e\u043c \u2014 \u0438 \u0437\u0430\u0442\u0435\u043c \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442, \u0447\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043b\u0435\u0433\u043b\u0438 \u0432 \u0411\u0414. \u0417\u0430\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0442\u044c \u0432\u0441\u0451 \u0432 \u043e\u0434\u043d\u0443 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u043a\u043e\u043c\u043c\u0438\u0442\u044f\u0449\u0443\u044e\u0441\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044e \u043e\u0437\u043d\u0430\u0447\u0430\u043b\u043e \u0431\u044b \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435 \u0442\u043e \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 \u043f\u0440\u043e\u0434\u0435. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0442\u0430\u043a\u0438\u0445 \u0442\u0435\u0441\u0442\u043e\u0432 \u043d\u0435\u0442 \u2014 rollback-\u043f\u0430\u0442\u0442\u0435\u0440\u043d \u0441\u0442\u043e\u0438\u0442 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u043d\u044c\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0433\u043e.<\/p>\n<p><code><strong>fsync = off<\/strong><\/code><strong> \/ <\/strong><code><strong>synchronous_commit = off<\/strong><\/code><strong> \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u0433\u043e Postgres.<\/strong> <a href=\"https:\/\/www.postgresql.org\/docs\/current\/non-durability.html\" rel=\"noopener noreferrer nofollow\">\u0418\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431<\/a> \u0441\u0440\u0435\u0437\u0430\u0442\u044c \u0441\u0442\u043e\u0438\u043c\u043e\u0441\u0442\u044c \u043a\u043e\u043c\u043c\u0438\u0442\u043e\u0432, \u0438 \u0447\u0442\u043e \u043e\u043d \u0434\u0430\u0451\u0442 \u2014 \u044f \u0437\u043d\u0430\u044e \u043d\u0435 \u043f\u043e\u043d\u0430\u0441\u043b\u044b\u0448\u043a\u0435: \u043d\u0435\u0434\u0430\u0432\u043d\u043e \u043d\u0430 \u043a\u0443\u0440\u0441\u0435 \u043f\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 Postgres \u0434\u0435\u043b\u0430\u043b \u0434\u043e\u043c\u0430\u0448\u043a\u0443 \u0441 \u043d\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u044b\u043c\u0438 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u043d\u0430 Raspberry Pi (\u0434\u0430, \u0438\u0437\u0432\u0440\u0430\u0442, \u043d\u043e \u0447\u0442\u043e \u0432\u044b \u043c\u043d\u0435 \u0441\u0434\u0435\u043b\u0430\u0435\u0442\u0435). \u041d\u0430 microSD-\u043a\u0430\u0440\u0442\u0435, \u0433\u0434\u0435 \u043a\u0430\u0436\u0434\u044b\u0439 \u043a\u043e\u043c\u043c\u0438\u0442 \u0447\u0435\u0441\u0442\u043d\u043e \u0436\u0434\u0451\u0442 \u0437\u0430\u043f\u0438\u0441\u0438 WAL, \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 fsync \u043f\u043e\u0434\u043d\u044f\u043b\u043e \u043f\u0438\u0448\u0443\u0449\u0438\u0439 TPC-B \u0432 2,4\u20132,9 \u0440\u0430\u0437\u0430, \u0430 latency \u043e\u0434\u0438\u043d\u043e\u0447\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u0443\u043f\u0430\u043b\u0430 \u0441 3,7 \u0434\u043e 1,55 \u043c\u0441 \u2014 <a href=\"https:\/\/github.com\/andy-takker\/pg-optimization\/tree\/main\/hw01\" rel=\"noopener noreferrer nofollow\">\u0437\u0430\u043c\u0435\u0440\u044b \u0438 \u0433\u0440\u0430\u0444\u0438\u043a\u0438 \u0442\u0443\u0442<\/a>. \u041d\u043e \u044d\u0442\u043e \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u043f\u0440\u043e \u0442\u043e, \u0447\u0442\u043e \u0431\u044b\u0432\u0430\u0435\u0442, \u043a\u043e\u0433\u0434\u0430 \u0443\u043f\u0438\u0440\u0430\u0435\u0448\u044c\u0441\u044f \u0432 \u0434\u0438\u0441\u043a. \u041d\u0430\u0448 \u0441\u044c\u044e\u0442 \u043f\u043e\u0441\u043b\u0435 \u043f\u0440\u0430\u0432\u043e\u043a 1\u20133 \u0432 \u0434\u0438\u0441\u043a \u043d\u0435 \u0443\u043f\u0438\u0440\u0430\u043b\u0441\u044f, \u0430 \u043c\u0435\u043d\u044f\u0442\u044c \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0421\u0423\u0411\u0414 \u043f\u043e\u0434 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u043d\u0435 \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u2014 \u043f\u0443\u0441\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432\u0430\u044f \u0431\u0430\u0437\u0430 \u0432\u0435\u0434\u0451\u0442 \u0441\u0435\u0431\u044f \u043a\u0430\u043a \u0431\u043e\u0435\u0432\u0430\u044f. \u0415\u0441\u043b\u0438 \u0436\u0435 \u0432\u0430\u0448\u0438 \u0442\u0435\u0441\u0442\u044b \u0442\u043e\u043d\u0443\u0442 \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u043a\u043e\u043c\u043c\u0438\u0442\u0430\u0445 \u2014 \u044d\u0442\u043e \u0437\u0430\u043a\u043e\u043d\u043d\u044b\u0439 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u043d\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u0437\u0430\u043c\u0435\u0440\u043e\u043c.<\/p>\n<p><strong>\u041f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a, <\/strong><a href=\"https:\/\/pytest-xdist.readthedocs.io\/\" rel=\"noopener noreferrer nofollow\"><strong>pytest-xdist<\/strong><\/a><strong>.<\/strong> \u0421\u0430\u043c\u044b\u0439 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u0439 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u2014 \u0438 \u043e\u043d \u0443 \u043d\u0430\u0441 \u0432 \u0440\u0430\u0431\u043e\u0442\u0435. \u0422\u0430\u043c \u0441\u0432\u043e\u0438 \u0433\u0440\u0430\u0431\u043b\u0438: \u0432\u043e\u0440\u043a\u0435\u0440\u0430\u043c \u043d\u0443\u0436\u043d\u044b \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0411\u0414, \u0431\u0440\u043e\u043a\u0435\u0440 \u0438 Redis, \u0438\u043d\u0430\u0447\u0435 \u0442\u0435\u0441\u0442\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0432\u0438\u0434\u0435\u0442\u044c \u0447\u0443\u0436\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0435. \u041a\u043e\u0433\u0434\u0430 \u0434\u043e\u0432\u0435\u0434\u0451\u043c \u0434\u043e \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u0438 \u0437\u0430\u043c\u0435\u0440\u0438\u043c, \u0431\u0443\u0434\u0435\u0442 \u0432\u0442\u043e\u0440\u0430\u044f \u0447\u0430\u0441\u0442\u044c.<\/p>\n<h3>\u0418\u0442\u043e\u0433<\/h3>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">\u0428\u0430\u0433<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0421\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0412\u0440\u0435\u043c\u044f<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u041f\u0440\u0438\u0440\u043e\u0441\u0442<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">0<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0431\u0435\u0437 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0439: function-scope + \u0431\u043e\u0435\u0432\u043e\u0439 argon2 + TRUNCATE<\/p>\n<\/td>\n<td>\n<p align=\"left\"><strong>1795 \u0441 (\u224830 \u043c\u0438\u043d)<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u2014<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">1<\/p>\n<\/td>\n<td>\n<p align=\"left\">+ session-scope \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b \u0438 \u043e\u0431\u0449\u0438\u0439 loop<\/p>\n<\/td>\n<td>\n<p align=\"left\">221 \u0441<\/p>\n<\/td>\n<td>\n<p align=\"left\"><strong>\u221288 % (\u00d78)<\/strong><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">2<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0437\u0430\u043c\u0435\u043d\u0430 TRUNCATE \u2192 DELETE<\/p>\n<\/td>\n<td>\n<p align=\"left\">125 \u0441<\/p>\n<\/td>\n<td>\n<p align=\"left\"><strong>\u221243 %<\/strong><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">3<\/p>\n<\/td>\n<td>\n<p align=\"left\">+ \u0431\u044b\u0441\u0442\u0440\u044b\u0439 argon2 \u0432 \u0442\u0435\u0441\u0442\u0430\u0445<\/p>\n<\/td>\n<td>\n<p align=\"left\"><strong>109 \u0441 (\u22481,8 \u043c\u0438\u043d)<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u221213 %<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/333\/d97\/d0b\/333d97d0b0738299a76fd20c9523fad5.png\" alt=\"\u0412\u043a\u043b\u0430\u0434 \u043a\u0430\u0436\u0434\u043e\u0439 \u043f\u0440\u0430\u0432\u043a\u0438 \u0432 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0433\u043e\u043d\u0430\" width=\"1457\" height=\"693\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/333\/d97\/d0b\/333d97d0b0738299a76fd20c9523fad5.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/333\/d97\/d0b\/333d97d0b0738299a76fd20c9523fad5.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u0412\u043a\u043b\u0430\u0434 \u043a\u0430\u0436\u0434\u043e\u0439 \u043f\u0440\u0430\u0432\u043a\u0438 \u0432 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0433\u043e\u043d\u0430<\/figcaption><\/div>\n<\/figure>\n<p>\u0418\u0437 \u043f\u043e\u043b\u0443\u0447\u0430\u0441\u0430 \u0434\u043e \u043f\u043e\u043b\u0443\u0442\u043e\u0440\u0430 \u043c\u0438\u043d\u0443\u0442 \u2014 \u00d716,5, \u0438 \u043b\u044c\u0432\u0438\u043d\u0430\u044f \u0434\u043e\u043b\u044f \u0432\u044b\u0438\u0433\u0440\u044b\u0448\u0430 \u0432 \u043e\u0434\u043d\u043e\u0439 \u043f\u0440\u0430\u0432\u043a\u0435 \u043f\u0440\u043e scope \u0444\u0438\u043a\u0441\u0442\u0443\u0440. \u0421\u0430\u043c\u0430\u044f \u0434\u043e\u0440\u043e\u0433\u0430\u044f \u0432\u0435\u0449\u044c \u0432 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0442\u0435\u0441\u0442\u0430\u0445 \u2014 \u043d\u0435 \u0441\u0430\u043c\u0430 \u0411\u0414, \u0430 \u0442\u043e, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u0437\u0430 \u043f\u0440\u043e\u0433\u043e\u043d \u0432\u044b \u0437\u0430\u043d\u043e\u0432\u043e \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0435 \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435: event loop, \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u0441\u0445\u0435\u043c\u0443. Session-scope \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u00ab\u0437\u0430\u043f\u043b\u0430\u0442\u0438 \u0437\u0430 \u0432\u0445\u043e\u0434 3316 \u0440\u0430\u0437\u00bb \u0432 \u00ab\u0437\u0430\u043f\u043b\u0430\u0442\u0438 \u043e\u0434\u0438\u043d \u0440\u0430\u0437\u00bb. \u0410 \u0441\u043f\u043e\u0441\u043e\u0431 \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u0432\u0438\u0434\u0435\u043d \u0438 \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u043d\u0430 \u043f\u0435\u0440\u0432\u044b\u0439 \u043f\u043b\u0430\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043a\u0440\u0443\u043f\u043d\u043e\u0435 \u0443\u0431\u0440\u0430\u043d\u043e \u2014 \u0438 \u0442\u0430\u043c \u00ab\u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u0439\u00bb TRUNCATE \u043f\u0440\u043e\u0438\u0433\u0440\u044b\u0432\u0430\u0435\u0442 \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 DELETE.<\/p>\n<p>\u0427\u0435\u043a-\u043b\u0438\u0441\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0433\u043d\u0430\u0442\u044c \u043d\u0430 \u0441\u0432\u043e\u0451\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0437\u0430 \u0432\u0435\u0447\u0435\u0440:<\/p>\n<ol>\n<li>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u0440\u043e\u0444\u0438\u043b\u044c, \u043f\u043e\u0442\u043e\u043c \u043f\u0440\u0430\u0432\u043a\u0438. <code>--durations<\/code> \u2192 \u0435\u0441\u043b\u0438 \u0432\u0438\u043d\u043e\u0432\u0430\u0442\u043e\u0433\u043e \u0442\u0435\u0441\u0442\u0430 \u043d\u0435\u0442, \u0443 \u0432\u0430\u0441 \u0440\u043e\u0432\u043d\u044b\u0439 \u043d\u0430\u043b\u043e\u0433 \u043d\u0430 \u0432\u0445\u043e\u0434, \u0438 \u0447\u0438\u043d\u0438\u0442\u044c \u043d\u0430\u0434\u043e scope, \u0430 \u043d\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0442\u0435\u0441\u0442\u044b. \u0414\u0430\u043b\u044c\u0448\u0435 \u2014 cProfile (\u0438\u043b\u0438 py-spy) \u043d\u0430 \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438: \u043d\u0430 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 \u043e\u043d \u043f\u043e\u043a\u0430\u0436\u0435\u0442 \u0441\u043a\u0443\u0447\u043d\u043e\u0435 \u00ab\u0436\u0434\u0451\u043c \u0441\u0435\u0442\u044c\u00bb \u0438 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u0434\u0441\u043a\u0430\u0436\u0435\u0442.<\/p>\n<\/li>\n<li>\n<p>\u0411\u043e\u043b\u044c\u0448\u043e\u0439 \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u043d\u0435 \u0447\u0438\u0442\u0430\u0439\u0442\u0435 \u0433\u043b\u0430\u0437\u0430\u043c\u0438. \u0413\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0430\u043c (snakeviz, gprof2dot, LLM \u2014 \u0447\u0442\u043e \u0432\u0430\u043c \u0431\u043b\u0438\u0436\u0435) \u2192 \u0442\u043e\u043f \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u043e\u0432 \u2192 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0437\u0430\u043c\u0435\u0440\u043e\u043c. \u041f\u0440\u043e\u0444\u0430\u0439\u043b\u0435\u0440 \u043d\u0430\u0445\u043e\u0434\u0438\u0442, \u0437\u0430\u043c\u0435\u0440 \u0434\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442.<\/p>\n<\/li>\n<li>\n<p>Event loop \u0438 scope \u0444\u0438\u043a\u0441\u0442\u0443\u0440 \u2014 \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c. \u0414\u043b\u044f async-\u043f\u0440\u043e\u0435\u043a\u0442\u0430 <code>*_loop_scope = \"session\"<\/code> \u0438 <code>scope=\"session\"<\/code> \u043d\u0430 \u0434\u043e\u0440\u043e\u0433\u0438\u0445 \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u0445 \u2014 \u043e\u0434\u043d\u043e\u0441\u0442\u0440\u043e\u0447\u043d\u0438\u043a\u0438 \u0441 \u0441\u0430\u043c\u044b\u043c \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0432\u044b\u0438\u0433\u0440\u044b\u0448\u0435\u043c.<\/p>\n<\/li>\n<li>\n<p>\u0421\u0431\u0435\u0439\u0442\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043a\u0440\u0438\u043f\u0442\u043e\u0445\u0435\u0448\u0430 \u0432 \u0442\u0435\u0441\u0442\u0430\u0445. argon2\/bcrypt \u043d\u0430 \u0431\u043e\u0435\u0432\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u0445 \u2014 \u0441\u043e\u0436\u0436\u0451\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u043b\u043e\u0433\u0438\u043d\u0435.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0435\u043d\u044f\u0439\u0442\u0435 \u043f\u043e \u043e\u0434\u043d\u043e\u0439 \u0432\u0435\u0449\u0438, \u043c\u0435\u0434\u0438\u0430\u043d\u0430 \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u0440\u043e\u0433\u043e\u043d\u043e\u0432, <code>-p no:randomly<\/code>, \u043e\u0434\u043d\u043e \u0438 \u0442\u043e \u0436\u0435 \u0436\u0435\u043b\u0435\u0437\u043e. \u0418\u043d\u0430\u0447\u0435 \u043b\u044e\u0431\u044b\u0435 \u00ab\u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f\u00bb \u2014 \u0448\u0443\u043c.<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u043c\u043e\u043a\u0430\u0442\u044c \u0431\u0430\u0437\u0443 \u00ab\u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u00bb \u2014 \u043f\u043e\u043c\u0435\u0440\u044f\u0439\u0442\u0435. \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0431\u0430\u0437\u0430 \u043d\u0438 \u043f\u0440\u0438 \u0447\u0451\u043c.<\/p>\n<\/li>\n<\/ol>\n<p>\u0421\u043a\u0440\u0438\u043f\u0442\u044b \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0430 \u2014 <code>apply_variant.py<\/code> (\u0442\u043e\u0447\u0435\u0447\u043d\u044b\u0439 \u043e\u0442\u043a\u0430\u0442 \u043a\u0430\u0436\u0434\u043e\u0439 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438), <code>run.sh<\/code> (\u043f\u0440\u043e\u0433\u043e\u043d\u044b \u0441 \u0437\u0430\u043f\u0438\u0441\u044c\u044e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432 CSV) \u0438 \u0441\u044b\u0440\u044b\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u2014 \u043b\u0435\u0436\u0430\u0442 \u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438: <a href=\"https:\/\/github.com\/andy-takker\/slow-tests-benchmark\" rel=\"noopener noreferrer nofollow\">andy-takker\/slow-tests-benchmark<\/a>. \u041a\u0430\u0436\u0434\u044b\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u043e\u0442\u043a\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0447\u0435\u0440\u0435\u0437 <code>git checkout<\/code>, \u0442\u0430\u043a \u0447\u0442\u043e \u043f\u0435\u0440\u0435\u043c\u0435\u0440\u0438\u0442\u044c \u0443 \u0441\u0435\u0431\u044f \u043c\u043e\u0436\u043d\u043e \u0437\u0430 \u0432\u0435\u0447\u0435\u0440.<\/p>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1045923\/\">https:\/\/habr.com\/ru\/articles\/1045923\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0414\u0438\u0441\u043a\u043b\u0435\u0439\u043c\u0435\u0440. \u042d\u0442\u043e \u043d\u0435 \u00ab\u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0432\u0435\u0440\u043d\u044b\u0439 \u043f\u0443\u0442\u044c\u00bb, \u0430 \u043a\u0435\u0439\u0441 \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430: \u0431\u044d\u043a\u0435\u043d\u0434 \u043d\u0430 Litestar + SQLAlchemy + Postgres + Redis, 3316 \u0442\u0435\u0441\u0442\u043e\u0432, \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435, \u0445\u043e\u0434\u044f\u0442 \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0411\u0414. \u0412\u0441\u0435 \u0437\u0430\u043c\u0435\u0440\u044b \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435, \u043d\u0430 \u043c\u043e\u0451\u043c \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435 \u2014 \u043d\u0435 \u0432 CI. \u0420\u0430\u043d\u043d\u0435\u0440\u043e\u0432 \u0443 \u043d\u0430\u0441 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438 \u043e\u043d\u0438 \u0440\u0430\u0437\u043d\u044b\u0435 \u043f\u043e \u0436\u0435\u043b\u0435\u0437\u0443, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0435 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0443 \u0432\u0430\u0441 \u0431\u0443\u0434\u0443\u0442 \u0434\u0440\u0443\u0433\u0438\u043c\u0438; \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, \u0432\u043e \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u0441\u0442\u0430\u043b\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u0437\u0430 \u0441\u0447\u0451\u0442 \u0447\u0435\u0433\u043e. \u0421\u043a\u0440\u0438\u043f\u0442\u044b \u0434\u043b\u044f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u2014 \u0432 \u043a\u043e\u043d\u0446\u0435 \u0441\u0442\u0430\u0442\u044c\u0438.\u0415\u0441\u0442\u044c \u0443\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u043e\u0435 \u043f\u043e\u0432\u0435\u0440\u044c\u0435: \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435 \u0442\u0435\u0441\u0442\u044b \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0435, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0445\u043e\u0434\u044f\u0442 \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0431\u0430\u0437\u0443. \u00ab\u041f\u043e\u0434\u043d\u0438\u043c\u0438 SQLite \u0432 \u043f\u0430\u043c\u044f\u0442\u0438\u00bb, \u00ab\u0437\u0430\u043c\u043e\u043a\u0430\u0439 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438\u00bb, \u00ab\u043d\u0435 \u0433\u043e\u043d\u044f\u0439 Postgres \u0432 CI\u00bb \u2014 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0441\u043e\u0432\u0435\u0442\u043e\u0432. \u041c\u043e\u043a\u0430\u0442\u044c \u044f \u043d\u0435 \u043b\u044e\u0431\u043b\u044e \u0438 \u0443\u0436\u0435 \u043f\u0438\u0441\u0430\u043b \u043f\u043e\u0447\u0435\u043c\u0443, \u043d\u043e \u043a\u0440\u044b\u0442\u044c \u0443\u043f\u0440\u0451\u043a \u00ab\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0430\u044f \u0431\u0430\u0437\u0430 \u2014 \u044d\u0442\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u00bb \u0431\u044b\u043b\u043e \u043d\u0435\u0447\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0441\u0435\u043b, \u0441\u043f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043b \u0438 \u043f\u043e\u043c\u0435\u0440\u0438\u043b. \u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0432\u0440\u0435\u043c\u044f \u0441\u044a\u0435\u0434\u0430\u043b\u0430 \u043e\u0434\u043d\u0430 \u043f\u0440\u0430\u0432\u043a\u0430 \u043f\u0440\u043e \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b. \u0410 \u043d\u0430\u0440\u043e\u0434\u043d\u044b\u0439 \u0441\u043e\u0432\u0435\u0442 \u00ab\u0447\u0438\u0441\u0442\u0438 \u0431\u0430\u0437\u0443 \u0447\u0435\u0440\u0435\u0437 TRUNCATE, \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 DELETE\u00bb \u0443 \u043c\u0435\u043d\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0440\u043e\u0432\u043d\u043e \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u2014 \u0447\u0442\u043e \u043e\u0431\u0438\u0434\u043d\u043e \u0432\u0434\u0432\u043e\u0439\u043d\u0435: \u044d\u0442\u0430 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0443\u0436\u0435 \u043b\u0435\u0436\u0430\u043b\u0430 \u0432 \u0447\u0435\u0440\u043d\u043e\u0432\u0438\u043a\u0435 \u043c\u043e\u0435\u0439 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0438 \u043f\u0440\u043e pytest. \u041f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u043d\u043e\u0432\u0438\u043a.\u0421\u044c\u044e\u0442 \u0448\u0451\u043b \u224830 \u043c\u0438\u043d\u0443\u0442 (1795 \u0441). \u0421\u0442\u0430\u043b \u2014 \u043c\u0435\u043d\u044c\u0448\u0435 \u0434\u0432\u0443\u0445 \u043c\u0438\u043d\u0443\u0442 (109 \u0441). \u0411\u0435\u0437 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u043d\u0438\u044f \u0442\u0435\u0441\u0442\u043e\u0432, \u0442\u0440\u0435\u043c\u044f \u043f\u0440\u0430\u0432\u043a\u0430\u043c\u0438 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b. \u041d\u0438\u0436\u0435 \u2014 \u043a\u0430\u043a \u044f \u0438\u0441\u043a\u0430\u043b \u0443\u0437\u043a\u0438\u0435 \u043c\u0435\u0441\u0442\u0430 \u0438 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0430\u043b\u0430 \u043a\u0430\u0436\u0434\u0430\u044f \u043f\u0440\u0430\u0432\u043a\u0430.\u0415\u0441\u043b\u0438 \u0443\u0437\u043d\u0430\u0451\u0442\u0435 \u0441\u0432\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u0445\u043e\u0442\u044f \u0431\u044b \u0432 \u043e\u0434\u043d\u043e\u043c \u043f\u0443\u043d\u043a\u0442\u0435 \u2014 \u0434\u0430\u043b\u044c\u0448\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u043e:async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b (engine, redis, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435) \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d\u044b \u0431\u0435\u0437 scope= \u2014 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442;\u0432 \u0442\u0435\u0441\u0442\u0430\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0431\u043e\u0435\u0432\u043e\u0439 \u0445\u0435\u0448 \u043f\u0430\u0440\u043e\u043b\u044f (argon2\/bcrypt) \u0441 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438;\u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u0431\u0430\u0437\u0430 \u0447\u0438\u0441\u0442\u0438\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 DELETE\/TRUNCATE, \u0438 \u0435\u0441\u0442\u044c \u043f\u043e\u0434\u043e\u0437\u0440\u0435\u043d\u0438\u0435, \u0447\u0442\u043e \u00ab\u0432\u043e\u0442 \u044d\u0442\u043e \u0438 \u0442\u043e\u0440\u043c\u043e\u0437\u0438\u0442\u00bb;\u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043c\u0438\u043d\u0443\u0442\u044b (\u0430 \u0442\u043e \u0438 \u0434\u0435\u0441\u044f\u0442\u043a\u0438), \u0432 CI \u2014 \u043a\u0440\u0430\u0442\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u0438 \u0442\u043e\u0447\u043d\u043e\u0433\u043e \u043e\u0442\u0432\u0435\u0442\u0430 \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb \u043d\u0435\u0442.\u041e\u0442\u043f\u0440\u0430\u0432\u043d\u0430\u044f \u0442\u043e\u0447\u043a\u0430: 3316 \u0442\u0435\u0441\u0442\u043e\u0432 \u0438 \u043f\u043e\u043b\u0447\u0430\u0441\u0430 \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f\u0422\u0435\u0441\u0442\u044b \u043d\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0447\u0435\u0441\u0442\u043d\u044b\u0435: \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435, \u0445\u043e\u0434\u044f\u0442 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 Postgres \u0438 Redis \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 ASGI-\u0441\u0435\u0440\u0432\u0435\u0440.\u041f\u043e\u043a\u0430 \u0438\u0445 \u043d\u0435\u043c\u043d\u043e\u0433\u043e, \u0432\u0441\u0451 \u0438\u0434\u0451\u0442 \u0431\u044b\u0441\u0442\u0440\u043e: \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e, \u0432 CI \u0447\u0443\u0442\u044c \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435. \u0422\u0435\u0440\u043f\u0438\u043c\u043e. \u041c\u043e\u0436\u043d\u043e \u0434\u0430\u0436\u0435 \u0441 \u043b\u0451\u0433\u043a\u043e\u0439 \u0438\u0440\u043e\u043d\u0438\u0435\u0439 \u043f\u043e\u0433\u043b\u044f\u0434\u044b\u0432\u0430\u0442\u044c \u043d\u0430 \u0442\u0435\u0445, \u0443 \u043a\u043e\u0433\u043e \u00ab\u0442\u0435\u0441\u0442\u044b \u043f\u043e \u043f\u043e\u043b\u0447\u0430\u0441\u0430\u00bb. \u041f\u043e\u0442\u043e\u043c \u043f\u0440\u043e\u0433\u043e\u043d \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 5 \u043c\u0438\u043d\u0443\u0442. \u041f\u043e\u0442\u043e\u043c 10. \u041f\u043e\u0442\u043e\u043c 15 \u2014 \u043d\u0443 \u0442\u0430\u043a \u0442\u0435\u0441\u0442\u043e\u0432 \u0436\u0435 \u0441\u0442\u0430\u043b\u043e \u0431\u043e\u043b\u044c\u0448\u0435. \u0423\u0445\u043e\u0434\u0438\u0448\u044c \u043d\u0430 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0448\u044c\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0440\u0443 \u043d\u0435\u0434\u0435\u043b\u044c \u2014 \u043f\u043e\u043b\u0447\u0430\u0441\u0430. 1795 \u0441\u0435\u043a\u0443\u043d\u0434 \u043d\u0430 3316 \u0442\u0435\u0441\u0442\u043e\u0432.\u041b\u043e\u043a\u0430\u043b\u044c\u043d\u043e \u044d\u0442\u043e \u0431\u043e\u043b\u044c. \u0412 CI \u0445\u0443\u0436\u0435: \u043a\u0430\u0436\u0434\u044b\u0439 \u043f\u0443\u0448 \u0441\u0442\u043e\u0438\u0442 \u043e\u043a\u043e\u043b\u043e \u0447\u0430\u0441\u0430.\u0427\u0438\u043d\u0438\u0442\u044c \u043d\u0430\u0443\u0433\u0430\u0434 \u0434\u043e\u0440\u043e\u0433\u043e \u2014 \u043c\u043e\u0436\u043d\u043e \u043d\u0435\u0434\u0435\u043b\u044e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432 \u0441\u0443\u043c\u043c\u0435 \u0434\u0430\u044e\u0442 2 % \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u0434\u043e \u043f\u043e\u043d\u044f\u0442\u044c, \u043a\u0443\u0434\u0430 \u0443\u0445\u043e\u0434\u0438\u0442 \u0432\u0440\u0435\u043c\u044f.\u041f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435: \u0433\u0434\u0435 \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0433\u043e\u0440\u0438\u0442\u041f\u0435\u0440\u0432\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d \u0432 pytest:pytest &#8212;durations=0    # \u0432\u0441\u0435 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438; &#8212;durations=25 \u2014 \u0442\u043e\u043f-25\u0418 \u043f\u0435\u0440\u0432\u044b\u0439 \u0441\u044e\u0440\u043f\u0440\u0438\u0437: \u0432\u0438\u043d\u043e\u0432\u0430\u0442\u043e\u0433\u043e \u0442\u0435\u0441\u0442\u0430 \u043d\u0435\u0442. \u041d\u0435\u0442 \u0434\u0435\u0441\u044f\u0442\u0438 \u0442\u044f\u0436\u0451\u043b\u044b\u0445 \u0442\u0435\u0441\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u0441\u0451 \u043f\u043e\u0440\u0442\u044f\u0442, \u2014 \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d\u043e \u0440\u043e\u0432\u043d\u044b\u043c \u0441\u043b\u043e\u0435\u043c \u043f\u043e \u0432\u0441\u0435\u043c 3316. \u042d\u0442\u043e \u043d\u0430\u043b\u043e\u0433, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043b\u0430\u0442\u0438\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043d\u0430 \u0432\u0445\u043e\u0434\u0435. &#8212;durations \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442, \u043a\u0430\u043a\u0438\u0435 \u0442\u0435\u0441\u0442\u044b \u0434\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043a\u043e\u0433\u0434\u0430 \u0434\u043e\u043b\u044c\u0448\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0432\u0441\u0435 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e, \u043e\u043d \u043d\u0435 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441 \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb.\u0414\u043b\u044f \u00ab\u043f\u043e\u0447\u0435\u043c\u0443\u00bb \u043d\u0443\u0436\u0435\u043d \u043f\u0440\u043e\u0444\u0430\u0439\u043b\u0435\u0440 \u0443\u0440\u043e\u0432\u043d\u0435\u043c \u043d\u0438\u0436\u0435:python -m cProfile -o profile_v0.out -m pytest .\/tests -p no:randomly -q\u041e\u0433\u043e\u0432\u043e\u0440\u043a\u0430: cProfile \u043d\u0435 \u043b\u0443\u0447\u0448\u0438\u0439 \u0434\u0440\u0443\u0433 async-\u043a\u043e\u0434\u0430 \u2014 \u0432\u0440\u0435\u043c\u044f \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0432 await \u043e\u043d \u0440\u0430\u0437\u043c\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u043f\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u0430, \u0438 \u0434\u043b\u044f \u043a\u0440\u0430\u0441\u0438\u0432\u044b\u0445 flame-\u0433\u0440\u0430\u0444\u043e\u0432 \u0431\u043e\u043b\u044c\u0448\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0442 py-spy \u0438\u043b\u0438 pyinstrument. \u041c\u043d\u0435 \u0445\u0432\u0430\u0442\u0438\u043b\u043e \u0433\u0440\u0443\u0431\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0438 \u043f\u043e \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u043c\u0443 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043d\u043e \u0437\u043d\u0430\u0442\u044c \u043f\u0440\u043e \u044d\u0442\u043e \u0441\u0442\u043e\u0438\u0442.\u0424\u0430\u0439\u043b \u043f\u0440\u043e\u0444\u0438\u043b\u044f \u2014 186 \u043c\u043b\u043d \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0438 \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u0442\u044b\u0441\u044f\u0447 \u0441\u0442\u0440\u043e\u043a \u043f\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c (\u0441\u043d\u0438\u043c\u0430\u043b \u043d\u0430 \u043f\u043e\u0434\u0432\u044b\u0431\u043e\u0440\u043a\u0435 \u0442\u0435\u0441\u0442\u043e\u0432: \u043f\u043e\u043b\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u043f\u043e\u0434 cProfile \u0432 \u043d\u0435\u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u043d\u0435\u0432\u044b\u043d\u043e\u0441\u0438\u043c\u043e \u0434\u043e\u043b\u0433\u0438\u0439). \u0413\u043b\u0430\u0437\u0430\u043c\u0438 \u0442\u0430\u043a\u043e\u0435 \u043d\u0435 \u043e\u0442\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u044e\u0442 \u2014 \u043b\u0435\u0433\u043a\u043e \u0437\u0430\u0446\u0435\u043f\u0438\u0442\u044c\u0441\u044f \u0437\u0430 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443 \u0438 \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u0442\u044c \u0443\u0437\u043a\u043e\u0435 \u043c\u0435\u0441\u0442\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0435\u0442. \u042f \u0441\u043a\u043e\u0440\u043c\u0438\u043b profile_v0.out LLM \u0441 \u043e\u0434\u043d\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435\u0439: \u0441\u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0438 \u043e\u0442\u0440\u0430\u043d\u0436\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u043e \u0441\u043e\u0432\u043e\u043a\u0443\u043f\u043d\u043e\u043c\u0443 tottime. \u0422\u043e\u0442 \u0436\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0434\u0430\u043b\u0438 \u0431\u044b snakeviz \u0438\u043b\u0438 gprof2dot \u043f\u043b\u044e\u0441 \u043f\u0430\u0440\u0430 \u0447\u0430\u0441\u043e\u0432 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u2014 \u043c\u043d\u0435 \u0431\u044b\u043b\u043e \u043b\u0435\u043d\u044c. \u0420\u0435\u0448\u0430\u0435\u0442 \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0437\u0430\u043c\u0435\u0440, \u043f\u0440\u043e\u0444\u0430\u0439\u043b\u0435\u0440 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442, \u043a\u0443\u0434\u0430 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c.\u0413\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430\u0441\u044c \u0442\u0430\u043a\u0430\u044f:\u0413\u0440\u0443\u043f\u043f\u0430 \u0440\u0430\u0441\u0445\u043e\u0434\u043e\u0432\u0414\u043e\u043b\u044f\u041e\u0436\u0438\u0434\u0430\u043d\u0438\u0435 I\/O \u043d\u0430 \u0441\u043e\u043a\u0435\u0442\u0430\u0445 (\u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 Postgres\/Redis)64 %\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 event loop \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u04425,6 %\u041e\u0442\u043a\u0440\u044b\u0442\u0438\u0435 \u043d\u043e\u0432\u044b\u0445 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 (asyncpg.connect)3,7 %\u0425\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u0430\u0440\u043e\u043b\u0435\u0439 (argon2)2,3 %\u041f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b \u0411\u0414 (create_all, DDL)1,2 %greenlet-\u043c\u043e\u0441\u0442 async\u2194sync SQLAlchemy0,7 %\u0427\u0442\u043e \u0438\u0437 \u044d\u0442\u043e\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u0435\u0442.\u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0441\u044c\u044e\u0442 I\/O-bound: 64 % \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0440\u043e\u0441\u0442\u043e \u0436\u0434\u0451\u0442 \u0441\u043e\u043a\u0435\u0442\u044b. CPU \u043f\u043e\u0447\u0442\u0438 \u043f\u0440\u043e\u0441\u0442\u0430\u0438\u0432\u0430\u0435\u0442 \u2014 \u0442\u0435\u0441\u0442\u044b \u043d\u0435 \u00ab\u0441\u0447\u0438\u0442\u0430\u044e\u0442\u00bb, \u043e\u043d\u0438 \u043e\u0431\u0449\u0430\u044e\u0442\u0441\u044f \u0441 Postgres \u0438 Redis. \u042d\u0442\u043e \u043d\u0435 \u043b\u0435\u0447\u0438\u0442\u0441\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043a\u043e\u0434\u0430 \u0442\u0435\u0441\u0442\u043e\u0432; \u0432\u043e\u043f\u0440\u043e\u0441 \u0432 \u0442\u043e\u043c, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u043c\u044b \u0437\u0430 \u044d\u0442\u043e \u043e\u0431\u0449\u0435\u043d\u0438\u0435 \u043f\u043b\u0430\u0442\u0438\u043c.\u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0437\u0430\u043c\u0435\u0442\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u2014 \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u044b\u0439 setup \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0442\u0435\u0441\u0442\u0435: \u043d\u043e\u0432\u044b\u0439 event loop (5,6 %), \u043d\u043e\u0432\u044b\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f (3,7 %), \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b (1,2 %). \u041d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u0435\u0440\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u041f\u0440\u0438\u0447\u0451\u043c \u0441\u0430\u043c\u0438 \u043f\u0435\u0440\u0435\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0438 CREATE TABLE \u0442\u043e\u0436\u0435 \u0438\u0434\u0443\u0442 \u043f\u043e \u0441\u043e\u043a\u0435\u0442\u0443, \u0442\u043e \u0435\u0441\u0442\u044c \u0440\u0430\u0437\u0434\u0443\u0432\u0430\u044e\u0442 \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 64 %. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 create_all \u0438 \u043d\u0435 \u0442\u043e\u0440\u0447\u0438\u0442 \u0432 \u043f\u0440\u043e\u0444\u0438\u043b\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u043c \u0441\u0442\u043e\u043b\u0431\u0438\u043a\u043e\u043c \u2014 \u0435\u0433\u043e \u0446\u0435\u043d\u0430 \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d\u0430 \u043f\u043e I\/O.\u0412-\u0442\u0440\u0435\u0442\u044c\u0438\u0445, \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u0411\u0414 \u0432 \u0442\u043e\u043f\u0435 \u043d\u0435\u0442. \u0421\u043f\u043e\u0441\u043e\u0431 \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 (\u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 TRUNCATE) \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u043b \u0432 \u0437\u043d\u0430\u0447\u0438\u043c\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u2014 \u043d\u0430 \u044d\u0442\u043e\u0439, \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041a \u043e\u0447\u0438\u0441\u0442\u043a\u0435 \u0435\u0449\u0451 \u0432\u0435\u0440\u043d\u0451\u043c\u0441\u044f.\u041f\u043e\u0434\u043e\u0437\u0440\u0435\u0432\u0430\u0435\u043c\u044b\u0439 \u043d\u0430\u0437\u0432\u0430\u043d: \u043c\u044b \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0432\u0435\u0441\u044c \u043c\u0438\u0440 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442. \u0414\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0431\u0443\u0434\u0435\u043c \u0437\u0430\u043c\u0435\u0440\u043e\u043c.\u041a\u0430\u043a \u043c\u0435\u0440\u0438\u0442\u044c, \u0447\u0442\u043e\u0431\u044b \u0441\u0435\u0431\u0435 \u043d\u0435 \u0441\u043e\u0432\u0440\u0430\u0442\u044c\u0413\u043b\u0430\u0432\u043d\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430 \u2014 \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0435\u0449\u0435\u0439 \u0441\u0440\u0430\u0437\u0443 \u0438 \u0440\u0430\u0434\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e\u0439 \u0446\u0438\u0444\u0440\u0435: \u0442\u0430\u043a \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u043e, \u0430 \u0447\u0442\u043e \u043f\u043b\u0430\u0446\u0435\u0431\u043e. \u041f\u0440\u0430\u0432\u0438\u043b\u0430:\u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044e \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u044f \u043f\u043e \u043e\u0447\u0435\u0440\u0435\u0434\u0438 \u0438 \u0437\u0430\u043c\u0435\u0440\u044f\u044e \u043f\u043e\u0441\u043b\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e;-p no:randomly \u2014 \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0441\u0442\u043e\u0438\u0442 pytest-randomly, \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435 \u0431\u043b\u0430\u0433\u043e, \u0434\u043b\u044f \u0437\u0430\u043c\u0435\u0440\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0448\u0443\u043c;\u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0433\u043e\u043d\u043e\u0432 \u0438 \u043c\u0435\u0434\u0438\u0430\u043d\u0430: \u043f\u0435\u0440\u0432\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a \u0433\u0440\u0435\u0435\u0442 \u043a\u044d\u0448\u0438, \u0441\u043e\u0441\u0435\u0434 \u0434\u0451\u0440\u043d\u0443\u043b \u0434\u0438\u0441\u043a \u2014 \u0432\u043e\u0442 \u0432\u0430\u043c \u00ab\u0440\u0435\u0433\u0440\u0435\u0441\u0441\u0438\u044f\u00bb \u043d\u0430 \u0440\u043e\u0432\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435;\u043e\u0442\u043a\u0430\u0442 \u2014 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u043c, \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u2014 git checkout. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0430\u0432\u043e\u043a \u0440\u0443\u043a\u0430\u043c\u0438, \u0438\u043d\u0430\u0447\u0435 \u043d\u0435 \u043e\u0442\u043b\u0438\u0447\u0438\u0448\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043e\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u043d\u0435\u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438;\u0432\u0441\u0451 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e, \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u0438 \u0442\u043e\u043c \u0436\u0435 \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435, \u043f\u0440\u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u043c\u043e\u0439 \u0444\u043e\u043d\u043e\u0432\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0435. \u0426\u0438\u0444\u0440\u044b \u0438\u0437 CI \u0437\u0434\u0435\u0441\u044c \u043d\u0435 \u0444\u0438\u0433\u0443\u0440\u0438\u0440\u0443\u044e\u0442 \u0441\u043e\u0437\u043d\u0430\u0442\u0435\u043b\u044c\u043d\u043e: \u0440\u0430\u043d\u043d\u0435\u0440\u044b \u0440\u0430\u0437\u043d\u044b\u0435, \u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u0438\u0445 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439 \u0431\u0435\u0441\u0441\u043c\u044b\u0441\u043b\u0435\u043d\u043d\u043e.\u0423\u0441\u043b\u043e\u0432\u0438\u044f \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430, \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u0441 \u0447\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c:Python3.13\u0424\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043aLitestar 2.20 (async ASGI), DI \u2014 Dishka\u0411\u0414PostgreSQL 18 \u2014 \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u043e\u0431\u0440\u0430\u0437 \u0432 Docker, \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e; SQLAlchemy 2.0.46 + asyncpg 0.31, \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 Alembic\u041a\u044d\u0448 \/ \u0431\u0440\u043e\u043a\u0435\u0440Redis 8 \u0438 NATS 2.10 (FastStream) \u2014 \u0442\u043e\u0436\u0435 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0435, \u0432 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u0445\u0422\u0435\u0441\u0442\u044bpytest 9.0 + pytest-asyncio 1.3; 3316 \u0442\u0435\u0441\u0442\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 ASGI-\u0441\u0435\u0440\u0432\u0435\u0440\u0416\u0435\u043b\u0435\u0437\u043eMacBook Pro (M4 Max, 36 \u0413\u0411); \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u0432 Docker Desktop \u043d\u0430 macOS \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u0432\u043d\u0443\u0442\u0440\u0438 Linux-VM, \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u043f\u043e TCP \u043d\u0430 localhost\u041f\u0440\u043e macOS \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e: Docker \u0437\u0434\u0435\u0441\u044c \u2014 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043c\u0430\u0448\u0438\u043d\u0430, \u0438 \u0432\u0435\u0441\u044c \u0442\u0440\u0430\u0444\u0438\u043a \u0434\u043e \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432 \u0438\u0434\u0451\u0442 \u0447\u0435\u0440\u0435\u0437 \u043f\u0440\u043e\u0431\u0440\u043e\u0441 \u043f\u043e\u0440\u0442\u043e\u0432 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438. \u0414\u043b\u044f I\/O-bound \u0441\u044c\u044e\u0442\u0430 \u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u043a\u043e\u043d\u0441\u0435\u0440\u0432\u0430\u0442\u0438\u0432\u043d\u044b \u2014 \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u043c Linux \u0431\u0443\u0434\u0435\u0442 \u0431\u044b\u0441\u0442\u0440\u0435\u0435. \u041d\u043e \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0448\u0430\u0433\u043e\u0432 \u043e\u0442 \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f, \u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442 \u043d\u0430\u0441 \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u043d\u043e.# benchmark\/apply_variant.py \u2014 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442def function_scope() -&gt; None:    &#171;&#187;&#187;\u0412\u0435\u0440\u043d\u0443\u0442\u044c \u0432\u0441\u0451 \u043a function-scope \u2014 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 &#8216;\u0434\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438&#8217;.&#187;&#187;&#187;    replace(        PYPROJECT,        &#8216;asyncio_default_fixture_loop_scope = &#171;session&#187;&#8216;,        &#8216;asyncio_default_fixture_loop_scope = &#171;function&#187;&#8216;,    )    # &#8230;\u0438 \u0442\u0430\u043a \u0434\u043b\u044f \u0412\u0421\u0415\u0425 session-scoped \u0444\u0438\u043a\u0441\u0442\u0443\u0440 \u0432 plugins\/instances (\u0443 \u043c\u0435\u043d\u044f \u0438\u0445 29).    # \u041f\u043e\u043b\u0443\u043c\u0435\u0440\u044b \u043d\u0435 \u0433\u043e\u0434\u044f\u0442\u0441\u044f: \u043e\u0441\u0442\u0430\u0432\u0438\u0448\u044c \u0445\u043e\u0442\u044c \u043e\u0434\u043d\u0443 session-scoped async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u0443 \u043f\u0440\u0438    # function loop scope \u2014 pytest-asyncio \u043f\u0430\u0434\u0430\u0435\u0442 \u0441\u043e ScopeMismatch \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0442\u0435\u0441\u0442\u0435.\u041f\u0440\u0430\u0432\u043a\u0430 1. Session-scope \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b \u0438 \u043e\u0431\u0449\u0438\u0439 event loop\u042d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u00ab\u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0432\u0435\u0441\u044c \u043c\u0438\u0440 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442\u00bb. \u0414\u0435\u0444\u043e\u043b\u0442 pytest-asyncio \u0441 asyncio_mode = &#171;auto&#187;: \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 event loop. \u0410 \u0440\u0430\u0437 \u043d\u043e\u0432\u044b\u0439 loop \u2014 \u0437\u0430\u043d\u043e\u0432\u043e \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u043a Postgres, \u043f\u0443\u043b Redis, \u0438\u043d\u0441\u0442\u0430\u043d\u0441 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438, \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u0441\u0445\u0435\u043c\u0430 \u0411\u0414. \u042d\u0442\u043e\u0442 \u043d\u0430\u043b\u043e\u0433 \u043f\u043b\u0430\u0442\u0438\u0442\u0441\u044f 3316 \u0440\u0430\u0437 \u0437\u0430 \u043f\u0440\u043e\u0433\u043e\u043d:\u0414\u043e: \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043f\u043b\u0430\u0442\u0438\u0442 \u0437\u0430 event loop, \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0438 \u0441\u0445\u0435\u043c\u0443; \u043f\u043e\u0441\u043b\u0435: \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043d\u0430 \u043f\u0440\u043e\u0433\u043e\u043d\u041b\u0435\u0447\u0438\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u043e\u0439 \u0438 scope=&#187;session&#187; \u043d\u0430 \u0434\u043e\u0440\u043e\u0433\u0438\u0445 \u0444\u0438\u043a\u0441\u0442\u0443\u0440\u0430\u0445:# pyproject.toml[tool.pytest.ini_options]asyncio_mode = &#171;auto&#187;asyncio_default_fixture_loop_scope = &#171;session&#187;asyncio_default_test_loop_scope = &#171;session&#187;@pytest.fixture(scope=&#187;session&#187;)async def engine(db_config: DatabaseConfig) -&gt; AsyncIterator[AsyncEngine]:    # create_engine \u2014 \u043d\u0430\u0448\u0430 \u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u043d\u0430\u0434 create_async_engine (\u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u044b\u0439 \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440)    async with create_engine(dsn=str(db_config.dsn), &#8230;) as engine:        async with engine.begin() as conn:            await conn.run_sync(BaseTable.metadata.drop_all)            await conn.run_sync(BaseTable.metadata.create_all)        yield engine                       # \u0441\u0445\u0435\u043c\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u041e\u0414\u0418\u041d \u0440\u0430\u0437 \u043d\u0430 \u0441\u0435\u0441\u0441\u0438\u044e\u041f\u043e\u0434\u0432\u043e\u0445: session-scope async-\u0444\u0438\u043a\u0441\u0442\u0443\u0440\u044b \u0442\u0435\u043f\u0435\u0440\u044c \u0436\u0438\u0432\u0443\u0442 \u0432\u0435\u0441\u044c \u043f\u0440\u043e\u0433\u043e\u043d, \u0438 \u0435\u0441\u043b\u0438 \u0432 \u043d\u0438\u0445 \u043a\u043e\u043f\u0438\u0442\u0441\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u2014 \u043e\u043d\u043e \u043f\u0440\u043e\u0442\u0435\u0447\u0451\u0442 \u0432\u043e \u0432\u0441\u0435 \u0442\u0435\u0441\u0442\u044b. \u0418\u0437\u043e\u043b\u044f\u0446\u0438\u044e \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u0435\u043b\u0430\u0435\u043c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u043e\u0447\u0438\u0441\u0442\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438, \u0430 \u043d\u0435 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435\u043c \u0432\u0441\u0435\u0433\u043e \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f.\u0417\u0430\u043c\u0435\u0440: 1795 \u0441 (\u224830 \u043c\u0438\u043d) \u2192 221 \u0441. \u041c\u0438\u043d\u0443\u0441 88 %, \u0432 8 \u0440\u0430\u0437. \u041d\u0438 \u043e\u0434\u0438\u043d \u0442\u0435\u0441\u0442 \u043d\u0435 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043d \u2014 \u043c\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u043b\u0438 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435 3316 \u0440\u0430\u0437. \u041f\u043e \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u044e \u0446\u0435\u043d\u044b \u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u044d\u0442\u043e, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0441\u0430\u043c\u0430\u044f \u043d\u0435\u0434\u043e\u043e\u0446\u0435\u043d\u0451\u043d\u043d\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u0434\u043b\u044f async-\u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432.\u041f\u0440\u0430\u0432\u043a\u0430 2. TRUNCATE \u2192 DELETE: \u043a\u043e\u043d\u0442\u0440\u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u044e\u0440\u043f\u0440\u0438\u0437\u041e\u0447\u0438\u0441\u0442\u043a\u0430 \u0411\u0414 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043c\u0438 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0431\u044b\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u043d\u0430 \u00ab\u043a\u0430\u043a \u043f\u0440\u0438\u043d\u044f\u0442\u043e\u00bb \u2014 \u043e\u0434\u043d\u0438\u043c TRUNCATE &#8230; RESTART IDENTITY CASCADE \u043d\u0430 \u0432\u0441\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u041e\u0434\u0438\u043d \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u0440\u0438\u0434\u0446\u0430\u0442\u0438, \u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0436\u0435. \u041d\u0430 \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u0435\u0451 \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u043b \u2014 \u043e\u043d\u0430 \u0442\u043e\u043d\u0443\u043b\u0430 \u0432 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f.\u041d\u043e \u043f\u0440\u043e\u0433\u043e\u043d \u0443\u0436\u0435 \u043d\u0435 30 \u043c\u0438\u043d\u0443\u0442, \u0430 \u0442\u0440\u0438 \u0441 \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u043e\u0439. \u041f\u0435\u0440\u0435\u043c\u0435\u0440\u044f\u044e \u2014 \u0438 \u0442\u0435\u043f\u0435\u0440\u044c, \u043a\u043e\u0433\u0434\u0430 \u043a\u0440\u0443\u043f\u043d\u043e\u0435 \u0443\u0431\u0440\u0430\u043d\u043e, \u043e\u0447\u0438\u0441\u0442\u043a\u0430 \u0441\u0442\u0430\u043b\u0430 \u0437\u0430\u043c\u0435\u0442\u043d\u043e\u0439 \u0434\u043e\u043b\u0435\u0439. \u041f\u0440\u043e\u0431\u0443\u044e \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u043e\u0434\u0438\u043d TRUNCATE \u043d\u0430 \u043f\u0430\u0447\u043a\u0443 DELETE \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438:# \u0431\u044b\u043b\u043e: \u043e\u0434\u0438\u043d TRUNCATE &#8230; CASCADE \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442# \u0441\u0442\u0430\u043b\u043e: DELETE \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0432 \u043f\u043e\u0440\u044f\u0434\u043a\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439, \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438_DELETE_STATEMENTS = tuple(    text(f&#8217;DELETE FROM &#171;{t.name}&#187;&#8216;) for t in reversed(BaseTable.metadata.sorted_tables))\u0417\u0430\u043c\u0435\u0440: 221 \u0441 \u2192 125 \u0441 (\u221243 %). \u0422\u0440\u0438\u0434\u0446\u0430\u0442\u044c DELETE \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0437\u0430\u043c\u0435\u0442\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u043e\u0434\u043d\u043e\u0433\u043e TRUNCATE. \u041c\u0430\u043b\u043e \u0442\u043e\u0433\u043e, TRUNCATE \u0431\u044b\u043b \u0435\u0449\u0451 \u0438 \u0434\u0438\u043a\u0438\u043c \u043f\u043e \u0440\u0430\u0437\u0431\u0440\u043e\u0441\u0443: \u043e\u0442 \u043f\u0440\u043e\u0433\u043e\u043d\u0430 \u043a \u043f\u0440\u043e\u0433\u043e\u043d\u0443 \u0434\u0430\u0432\u0430\u043b \u043e\u0442 152 \u0434\u043e 254 \u0441\u0435\u043a\u0443\u043d\u0434 (\u0441\u043c. CSV \u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438), \u0442\u043e\u0433\u0434\u0430 \u043a\u0430\u043a DELETE \u0434\u0435\u0440\u0436\u0430\u043b\u0441\u044f \u0440\u043e\u0432\u043d\u043e, \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u0435\u043a\u0443\u043d\u0434.\u041f\u043e\u0447\u0435\u043c\u0443 \u0442\u0430\u043a. TRUNCATE \u2014 \u044d\u0442\u043e \u043d\u0435 \u00ab\u0431\u044b\u0441\u0442\u0440\u044b\u0439 DELETE\u00bb, \u0430 DDL-\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f: \u043e\u043d\u0430 \u0431\u0435\u0440\u0451\u0442 ACCESS EXCLUSIVE \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0443 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u0441 CASCADE \u043e\u0431\u0445\u043e\u0434\u0438\u0442 \u0434\u0435\u0440\u0435\u0432\u043e \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439, \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043d\u043e\u0432\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442 \u043a\u0430\u0442\u0430\u043b\u043e\u0433 \u2014 \u0438 \u0442\u0430\u043a \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0438\u0437 3316 \u0432\u044b\u0437\u043e\u0432\u043e\u0432. \u0421\u0442\u043e\u0438\u043c\u043e\u0441\u0442\u044c \u044d\u0442\u043e\u0433\u043e \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u0438&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-483138","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/483138","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=483138"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/483138\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=483138"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=483138"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=483138"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}