{"id":484584,"date":"2026-06-22T14:13:03","date_gmt":"2026-06-22T14:13:03","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=484584"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=484584","title":{"rendered":"\u042f \u043d\u0435 \u0445\u043e\u0442\u0435\u043b \u043f\u0438\u0441\u0430\u0442\u044c ORM \u0434\u043b\u044f Kotlin\/Native. \u041c\u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0443\u0436\u0435\u043d \u0431\u044b\u043b PostgreSQL"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u0412\u0441\u0435 \u043d\u0430\u0447\u0430\u043b\u043e\u0441\u044c \u0441 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0433\u043e \u0442\u0443\u043f\u0438\u043a\u0430. \u042f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u0431\u044d\u043a\u0435\u043d\u0434-\u0447\u0430\u0441\u0442\u044c\u044e low-code \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b, \u0434\u043b\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0432 \u043a\u0440\u0443\u043f\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0439. \u0423 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b \u0431\u044b\u043b\u0430 \u0436\u0435\u0441\u0442\u043a\u0430\u044f \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430 \u2014 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0438 \u0445\u0430\u0440\u0434\u043a\u043e\u0440\u043d\u044b\u0439 \u043e\u0444\u0444\u043b\u0430\u0439\u043d-\u0440\u0435\u0436\u0438\u043c. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438\u00a0 \u2014\u00a0 \u043f\u0440\u043e\u0440\u0430\u0431\u044b \u043d\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0442\u0440\u043e\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u0445 \u0438 \u0433\u0435\u043e\u043b\u043e\u0433\u0438 \u0432 \u0442\u0430\u0439\u0433\u0435, \u0433\u0434\u0435 \u0441\u0432\u044f\u0437\u044c \u043f\u0440\u043e\u043f\u0430\u0434\u0430\u0435\u0442 \u043d\u0435 \u043d\u0430 \u043f\u0430\u0440\u0443 \u043c\u0438\u043d\u0443\u0442, \u0430 \u043d\u0430 \u0446\u0435\u043b\u044b\u0435 \u0434\u043d\u0438.<\/p>\n<p>\u041f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0434\u043e\u043b\u0436\u043d\u043e \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u043e \u0436\u0438\u0442\u044c \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e: \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0437\u0430\u0431\u0438\u0432\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435, \u043c\u0435\u043d\u044f\u0435\u0442 \u0441\u0442\u0430\u0442\u0443\u0441\u044b \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439, \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u044b, \u043f\u0440\u0438\u043a\u0440\u0435\u043f\u043b\u044f\u0435\u0442 \u0444\u043e\u0442\u043e. \u0410 \u0437\u0430\u0442\u0435\u043c, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0435\u0442\u044c, \u043d\u0430 \u0431\u044d\u043a\u0435\u043d\u0434 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u0435\u0442 \u043b\u0430\u0432\u0438\u043d\u0430 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0439.<\/p>\n<p>\u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0430 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u0430\u044f, \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u043d\u0430\u044f \u0438 \u043a\u0440\u0443\u0442\u0438\u0442\u0441\u044f \u0432 Kubernetes, \u044f \u0431\u044b\u0441\u0442\u0440\u043e \u0443\u043f\u0435\u0440\u0441\u044f \u0432 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u043d\u0435\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0440\u0435\u0441\u0443\u0440\u0441\u043e\u0432. \u0422\u0435\u043d\u0430\u043d\u0442 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u043c\u043e\u0436\u0435\u0442 \u00ab\u0441\u043f\u0430\u0442\u044c\u00bb \u0447\u0430\u0441\u0430\u043c\u0438 \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0434\u043d\u044f\u043c\u0438, \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0442\u0440\u0430\u0444\u0438\u043a\u0430, \u0430 \u043f\u043e\u0442\u043e\u043c \u043f\u0430\u0447\u043a\u0430 \u044e\u0437\u0435\u0440\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0438\u0437 \u043e\u0444\u0444\u043b\u0430\u0439\u043d\u0430, \u0438 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0430 \u043d\u0430 \u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0437\u043b\u0435\u0442\u0430\u0435\u0442 \u043f\u043e \u044d\u043a\u0441\u043f\u043e\u043d\u0435\u043d\u0442\u0435. \u0414\u0435\u0440\u0436\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u043d\u0430\u043d\u0442 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u0437\u0430\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u0435 \u0438 \u043f\u0440\u043e\u0441\u0442\u0430\u0438\u0432\u0430\u044e\u0449\u0438\u0435 \u043f\u043e\u0434\u044b\u00a0 \u0431\u0435\u0437\u0443\u043c\u043d\u043e \u0434\u043e\u0440\u043e\u0433\u043e.<\/p>\n<p>\u041b\u043e\u0433\u0438\u0447\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0442\u044c \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043f\u043e \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044e \u0431\u043b\u0438\u0436\u0435 \u043a \u043c\u043e\u043c\u0435\u043d\u0442\u0443 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438. \u0412 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u0435\u0442 \u0431\u044b\u0442\u044c \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0442\u043d\u043e\u0439 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043c\u0435\u0442\u0440\u0438\u043a\u043e\u0439 \u0438 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432\u043b\u0438\u044f\u0442\u044c \u043d\u0430 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0432\u0441\u0435\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b. \u0415\u0441\u043b\u0438 Cold Start \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u0435\u0442\u0441\u044f, \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0443\u043f\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0432 \u043a\u0430\u0441\u043a\u0430\u0434\u043d\u044b\u0439 \u043e\u0442\u043a\u0430\u0437: \u0442\u0430\u0439\u043c\u0430\u0443\u0442\u044b \u0440\u0432\u0443\u0442\u0441\u044f, \u043a\u043b\u0438\u0435\u043d\u0442\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0430\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u044b\u0435 \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u044b\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 (retry storms), \u0430 \u0437\u0430\u0449\u0438\u0442\u043d\u044b\u0435 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u044b \u0432\u0440\u043e\u0434\u0435 Rate Limiting \u0438 Circuit Breaker \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0432\u0435\u0435\u0440\u043d\u043e \u043e\u0442\u0440\u0443\u0431\u0430\u0442\u044c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439, \u0447\u0442\u043e\u0431\u044b \u0441\u043f\u0430\u0441\u0442\u0438 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043e\u0442 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u0435\u0433\u0440\u0430\u0434\u0430\u0446\u0438\u0438. \u0411\u044b\u0441\u0442\u0440\u044b\u0439 \u0441\u0442\u0430\u0440\u0442 \u0441\u0442\u0430\u043b \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c \u0443\u0441\u043f\u0435\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u0432\u0441\u043f\u043b\u0435\u0441\u043a \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0430\u0432\u0430\u0440\u0438\u0439\u043d\u044b\u0435 \u043f\u0440\u0435\u0434\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435\u043b\u0438.<\/p>\n<h3>\u041a\u0430\u043a \u044f \u0443\u0445\u043e\u0434\u0438\u043b \u043e\u0442 JVM<\/h3>\n<p>\u042f \u043d\u0435 \u0441\u0442\u0430\u043b \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0432\u0441\u0435 \u0437\u0430 \u043e\u0434\u0438\u043d \u0440\u0430\u0437, \u0430 \u0434\u0432\u0438\u0433\u0430\u043b\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043f\u043e \u043c\u0435\u0440\u0435 \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433\u0430 \u0438\u043b\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043d\u043e\u0432\u044b\u0445 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432.<\/p>\n<p><strong>Ktor + Exposed \u0432\u043c\u0435\u0441\u0442\u043e Spring Boot + Hibernate.<\/strong> \u0422\u0438\u043f\u0438\u0447\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430 Spring \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u0437\u0430 25\u201330 \u0441\u0435\u043a\u0443\u043d\u0434, \u0430 \u043b\u0435\u043d\u0438\u0432\u043e\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0434\u043e \u0411\u0414 \u0432 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u043e\u0439 \u0441\u0440\u0435\u0434\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u043b\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441. \u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430 Ktor (JVM) \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u043b \u0443\u0436\u0435 \u0437\u0430 2\u20133 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. \u041c\u043d\u0435 \u0431\u044b\u043b \u043a\u0440\u0438\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0430\u0436\u0435\u043d \u043b\u0435\u0433\u043a\u0438\u0439 \u0441\u0442\u0430\u0440\u0442 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c \u043d\u0430\u0434 SQL, \u0430 \u043d\u0435 \u0442\u044f\u0436\u0435\u043b\u0430\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u0430\u044f \u043c\u043e\u0434\u0435\u043b\u044c. \u041d\u0430 \u0432\u0440\u0435\u043c\u044f \u044d\u0442\u043e\u0433\u043e \u0445\u0432\u0430\u0442\u0438\u043b\u043e.<\/p>\n<p><strong>GraalVM Native Image.<\/strong> \u0418\u0434\u0435\u044f \u043f\u043e\u043d\u044f\u0442\u043d\u0430\u044f: \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c JVM-\u043b\u0438\u0431\u044b, \u043d\u043e \u0441\u043e\u0431\u0440\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a. \u041d\u043e \u044f \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441 \u0436\u0435\u0441\u0442\u043a\u0438\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438 <strong>Closed-World \u2014 GraalVM<\/strong> \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0437\u043d\u0430\u0442\u044c \u0432\u0435\u0441\u044c \u043a\u043e\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u043d\u0435 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0432 runtime. \u041f\u043e\u043c\u0438\u043c\u043e \u0432\u043e\u0439\u043d\u044b \u0441 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u0435\u0439 \u0434\u043b\u044f \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, AOT-\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u043b\u0438\u0448\u0438\u043b\u0430 \u043c\u0435\u043d\u044f JIT-\u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0439 \u043d\u0430 \u0434\u0438\u0441\u0442\u0430\u043d\u0446\u0438\u0438. \u0412\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0432 Community-\u0432\u0435\u0440\u0441\u0438\u0438 GraalVM \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0441\u0442\u0430\u0442\u044c\u0438 \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u044b\u0439 Serial GC, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430 \u0442\u044f\u0436\u0435\u043b\u044b\u0445 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u044f\u0445 \u0443\u0432\u043e\u0434\u0438\u043b \u043f\u043e\u0434\u044b \u0432 Stop-The-World.\u00a0<\/p>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/9e2\/a8e\/cde\/9e2a8ecde2adb82062858abb82ef5e0d.png\" width=\"1110\" height=\"155\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/9e2\/a8e\/cde\/9e2a8ecde2adb82062858abb82ef5e0d.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/9e2\/a8e\/cde\/9e2a8ecde2adb82062858abb82ef5e0d.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u0414\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u043a \u044d\u0442\u043e\u043c\u0443 \u0441\u0431\u043e\u0440\u043a\u0438 \u043d\u0430 CI\/CD \u043f\u043e 10 \u043c\u0438\u043d\u0443\u0442 \u0441 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435\u043c \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0433\u0438\u0433\u0430\u0431\u0430\u0439\u0442 RAM \u2014 \u0438 GraalVM \u0441\u0442\u0430\u043b \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043a\u0430\u043a \u0442\u044f\u0436\u0435\u043b\u044b\u0439 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043d\u0430\u043b\u043e\u0433.<\/p>\n<h3>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0433\u0438\u043f\u043e\u0442\u0435\u0437\u0443: \u043f\u043e\u0447\u0435\u043c\u0443 \u0434\u043b\u044f R&amp;D \u0431\u044b\u043b \u0432\u044b\u0431\u0440\u0430\u043d Kotlin\/Native?<\/h3>\n<p>\u0427\u0442\u043e\u0431\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0441\u0430\u043c\u0443 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u044e Scale-to-zero \u0431\u0435\u0437 \u0431\u043e\u043b\u0438 \u0441 GraalVM, \u043c\u043d\u0435 \u043d\u0443\u0436\u0435\u043d \u0431\u044b\u043b \u0447\u0438\u0441\u0442\u044b\u0439 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f. \u0418 \u0438\u0434\u0435\u044f \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c Kotlin\/Native \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u043b\u0430 \u043a\u0430\u043a \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u0448\u0430\u0433 \u0434\u043b\u044f R&amp;D.<\/p>\n<p>\u0425\u043e\u0442\u044f Kotlin\/Native \u0441\u0435\u0439\u0447\u0430\u0441 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0440\u043e\u0441\u0442\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0438 \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u043e\u0439 \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u0435\u0433\u043e \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442\u043e\u043c \u0441\u043b\u0443\u0436\u0438\u0442 \u043c\u043e\u0449\u043d\u044b\u0439 \u0438\u043d\u0434\u0443\u0441\u0442\u0440\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 LLVM. \u0411\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0441\u0435\u0440\u044c\u0435\u0437\u043d\u044b\u043c \u0438\u043d\u0432\u0435\u0441\u0442\u0438\u0446\u0438\u044f\u043c \u0441\u043e \u0441\u0442\u043e\u0440\u043e\u043d\u044b JetBrains, \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f \u0441\u0442\u0440\u0435\u043c\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u044d\u0432\u043e\u043b\u044e\u0446\u0438\u043e\u043d\u0438\u0440\u0443\u0435\u0442, \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u044f \u0445\u043e\u0440\u043e\u0448\u0438\u0435 \u043f\u0435\u0440\u0441\u043f\u0435\u043a\u0442\u0438\u0432\u044b \u0434\u043b\u044f \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f Kotlin\/Native \u0432 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u044b\u0439, \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0439 \u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0434\u043b\u044f \u0431\u044d\u043a\u0435\u043d\u0434-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438.<\/p>\n<p>\u0412 \u0440\u0430\u043c\u043a\u0430\u0445 \u043c\u043e\u0435\u0433\u043e \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0433\u043b\u0430\u0432\u043d\u044b\u043c \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0435\u043c \u0431\u044b\u043b \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0430\u0440\u0442 \u0437\u0434\u0435\u0441\u044c \u0438 \u0441\u0435\u0439\u0447\u0430\u0441 \u0440\u0430\u0434\u0438 \u0431\u043e\u0440\u044c\u0431\u044b \u0441 Cold Start. \u0418 \u0434\u043b\u044f \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u044d\u0442\u043e\u0439 \u0433\u0438\u043f\u043e\u0442\u0435\u0437\u044b Kotlin\/Native \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u043b \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u043e \u043f\u043e \u0434\u0432\u0443\u043c \u043f\u0440\u0438\u0447\u0438\u043d\u0430\u043c:<\/p>\n<p><strong>\u041f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u044b\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0440\u0430\u043d\u0442\u0430\u0439\u043c.<\/strong> \u041a\u043e\u0434 \u0447\u0435\u0440\u0435\u0437 LLVM \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a \u043f\u043e\u0434 Linux x64. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u043c\u0430\u0448\u0438\u043d, \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u043e\u0432\u0435\u0440\u0445\u0435\u0434\u0430 \u0438 \u0441\u043a\u0440\u044b\u0442\u044b\u0445 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0441\u0431\u043e\u0440\u043a\u0438. \u041e\u043d \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e \u0438 \u0432\u0435\u0434\u0435\u0442 \u0441\u0435\u0431\u044f \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e, \u0432\u044b\u0434\u0430\u0432\u0430\u044f \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 memory footprint \u043f\u0440\u044f\u043c\u043e \u0441\u043e \u0441\u0442\u0430\u0440\u0442\u0430.<\/p>\n<p><strong>\u041d\u0438\u0437\u043a\u0438\u0439 \u043f\u043e\u0440\u043e\u0433 \u0432\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044f \u0437\u0430 \u0441\u0447\u0435\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0435\u043d\u043d\u043e\u0441\u0442\u0438 (KMP).<\/strong> \u042d\u0442\u043e, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0433\u043b\u0430\u0432\u043d\u044b\u0439 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442. \u041c\u043d\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0443\u0447\u0438\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u043d\u044b\u0439 Go \u0438\u043b\u0438 Rust \u0438 \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u044b \u043d\u0430 \u0447\u0443\u0436\u043e\u043c \u044f\u0437\u044b\u043a\u0435. \u042f \u043c\u043e\u0433 \u0432\u0437\u044f\u0442\u044c \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0443\u044e \u0434\u043e\u043c\u0435\u043d\u043d\u0443\u044e \u043b\u043e\u0433\u0438\u043a\u0443, \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0435\u0435 \u0432 shared-\u043c\u043e\u0434\u0443\u043b\u044c \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u043a \u0432 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u043c \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0435, \u0442\u0430\u043a \u0438 \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0445 JVM-\u0441\u0435\u0440\u0432\u0438\u0441\u0430\u0445.<\/p>\n<p><strong>\u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0446\u0435\u043b\u0435\u0432\u043e\u0439 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b JVM \u0438\u043b\u0438 K\/N<\/strong> &#8212; \u044d\u0442\u043e \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0432\u043e\u0431\u043e\u0434\u0430, \u044f \u043c\u043e\u0433\u0443 \u043f\u0440\u044f\u043c\u043e \u0441\u0435\u0439\u0447\u0430\u0441 \u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434 \u0438 \u043a\u0440\u0443\u0442\u0438\u0442\u044c \u0435\u0433\u043e \u043d\u0430 \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u043e\u0439, \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0439 JVM. \u0410 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442, \u043a\u043e\u0433\u0434\u0430 \u0431\u044d\u043a\u0435\u043d\u0434-\u0447\u0430\u0441\u0442\u044c \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440\u0430 Kotlin\/Native \u043e\u043a\u043e\u043d\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u0443\u044e\u0442, \u044f \u0441\u043c\u043e\u0433\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0441\u0431\u043e\u0440\u043a\u0443 \u043d\u0430 Native, \u0435\u0441\u043b\u0438 \u0437\u0430\u043c\u0435\u0440\u044b \u043f\u043e\u043a\u0430\u0436\u0443\u0442, \u0447\u0442\u043e \u0442\u0430\u043a \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u0432\u044b\u0433\u043e\u0434\u043d\u0435\u0435 \u0434\u043b\u044f \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b.<\/p>\n<p>\u0414\u043b\u044f \u0446\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0430 \u0432\u0441\u0435 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u043b\u043e\u0441\u044c \u043e\u0442\u043b\u0438\u0447\u043d\u043e. \u0421\u0435\u0442\u0435\u0432\u043e\u0439 \u0441\u043b\u043e\u0439 \u0438 HTTP-\u043a\u043b\u0438\u0435\u043d\u0442\u044b \u0431\u0435\u0437 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0437\u0430\u043a\u0440\u044b\u043b \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0435\u043d\u043d\u044b\u0439 Ktor. \u0414\u043b\u044f \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438 \u0441 Apache Kafka \u0442\u043e\u0436\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u043d\u0430\u0439\u0442\u0438 \u0440\u0430\u0431\u043e\u0447\u0443\u044e \u043e\u0431\u0435\u0440\u0442\u043a\u0443. \u0411\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u0430\u0440\u043a\u0430\u0441 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u0430 \u0441\u043a\u043b\u0435\u0438\u0432\u0430\u043b\u0441\u044f \u0432\u043f\u043e\u043b\u043d\u0435 \u0443\u0441\u043f\u0435\u0448\u043d\u043e.<\/p>\n<p>\u0420\u043e\u0432\u043d\u043e \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043d\u0435 \u0434\u043e\u0448\u0435\u043b \u0434\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0431\u0430\u0437\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445. \u0418 \u0432\u043e\u0442 \u0442\u0443\u0442 \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043f\u043e\u043a\u0430 Kotlin\/Native \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u043b\u0441\u044f \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0442\u0443\u043b\u0438\u043d\u0433\u0430, \u0448\u0430\u0440\u0438\u043d\u0433\u0430 \u043a\u043e\u0434\u0430 \u0438 \u0441\u0435\u0442\u0435\u0432\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442.<\/p>\n<h3>\u0412\u0435\u043b\u0438\u043a\u0430\u044f \u0441\u0442\u0435\u043d\u0430 PostgreSQL \u0432 Kotlin\/Native<\/h3>\n<p>\u041d\u0430 JVM \u044f \u043f\u0440\u0438\u0432\u044b\u043a \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e JDBC \u0435\u0441\u0442\u044c \u0432\u0441\u0435\u0433\u0434\u0430. \u042d\u0442\u043e \u043d\u0430\u0434\u0435\u0436\u043d\u044b\u0439, \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0439 \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u0438 \u043c\u043e\u043d\u0443\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0441\u0442\u043e\u044f\u0442 Hibernate, Exposed, jOOQ \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0435. JDBC \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0431\u0435\u0440\u0435\u0442 \u043d\u0430 \u0441\u0435\u0431\u044f \u0432\u0441\u044e \u043d\u0438\u0437\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u0443\u044e \u0440\u0443\u0442\u0438\u043d\u0443 \u043e\u0431\u0449\u0435\u043d\u0438\u044f \u0441 \u0421\u0423\u0411\u0414. \u0412 Kotlin\/Native \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e JDBC, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u043d\u0435\u0442.<\/p>\n<p>\u0412\u0441\u0435, \u0447\u0442\u043e \u0431\u044b\u043b\u043e \u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432 \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u2014 \u044d\u0442\u043e <a href=\"https:\/\/github.com\/moreirasantos\/pgkn\" rel=\"noopener noreferrer nofollow\">pgkn<\/a>, \u043d\u0438\u0437\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u044b\u0439 \u0434\u0440\u0430\u0439\u0432\u0435\u0440, \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0449\u0438\u0439 \u0441\u043e\u0431\u043e\u0439 \u0442\u043e\u043d\u043a\u0438\u0435 \u0431\u0438\u043d\u0434\u0438\u043d\u0433\u0438 \u0432\u043e\u043a\u0440\u0443\u0433 \u0441\u0438\u0448\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <a href=\"https:\/\/www.postgresql.org\/docs\/current\/libpq.html\" rel=\"noopener noreferrer nofollow\">libpq<\/a>. \u0422\u043e \u0435\u0441\u0442\u044c \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u043a PostgreSQL \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u043c\u043e\u0436\u043d\u043e. \u041d\u043e \u0434\u0430\u043b\u044c\u0448\u0435 \u0432\u044b \u043e\u0441\u0442\u0430\u0435\u0442\u0435\u0441\u044c \u043e\u0434\u0438\u043d \u043d\u0430 \u043e\u0434\u0438\u043d \u0441 \u043d\u0435\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c, \u0441\u044b\u0440\u044b\u043c\u0438 Result Set, \u0440\u0443\u0447\u043d\u044b\u043c \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u043e\u043c \u0438 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u043c\u0438 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u044f\u043c\u0438 DAO-\u043a\u043e\u0434\u0430.<\/p>\n<p>\u0412\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0442\u0438\u043f\u0438\u0447\u043d\u043e\u0433\u043e \u0438, \u0447\u0435\u0441\u0442\u043d\u043e \u0433\u043e\u0432\u043e\u0440\u044f, \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u0438\u0441\u0430\u0442\u044c \u043d\u0430 pgkn:<\/p>\n<p>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/><code>\u00a0 \u00a0 val list = driver.execute(\"SELECT * FROM users\") {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 mapOf(\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"id\" to it.getLong(0),\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"name\" to it.getString(1),\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"email\" to it.getString(2),\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"bool\" to it.getBoolean(3),\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"int\" to it.getInt(5),\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \"timestamp\" to it.getLocalDateTime(11)\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ ... \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0442\u0438\u043f\u0430 \u0434\u0430\u043d\u043d\u044b\u0445\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 )\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/><\/code><\/p>\n<h3>\u041e\u0442 \u043f\u0430\u0440\u044b \u0445\u0435\u043b\u043f\u0435\u0440\u043e\u0432 \u043a Kormium<\/h3>\n<p>\u0421\u0430\u043c\u043e\u0435 \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u2014 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442 \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0443\u0434\u0430\u0447\u043d\u044b\u043c. \u041d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u0430 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u043c\u0435\u043d\u0435\u0435 \u0447\u0435\u043c \u0437\u0430 0.3 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0438 \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0430\u043b\u0441\u044f \u0432 \u0440\u0430\u0431\u043e\u0442\u0443, \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043b\u0438\u043a\u0432\u0438\u0434\u0438\u0440\u0443\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 Cold Start. \u0413\u0438\u043f\u043e\u0442\u0435\u0437\u0430 \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043b\u0430\u0441\u044c, \u043d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u044f \u0441\u043f\u043e\u0442\u043a\u043d\u0443\u043b\u0441\u044f \u043e \u0441\u0443\u0440\u043e\u0432\u0443\u044e \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u0443\u044e \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c.<\/p>\n<p>\u041f\u0438\u0441\u0430\u0442\u044c \u0440\u0443\u0447\u043d\u043e\u0439 \u043c\u0430\u043f\u043f\u0438\u043d\u0433 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u0434\u043b\u044f \u043f\u0430\u0440\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e\u0433\u043e R&amp;D \u2014 \u0442\u0435\u0440\u043f\u0438\u043c\u043e. \u041d\u043e \u044d\u0442\u043e\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043d\u0435 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0438\u0440\u0443\u0435\u0442\u0441\u044f, \u043a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u0442\u044c \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u0443\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443 \u0441 \u0434\u0435\u0441\u044f\u0442\u043a\u0430\u043c\u0438 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041b\u044e\u0431\u043e\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 PostgreSQL (\u0431\u0430\u043d\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u043c\u0435\u043d\u0430 \u0442\u0438\u043f\u0430 \u0438\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 nullable-\u043f\u043e\u043b\u044f) \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u043b\u043e\u0441\u044c \u0432 \u043a\u043e\u0448\u043c\u0430\u0440: \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u043b\u043e\u0441\u044c \u0440\u0443\u043a\u0430\u043c\u0438 \u0438\u0434\u0442\u0438 \u0432\u043e \u0432\u0441\u0435 \u0444\u0430\u0439\u043b\u044b \u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0432 \u0434\u0443\u0445\u0435 it.getString(X), \u043d\u0430\u0434\u0435\u044f\u0441\u044c \u043d\u0435 \u043e\u0448\u0438\u0431\u0438\u0442\u044c\u0441\u044f \u0441 \u0446\u0438\u0444\u0440\u043e\u0439. \u041e\u0448\u0438\u0431\u043a\u0438 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u043e\u0432\u0430\u043b \u2014 \u0432\u0441\u0435 \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0438\u0441\u044c \u0441\u0442\u0440\u043e\u0433\u043e \u0432 \u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0435.<\/p>\n<p>\u041f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0434\u0438\u043b\u0435\u043c\u043c\u0430. \u0421 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u043a\u0430\u043a-\u0442\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u043a\u043e\u0434, \u043d\u0435 \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0432 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u0443\u044e \u0440\u0443\u0442\u0438\u043d\u0443. \u0421 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u0431\u044b\u043b\u043e \u043d\u0435 \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u0435\u0441\u043b\u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e\u0432\u0435\u0440\u0445 libpq \u0432\u044b\u0441\u043e\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u0443\u044e \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0446\u0438\u044e, \u043d\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043b\u0438 \u0442\u0430\u043c \u043e\u0432\u0435\u0440\u0445\u0435\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u0432\u0435\u0434\u0435\u0442 \u043d\u0430 \u043d\u0435\u0442 \u0432\u0441\u044e \u0432\u044b\u0433\u043e\u0434\u0443 \u043e\u0442 \u0431\u044b\u0441\u0442\u0440\u043e\u0433\u043e \u0441\u0442\u0430\u0440\u0442\u0430?<\/p>\n<p>\u041c\u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043d\u0440\u0430\u0432\u0438\u043b\u0441\u044f DSL \u0432 Exposed. \u0418\u0445 \u043f\u043e\u0434\u0445\u043e\u0434 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0430\u0436\u043d\u0443\u044e \u0432\u0435\u0449\u044c: API \u0434\u043b\u044f \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 Kotlin \u0434\u043e\u043b\u0436\u0435\u043d \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043a\u0430\u043a \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 Kotlin, \u0430 \u043d\u0435 \u043a\u0430\u043a \u0444\u0440\u0430\u043d\u043a\u0435\u043d\u0448\u0442\u0435\u0439\u043d \u0438\u0437 \u0447\u0443\u0436\u043e\u0433\u043e \u044f\u0437\u044b\u043a\u0430. \u0411\u043b\u0430\u0433\u043e, \u044f\u0437\u044b\u043a \u0434\u0430\u0435\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0432\u0441\u0435 \u043a\u0430\u0440\u0442\u044b \u0432 \u0440\u0443\u043a\u0438: \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u044b, \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, lambdas with receiver. \u042f \u0440\u0435\u0448\u0438\u043b \u0440\u0438\u0441\u043a\u043d\u0443\u0442\u044c \u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e \u0432\u0435\u0447\u0435\u0440\u0430\u043c \u043e\u0431\u0435\u0440\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u044b\u043b\u0430 \u0431\u044b \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043b\u0435\u0433\u043a\u043e\u0432\u0435\u0441\u043d\u043e\u0439.<\/p>\n<p>\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043f\u043b\u0430\u043d \u0431\u044b\u043b \u0441\u043a\u0440\u043e\u043c\u043d\u044b\u043c \u2014 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u0439-\u043f\u043e\u043c\u043e\u0449\u043d\u0438\u043a\u043e\u0432 \u043f\u043e\u0432\u0435\u0440\u0445 pgkn, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u0443\u0431\u0440\u0430\u0442\u044c \u0440\u0443\u0442\u0438\u043d\u0443. \u041d\u043e \u043a\u043e\u0434 \u043d\u0430\u0447\u0430\u043b \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043b\u0430\u0432\u0438\u043d\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u0434\u043d\u0430 \u0440\u0435\u0448\u0435\u043d\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0442\u0443\u0442 \u0436\u0435 \u043e\u0431\u043d\u0430\u0436\u0430\u043b\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e. \u042d\u0432\u043e\u043b\u044e\u0446\u0438\u044f \u0448\u043b\u0430 \u043f\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u043b\u043e\u0433\u0438\u0447\u043d\u044b\u043c \u0448\u0430\u0433\u0430\u043c:<\/p>\n<p><strong>\u0411\u043e\u0440\u044c\u0431\u0430 \u0441\u043e \u0441\u0434\u0432\u0438\u0433\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 (ResultSet).<\/strong> \u041f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b extension-\u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0432\u0440\u043e\u0434\u0435 fun ResultSet.toUser(), \u0447\u0442\u043e\u0431\u044b \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u0442\u0443\u0434\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u0435\u0439. \u041d\u043e \u0441\u0442\u043e\u0438\u043b\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043a\u043e\u043b\u043e\u043d\u043a\u0443 \u0432 \u0441\u0435\u0440\u0435\u0434\u0438\u043d\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u043a\u0430\u043a \u0432\u0441\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b it.getString(2), it.getInt(3) \u0441\u044a\u0435\u0437\u0436\u0430\u043b\u0438. \u0421\u0442\u0430\u043b\u043e \u043f\u043e\u043d\u044f\u0442\u043d\u043e: \u043c\u0430\u043f\u0438\u0442\u044c \u043d\u0443\u0436\u043d\u043e \u043d\u0435 \u043f\u043e \u0445\u0430\u0440\u0434\u043a\u043e\u0434\u043d\u044b\u043c \u043d\u043e\u043c\u0435\u0440\u0430\u043c, \u0430 \u043f\u043e \u0438\u043c\u0435\u043d\u0430\u043c \u043a\u043e\u043b\u043e\u043d\u043e\u043a.<\/p>\n<p><strong>\u041f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432-\u043a\u043e\u043b\u043e\u043d\u043e\u043a.<\/strong> \u0427\u0442\u043e\u0431\u044b \u0447\u0438\u0442\u0430\u0442\u044c \u043f\u043e \u0438\u043c\u0435\u043d\u0430\u043c \u0438 \u043d\u0435 \u043e\u043f\u0435\u0447\u0430\u0442\u0430\u0442\u044c\u0441\u044f \u0432 \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u0445 \u043b\u0438\u0442\u0435\u0440\u0430\u043b\u0430\u0445, \u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0438\u043c\u0435\u043d\u0430 \u0432 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u044b. \u041d\u043e \u0440\u0430\u0437 \u0443\u0436 \u044f \u0441\u043e\u0437\u0434\u0430\u044e \u043e\u0431\u044a\u0435\u043a\u0442 \u0434\u043b\u044f \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u043f\u043e\u0447\u0435\u043c\u0443 \u0431\u044b \u043d\u0435 \u0441\u0432\u044f\u0437\u0430\u0442\u044c \u0435\u0433\u043e \u0441 \u0442\u0438\u043f\u043e\u043c \u0434\u0430\u043d\u043d\u044b\u0445? \u0422\u0430\u043a \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0431\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 Column&lt;T&gt;, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u043d\u0430\u043b \u0438 \u0438\u043c\u044f \u043f\u043e\u043b\u044f \u0432 \u0411\u0414, \u0438 \u0442\u043e, \u043a\u0430\u043a \u0435\u0433\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0438\u043b\u0438 \u0437\u0430\u043a\u043e\u0434\u0438\u0440\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p><strong>DSL \u0434\u043b\u044f \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0442\u0430\u0431\u043b\u0438\u0446.<\/strong> \u0420\u0430\u0437 \u0435\u0441\u0442\u044c \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u0438\u0445 \u043d\u0443\u0436\u043d\u043e \u0433\u0434\u0435-\u0442\u043e \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c. \u0422\u0430\u043a \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u0441\u0438\u043d\u0433\u043b\u0442\u043e\u043d object Users : Table(&#8230;) (\u043f\u043e\u0437\u0436\u0435 \u0441\u0438\u0433\u043d\u0430\u0442\u0443\u0440\u0430 \u043e\u0431\u0440\u0430\u0441\u0442\u0435\u0442 \u0442\u0438\u043f\u0430\u043c\u0438 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u0438 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438 \u2014 \u043a \u044d\u0442\u043e\u043c\u0443 \u0432\u0435\u0440\u043d\u0435\u043c\u0441\u044f). \u041d\u0430 \u044d\u0442\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0430 \u043c\u0430\u0433\u0438\u044f Kotlin: \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u043e\u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432 (val id by Column.UUID()) \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0441\u043c\u043e\u0433\u043b\u0430 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0438\u043c\u0435\u043d\u0430 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0438\u0437 \u043a\u043e\u0434\u0430 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u043a\u0430\u043a \u0438\u043c\u0435\u043d\u0430 \u043a\u043e\u043b\u043e\u043d\u043e\u043a \u0432 \u0431\u0430\u0437\u0435, \u0438\u0437\u0431\u0430\u0432\u043b\u044f\u044f \u043e\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u0443\u0431\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u043c\u0438 \u043b\u0438\u0442\u0435\u0440\u0430\u043b\u0430\u043c\u0438.<\/p>\n<p><strong>Query Builder \u043f\u0440\u043e\u0442\u0438\u0432 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u0438 \u0441\u0442\u0440\u043e\u043a.<\/strong> \u0418\u043c\u0435\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043a\u043e\u043b\u043e\u043d\u043e\u043a, \u043f\u0438\u0441\u0430\u0442\u044c raw SQL \u0432 \u0434\u0443\u0445\u0435 &#171;SELECT * FROM &#187; + Users.tableName \u0441\u0442\u0430\u043b\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e. \u0417\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u043f\u0438\u0441\u0430\u0442\u044c <a href=\"http:\/\/Users.select\" rel=\"noopener noreferrer nofollow\">Users.select<\/a>(). \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0438\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u0435\u0440 SQL, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0440\u0430\u043b \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044f \u043f\u043b\u0435\u0439\u0441\u0445\u043e\u043b\u0434\u0435\u0440\u044b ($1, $2) \u0432\u043c\u0435\u0441\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439, \u0447\u0442\u043e\u0431\u044b \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0449\u0438\u0442\u0443 \u043e\u0442 SQL-\u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0439.<\/p>\n<p><strong>\u0422\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u044f \u0443\u0441\u043b\u043e\u0432\u0438\u0439 (\u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u044b).<\/strong> \u0421\u0430\u043c\u044b\u0439 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0432\u044b\u0437\u043e\u0432 \u2014 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u044f. \u041f\u0438\u0441\u0430\u0442\u044c .where(&#171;age &gt;= 18&#187;) \u2014 \u044d\u0442\u043e \u0441\u043d\u043e\u0432\u0430 runtime-\u0440\u0438\u0441\u043a\u0438. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0437\u0430\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u044d\u0442\u043e \u0432 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0432\u0438\u0434: where { Users.age gtEq 18 }. \u041f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 gtEq \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043b\u043e \u0434\u0435\u0440\u0435\u0432\u043e \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0439 (AST), \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0440\u0435\u043d\u0434\u0435\u0440\u0435\u0440 \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u043b \u0432 \u0432\u0430\u043b\u0438\u0434\u043d\u044b\u0439 WHERE age &gt;= $1.<\/p>\n<p>\u041f\u043e\u043b\u0443\u0447\u0438\u043b\u0430\u0441\u044c \u0442\u043e\u043d\u043a\u0430\u044f, \u0441\u0442\u0440\u043e\u0433\u043e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0446\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0430 \u043e\u0432\u0435\u0440\u0445\u0435\u0434\u0430 \u0432 \u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0435, \u043d\u043e \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043b\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 \u043e\u0442 \u0441\u0438\u0448\u043d\u044b\u0445 \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u0435\u0439. \u0418\u0437 \u044d\u0442\u043e\u0433\u043e R&amp;D-\u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0430 \u0432 \u0438\u0442\u043e\u0433\u0435 \u0438 \u0432\u044b\u0440\u043e\u0441\u043b\u0430 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0430\u044f \u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u043c\u0430\u044f ORM \u2014 \u0440\u043e\u0434\u0438\u043b\u0441\u044f Kormium.<\/p>\n<p>\u0418 \u0432\u043e\u0442 \u0447\u0442\u043e \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u043e: \u0432\u0441\u0435 \u044d\u0442\u043e \u0434\u0435\u0440\u0436\u0438\u0442\u0441\u044f \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430 \u0448\u0442\u0430\u0442\u043d\u044b\u0445 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430\u0445 \u044f\u0437\u044b\u043a\u0430. \u0412 Kormium \u043d\u0435\u0442 \u043d\u0438 \u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u0430 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u0439, \u043d\u0435\u0442 \u043a\u043e\u0434\u043e\u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438, \u043d\u0435\u0442 \u043f\u043b\u0430\u0433\u0438\u043d\u0430 \u043a \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440\u0443 \u0438 \u043d\u0435\u0442 \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u0430 \u0447\u0435\u0440\u0435\u0437 \u0440\u0430\u043d\u0442\u0430\u0439\u043c-\u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e. \u0418\u043c\u0435\u043d\u0430 \u043a\u043e\u043b\u043e\u043d\u043e\u043a \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0443\u0437\u043d\u0430\u0435\u0442 \u043d\u0435 \u043c\u0430\u0433\u0438\u0435\u0439, \u0430 \u0447\u0435\u0440\u0435\u0437 provideDelegate \u0438 <a href=\"http:\/\/property.name\" rel=\"noopener noreferrer nofollow\">property.name<\/a> \u2014 \u043e\u0431\u044b\u0447\u043d\u044b\u0435 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u044b \u0441\u0432\u043e\u0439\u0441\u0442\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 Kotlin \u0440\u0435\u0437\u043e\u043b\u0432\u0438\u0442 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438. \u0412\u0441\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u2014 \u044d\u0442\u043e \u0434\u0436\u0435\u043d\u0435\u0440\u0438\u043a\u0438, \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438 lambdas with receiver.<\/p>\n<p>\u0417\u0432\u0443\u0447\u0438\u0442 \u043a\u0430\u043a \u043c\u0435\u043b\u043e\u0447\u044c, \u043d\u043e \u043d\u0430 \u0434\u0438\u0441\u0442\u0430\u043d\u0446\u0438\u0438 \u044d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u00ab\u0436\u0438\u0432\u043e\u0439\u00bb \u0438 \u00ab\u043c\u0435\u0440\u0442\u0432\u043e\u0439\u00bb \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u043e\u0439. \u041d\u0435\u0442 \u0433\u0435\u043d\u0435\u0440\u0430\u0442\u043e\u0440\u0430 \u2014 \u043d\u0435\u0447\u0435\u043c\u0443 \u043b\u043e\u043c\u0430\u0442\u044c\u0441\u044f \u043f\u0440\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0438 Kotlin \u0438 \u043d\u0435\u0447\u0435\u0433\u043e \u0436\u0434\u0430\u0442\u044c \u043d\u0430 \u0441\u0431\u043e\u0440\u043a\u0435: \u043f\u0440\u043e\u0435\u043a\u0442 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u043e\u0431\u044b\u0447\u043d\u044b\u043c kotlinc, \u0431\u0435\u0437 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0445\u043e\u0434\u0430 KSP. IDE \u0432\u0438\u0434\u0438\u0442 \u0432\u0441\u0435 \u043a\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043a\u043e\u0434 \u2014 \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u044f, \u0430\u0432\u0442\u043e\u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0438 \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433-\u043f\u0435\u0440\u0435\u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438, \u0430 \u0432 \u0441\u0442\u0435\u043a-\u0442\u0440\u0435\u0439\u0441\u0430\u0445 \u043d\u0435\u0442 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u0435\u0439. \u041f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u0438 \u0447\u0438\u0442\u0430\u0442\u044c \u0442\u0430\u043a\u0443\u044e \u043a\u043e\u0434\u043e\u0432\u0443\u044e \u0431\u0430\u0437\u0443 \u043d\u0435\u0441\u0440\u0430\u0432\u043d\u0438\u043c\u043e \u0434\u0435\u0448\u0435\u0432\u043b\u0435. \u041e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u0440\u0438\u044f\u0442\u043d\u044b\u0439 \u0431\u043e\u043d\u0443\u0441: \u0440\u0430\u0437 \u0440\u0430\u043d\u0442\u0430\u0439\u043c-\u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u0438 \u043d\u0435\u0442 \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0442\u044c \u043f\u0440\u043e \u0441\u0435\u0431\u044f \u043d\u0438 AOT-\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440\u0443 Kotlin\/Native, \u043d\u0438 \u2014 \u0435\u0441\u043b\u0438 \u0432\u044b \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u043d\u0430 JVM \u2014 GraalVM, \u0441 \u043a\u043e\u043d\u0444\u0438\u0433\u0430\u043c\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f \u0432\u043e\u0435\u0432\u0430\u043b \u0432 \u0441\u0430\u043c\u043e\u043c \u043d\u0430\u0447\u0430\u043b\u0435 \u044d\u0442\u043e\u0439 \u0438\u0441\u0442\u043e\u0440\u0438\u0438.<\/p>\n<h3>\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 Kormium \u0441\u0435\u0433\u043e\u0434\u043d\u044f<\/h3>\n<p>Kormium \u2014 \u044d\u0442\u043e type-safe ORM \u0438 SQL DSL \u0434\u043b\u044f Kotlin Multiplatform \u043f\u043e\u0434 \u043b\u0438\u0446\u0435\u043d\u0437\u0438\u0435\u0439 Apache 2.0. \u0422\u0430\u0431\u043b\u0438\u0446\u044b, \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438, \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u044b, \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0434\u0436\u043e\u0439\u043d\u044b \u0438 \u0430\u0433\u0440\u0435\u0433\u0430\u0446\u0438\u0438 \u0432\u044b \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0435 \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043d\u0430 \u0447\u0438\u0441\u0442\u043e\u043c Kotlin, \u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0442\u043e\u0442 \u043a\u043e\u0434 \u043d\u0430 \u0432\u0441\u0435\u0445 \u0446\u0435\u043b\u0435\u0432\u044b\u0445 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0430\u0445.<\/p>\n<p>\u0427\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u043f\u0440\u0435\u0434\u043c\u0435\u0442\u043d\u043e \u2014 \u0432\u043e\u0442 \u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 SELECT \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0441 pgkn, \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435\u043f\u0435\u0440\u044c \u0431\u0435\u0437 \u0440\u0443\u0447\u043d\u043e\u0433\u043e \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u0430 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0445\u0435\u043c\u0430 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u0438\u043d \u0440\u0430\u0437:<\/p>\n<p>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/><code>\u00a0 \u00a0 object MainCatalog : Catalog \/\/ \u0442\u0435\u0433 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u2014 \u043f\u0440\u043e \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0438 \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u0447\u0443\u0442\u044c \u043d\u0438\u0436\u0435\u00a0 \u00a0 <br \/> \u00a0 \u00a0 \u00a0 \u00a0 <br \/>\u00a0 \u00a0 object Users : Table&lt;MainCatalog, User&gt;(\"users\", ::User) {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val id by Column.Long().primaryKey()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val name by Column.Text()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val email by Column.Text()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val age by Column.Int()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 class User : Entity() {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var id by Users.id\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var name by Users.name\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var email by Users.email\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var age by Users.age\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <\/code><\/p>\n<p>\u0410 \u0434\u0430\u043b\u044c\u0448\u0435 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u2014 \u044d\u0442\u043e \u0442\u0438\u043f\u043e\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u044b\u0439 Kotlin, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 User, \u0430 \u043d\u0435 \u0441\u044b\u0440\u043e\u0439 ResultSet:<\/p>\n<p>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/><code>\u00a0 \u00a0 transaction {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val all: List&lt;User&gt; = Users.all() \/\/ SELECT * FROM users\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val adults = Users.find { where { Users.age gtEq 18 } } \/\/ ... WHERE age &gt;= $1\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 Users.insert(User().apply { name = \"Alice\"; email = \"alice@example.com\"; age = 30 })\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <\/code><\/p>\n<p>\u0421\u0440\u0430\u0432\u043d\u0438\u0442\u0435 \u0441 pgkn-\u043f\u0440\u043e\u0441\u0442\u044b\u043d\u0435\u0439 \u0438\u0437 \u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0442\u0430\u0442\u044c\u0438: \u0438\u0441\u0447\u0435\u0437\u043b\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043a\u043e\u043b\u043e\u043d\u043e\u043a, \u0440\u0443\u0447\u043d\u043e\u0439 mapOf, \u0440\u0438\u0441\u043a \u043f\u0435\u0440\u0435\u043f\u0443\u0442\u0430\u0442\u044c \u0442\u0438\u043f \u2014 \u0438 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u0432\u0441\u0435 \u0442\u0430\u043a \u0436\u0435 \u0442\u043e\u043d\u043a\u043e \u0438 \u0431\u0435\u0437 \u0440\u0430\u043d\u0442\u0430\u0439\u043c-\u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u0438.<\/p>\n<p>\u042f\u0434\u0440\u043e \u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u043c\u043e, \u0430 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u0443\u044e \u0421\u0423\u0411\u0414 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0431\u044d\u043a\u0435\u043d\u0434. \u041f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0442\u0440\u0438:<\/p>\n<ul>\n<li>\n<p><strong>PostgreSQL<\/strong> \u2014 \u043d\u0430 JVM (JDBC\/HikariCP), \u043d\u0430 Kotlin\/Native (\u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0447\u0435\u0440\u0435\u0437 libpq, \u0431\u0435\u0437 JVM) \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e \u0447\u0435\u0440\u0435\u0437 R2DBC.<\/p>\n<\/li>\n<li>\n<p><strong>MySQL \/ MariaDB<\/strong> \u2014 \u0442\u0430\u043c \u0436\u0435: JVM (JDBC), Native (\u0447\u0435\u0440\u0435\u0437 libmariadb) \u0438 async \u0447\u0435\u0440\u0435\u0437 R2DBC.<\/p>\n<\/li>\n<li>\n<p><strong>SQLite<\/strong> \u2014 \u043d\u0430 JVM, Native, Android \u0438 iOS.<\/p>\n<\/li>\n<\/ul>\n<p>\u0418 \u0432\u043e\u0442 \u0442\u0443\u0442 \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0440\u0430\u0434\u0438 \u0447\u0435\u0433\u043e \u0432\u0441\u0435 \u0437\u0430\u0442\u0435\u0432\u0430\u043b\u043e\u0441\u044c: \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u043d\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e, Kormium \u2014 \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 KMP-\u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0441 \u0447\u0435\u0441\u0442\u043d\u043e\u0439 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 PostgreSQL \u043f\u0440\u044f\u043c\u043e \u043d\u0430 Kotlin\/Native. Exposed \u0436\u0435\u0441\u0442\u043a\u043e \u0437\u0430\u0432\u044f\u0437\u0430\u043d \u043d\u0430 JVM, \u0430 SQLDelight \u0438\u0441\u0442\u043e\u0440\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u043e \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0439 SQLite. \u0421 Kormium \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 \u0438\u043b\u0438 CLI-\u0443\u0442\u0438\u043b\u0438\u0442\u0430 \u0445\u043e\u0434\u044f\u0442 \u0432 Postgres \u0432\u043e\u043e\u0431\u0449\u0435 \u0431\u0435\u0437 Java-\u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0430 \u043f\u043e\u0434 \u043d\u043e\u0433\u0430\u043c\u0438.<\/p>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442 \u0434\u0430\u0432\u043d\u043e \u0432\u044b\u0448\u0435\u043b \u0438\u0437 \u00ab\u043d\u0430\u043a\u043e\u043b\u0435\u043d\u043e\u0447\u043d\u043e\u0439\u00bb \u0441\u0442\u0430\u0434\u0438\u0438. \u0422\u0435\u043a\u0443\u0449\u0430\u044f \u0432\u0435\u0440\u0441\u0438\u044f \u2014 <strong>0.7.0<\/strong> (\u0438\u044e\u043d\u044c 2026, \u0441\u0442\u0430\u0442\u0443\u0441 pre-1.0), \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043d\u0430 \u043d\u0430 Maven Central (\u0433\u0440\u0443\u043f\u043f\u0430 io.github.kormium, \u0435\u0441\u0442\u044c kormium-bom), \u0442\u0440\u0435\u0431\u0443\u0435\u0442 Kotlin 2.4.x \u0438 JDK 21+ \u043d\u0430 JVM.<\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0437\u043d\u0435\u0441\u0435\u043d\u0430 \u043f\u043e \u043c\u043e\u0434\u0443\u043b\u044f\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u044e\u0442\u0441\u044f \u043f\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438. \u0421\u0430\u043c\u043e \u044f\u0434\u0440\u043e (kormium-core) \u2014 \u044d\u0442\u043e \u0447\u0438\u0441\u0442\u044b\u0439 Kotlin \u0431\u0435\u0437 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u043e\u0442 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u043e\u0432: DSL, \u043c\u043e\u0434\u0435\u043b\u044c \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 SQL. \u041f\u043e\u0432\u0435\u0440\u0445 \u043d\u0435\u0433\u043e \u0436\u0438\u0432\u0443\u0442 \u0431\u044d\u043a\u0435\u043d\u0434\u044b (kormium-postgres, kormium-mysql, kormium-sqlite) \u0438 \u043e\u0431\u0449\u0438\u0439 async-\u0441\u043b\u043e\u0439 kormium-r2dbc. \u0418\u0437 \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u043e\u0433\u043e: kormium-migrate \u2014 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u0440\u0430\u043d\u043d\u0435\u0440 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0439 \u043d\u0430 raw-SQL \u0441 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0435\u0439 \u0447\u0435\u043a\u0441\u0443\u043c\u043c, advisory-\u043b\u043e\u043a\u0430\u043c\u0438 \u043d\u0430 Postgres (\u0437\u0430\u0449\u0438\u0442\u0430 \u043e\u0442 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u0442\u0430\u0440\u0442\u0430 \u043f\u043e\u0434\u043e\u0432) \u0438 \u0436\u0443\u0440\u043d\u0430\u043b\u043e\u043c; \u043f\u043b\u044e\u0441 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438 kormium-ktor \/ -ktor-di \/ -ktor-koin \u0434\u043b\u044f \u0432\u0435\u0431\u0430 \u0438 DI. \u0410 kormium-observe \u2014 \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0435 Flow-\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432 \u0434\u0443\u0445\u0435 Room \u2014 \u044f \u0432\u044b\u043d\u0435\u0441 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u0432 \u0444\u0438\u0447\u0438 \u043d\u0438\u0436\u0435: \u044d\u0442\u043e \u043e\u0434\u043d\u0430 \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u0432\u043a\u0443\u0441\u043d\u044b\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<h3>\u041a\u043b\u044e\u0447\u0435\u0432\u044b\u0435 \u0444\u0438\u0447\u0438, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u0441\u0435 \u0434\u0435\u043b\u0430\u043b\u043e\u0441\u044c<\/h3>\n<h4>1. \u0413\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u043e\u0432 (Catalog)<\/h4>\n<p>\u0412 Kormium \u0432\u0432\u0435\u0434\u0435\u043d\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u043e\u0432 \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u0444\u0430\u043d\u0442\u043e\u043c\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u0430\u0437 \u0434\u0430\u043d\u043d\u044b\u0445 (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u043e\u043d\u043d\u0430\u044f \u0438 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043a\u044d\u0448\u0430), \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0436\u0435\u0441\u0442\u043a\u043e \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u0432 \u043a\u043e\u0434\u0435:<\/p>\n<p><code>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/>\u00a0 \u00a0 object MainCatalog : Catalog\u00a0 \u00a0 <br \/>\u00a0 \u00a0 object CacheCatalog : Catalog\u00a0 \u00a0 <br \/> \u00a0 \u00a0 \u00a0 \u00a0 <br \/>\u00a0 \u00a0 \/\/ \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u043e\u043d\u043d\u0430\u044f \u0431\u0430\u0437\u0430\u00a0 \u00a0 <br \/>\u00a0 \u00a0 object Orders : Table&lt;MainCatalog, Order&gt;(\"orders\", ::Order) {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val id by Column.UUID().primaryKey()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 class Order : Entity() {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var id by Orders.id\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/> \u00a0 \u00a0 \u00a0 \u00a0 <br \/>\u00a0 \u00a0 \/\/ \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043a\u044d\u0448\u0430\u00a0 \u00a0 <br \/>\u00a0 \u00a0 object SessionCache : Table&lt;CacheCatalog, Session&gt;(\"sessions\", ::Session) {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 val token by Column.Text()\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 class Session : Entity() {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 var token by SessionCache.token\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <\/code><\/p>\n<p>\u0415\u0441\u043b\u0438 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0432\u0430\u0448\u0435\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u043e\u0442\u043a\u0440\u044b\u0442 \u0434\u043b\u044f MainCatalog, \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435 \u0434\u0430\u0441\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0432 \u043d\u0435\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0435 \u0438\u0437 CacheCatalog \u2014 \u044d\u0442\u043e \u043d\u0435 \u0440\u0430\u043d\u0442\u0430\u0439\u043c-\u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0438 \u043d\u0435 \u043b\u0438\u043d\u0442\u0435\u0440, \u0430 \u043e\u0431\u044b\u0447\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0442\u0438\u043f\u043e\u0432 Kotlin. \u041f\u0435\u0440\u0435\u043f\u0443\u0442\u0430\u0442\u044c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u043a \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0431\u0430\u0437\u0435 \u0438 \u043a \u043a\u044d\u0448\u0443, \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u00ab\u043d\u0435 \u0432 \u0442\u0443 \u0411\u0414\u00bb \u043f\u0440\u0438 \u0448\u0430\u0440\u0434\u0438\u043d\u0433\u0435 \u0438\u043b\u0438 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u0438 \u2014 \u043a\u043b\u0430\u0441\u0441 \u043e\u0448\u0438\u0431\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432 Kormium \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0434\u043e\u0435\u0437\u0436\u0430\u0435\u0442 \u0434\u043e \u0442\u0435\u0441\u0442\u043e\u0432, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043a\u043e\u0434 \u0441 \u043d\u0438\u043c \u043d\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f.<\/p>\n<h4>2. \u041a\u043e\u0440\u0443\u0442\u0438\u043d\u044b \u2014 \u0438 \u043d\u0430 JVM, \u0438 \u043d\u0430 Native<\/h4>\n<p>\u0421\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 API \u0437\u0434\u0435\u0441\u044c \u0440\u0430\u0432\u043d\u043e\u043f\u0440\u0430\u0432\u043d\u044b: \u0435\u0441\u0442\u044c transaction {} \u0434\u043b\u044f \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e \u043a\u043e\u0434\u0430 \u0438 suspendTransaction {} \u0434\u043b\u044f \u043a\u043e\u0440\u0443\u0442\u0438\u043d \u2014 \u043d\u0435 \u043e\u0431\u0435\u0440\u0442\u043a\u0430 \u043d\u0430\u0434 \u043e\u0431\u0435\u0440\u0442\u043a\u043e\u0439, \u0430 \u0434\u0432\u0435 \u0447\u0435\u0441\u0442\u043d\u044b\u0435 \u0442\u043e\u0447\u043a\u0438 \u0432\u0445\u043e\u0434\u0430. \u0421\u0430\u043c\u043e\u0435 \u0436\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e suspendTransaction {} \u2014 \u044d\u0442\u043e \u043e\u0434\u0438\u043d \u0438 \u0442\u043e\u0442 \u0436\u0435 \u0432\u0430\u0448 \u043a\u043e\u0434 \u043d\u0430 \u0432\u0441\u0435\u0445 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0430\u0445, \u0430 \u0432\u043e\u0442 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043f\u043e\u0434 \u043d\u0438\u043c Kormium \u043f\u043e\u0434\u0431\u0438\u0440\u0430\u0435\u0442 \u043b\u0443\u0447\u0448\u0438\u0439 \u0438\u0437 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0445.<\/p>\n<p><strong>\u041d\u0430 JVM<\/strong> \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u044b JDBC \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0438\u0435, \u0438 \u043d\u0430\u0438\u0432\u043d\u044b\u0439 \u043e\u0444\u0444\u043b\u043e\u0430\u0434 \u043d\u0430 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043f\u0443\u043b \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u0443\u043f\u0435\u0440\u0441\u044f \u0431\u044b \u0432 \u0435\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430 JDK 21+ Kormium \u0433\u043e\u043d\u044f\u0435\u0442 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0438\u0435 \u0432\u044b\u0437\u043e\u0432\u044b \u043f\u043e \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u044b\u043c \u043f\u043e\u0442\u043e\u043a\u0430\u043c (Project Loom): \u043a\u043e\u0440\u0443\u0442\u0438\u043d\u0430, \u0437\u0430\u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u0430\u0432\u0448\u0430\u044f\u0441\u044f \u043d\u0430 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0435, \u043e\u0442\u0446\u0435\u043f\u043b\u044f\u0435\u0442 \u043d\u0435\u0441\u0443\u0449\u0438\u0439 \u043f\u043e\u0442\u043e\u043a, \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0430 \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0434\u0435\u0448\u0435\u0432\u043e\u0439, \u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043b\u043e\u043a \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u0438\u0437\u043c\u0430 \u0437\u0430\u0434\u0430\u0435\u0442 \u043d\u0435 \u0447\u0438\u0441\u043b\u043e \u043f\u043e\u0442\u043e\u043a\u043e\u0432, \u0430 \u0440\u0430\u0437\u043c\u0435\u0440 \u043f\u0443\u043b\u0430 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439.<\/p>\n<p><strong>\u041d\u0430 Native<\/strong> \u043a\u043e\u0440\u0443\u0442\u0438\u043d\u044b \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0435 \u2014 \u0443 Kotlin\/Native \u0434\u0430\u0432\u043d\u043e \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u044b\u0439 \u0440\u0430\u043d\u0442\u0430\u0439\u043c, \u0438 suspendTransaction \u044d\u0442\u043e \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0430\u044f suspend-\u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u0430 \u043d\u0435 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u0432\u044b\u0437\u043e\u0432 \u0432 \u043c\u0430\u0441\u043a\u0435. \u041d\u043e \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0432 Postgres-\u0431\u044d\u043a\u0435\u043d\u0434\u0435: \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0435 \u0447\u0435\u0440\u0435\u0437 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0438\u0439, \u0430 \u0447\u0435\u0440\u0435\u0437 <strong>\u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 API libpq<\/strong> \u0438 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 socket-\u0440\u0435\u0430\u043a\u0442\u043e\u0440 (poll \u043d\u0430 Unix, WSAPoll \u043d\u0430 Windows). \u041f\u043e\u043a\u0430 \u0437\u0430\u043f\u0440\u043e\u0441 \u0436\u0434\u0435\u0442 \u043e\u0442\u0432\u0435\u0442\u0430 \u043e\u0442 \u0441\u0435\u0442\u0438, \u043a\u043e\u0440\u0443\u0442\u0438\u043d\u0430 \u043f\u043e-\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u043c\u0443 \u043f\u0440\u0438\u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u043e\u0442\u043e\u043a \u0432 \u043f\u0443\u043b \u2014 \u0442\u043e\u0442 \u0436\u0435 \u044d\u0444\u0444\u0435\u043a\u0442, \u0447\u0442\u043e Loom \u0434\u0430\u0435\u0442 \u043d\u0430 JVM, \u0442\u043e\u043b\u044c\u043a\u043e \u0431\u0435\u0437 \u0432\u0441\u044f\u043a\u043e\u0439 JVM.<\/p>\n<p>\u0410 \u0442\u0430\u043c, \u0433\u0434\u0435 \u0443 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430 \u043d\u0435\u0442 \u043d\u0435\u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e API (SQLite, MySQL \u0447\u0435\u0440\u0435\u0437 libmariadb, \u043f\u043b\u044e\u0441 \u0444\u043e\u043b\u043b\u0431\u044d\u043a Postgres \u043d\u0430 Windows), Kormium \u0447\u0435\u0441\u0442\u043d\u043e \u043e\u0444\u0444\u043b\u043e\u0430\u0434\u0438\u0442 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0438\u0439 \u0432\u044b\u0437\u043e\u0432 \u043d\u0430 \u043f\u0443\u043b \u043f\u043e\u0442\u043e\u043a\u043e\u0432 (Dispatchers.Default, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 Dispatchers.IO \u043d\u0430 Native \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442 \u0432 \u043f\u0443\u0431\u043b\u0438\u0447\u043d\u044b\u0439 API). \u0418\u0442\u043e\u0433: \u0432\u044b \u043f\u0438\u0448\u0435\u0442\u0435 \u043e\u0431\u044b\u0447\u043d\u044b\u0439 suspend-\u043a\u043e\u0434, \u0430 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0435 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u043d\u0435\u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0443\u044e \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 \u0441\u0435\u0442\u044c\u044e \u0442\u0430\u043c, \u0433\u0434\u0435 \u044d\u0442\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e.<\/p>\n<h4>3. \u0427\u0435\u0441\u0442\u043d\u0430\u044f \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0430 \u0447\u0430\u0441\u0442\u0438\u0447\u043d\u044b\u0445 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0439<\/h4>\n<p>\u0412 Kormium \u0447\u0435\u0442\u043a\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u044b null \u0438 \u00ab\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043d\u0435 \u0437\u0430\u0434\u0430\u043d\u043e\u00bb. \u0421\u0443\u0449\u043d\u043e\u0441\u0442\u044c \u0445\u0440\u0430\u043d\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u043f\u0440\u0438\u0441\u0432\u043e\u0435\u043d\u043d\u044b\u0435 \u043f\u043e\u043b\u044f, \u0438 \u0435\u0441\u043b\u0438 \u043f\u043e\u043b\u0435 \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u043b\u0438 (entity.isSet(column) \u0432\u0435\u0440\u043d\u0435\u0442 false), \u043e\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u043f\u043e\u043f\u0430\u0434\u0435\u0442 \u0432 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u043c\u044b\u0439 INSERT \u0438\u043b\u0438 UPDATE:<\/p>\n<p>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/><code>\u00a0 \u00a0\/\/ \u043c\u0435\u043d\u044f\u0435\u043c \u0442\u043e\u043b\u044c\u043a\u043e email \u2014 age, name \u0438 \u043f\u0440\u043e\u0447\u0438\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u0437\u0430\u043f\u0440\u043e\u0441 \u043d\u0435 \u0442\u0440\u043e\u043d\u0435\u0442\u00a0 \u00a0 <br \/>\u00a0 \u00a0 Users.update(User().apply { email = \"new@example.com\" }) {\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 where { Users.id eq 42 }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \/\/ UPDATE users SET email = $1 WHERE id = $2\u00a0 \u00a0 <br \/><\/code><\/p>\n<p>\u042d\u0442\u043e \u0442\u043e, \u0447\u0442\u043e \u0432\u043e \u043c\u043d\u043e\u0433\u0438\u0445 ORM \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u0435\u0442\u0441\u044f \u0432 \u0433\u043e\u043b\u043e\u0432\u043d\u0443\u044e \u0431\u043e\u043b\u044c: \u0437\u0434\u0435\u0441\u044c \u0436\u0435 \u0434\u0435\u0444\u043e\u043b\u0442\u044b \u043d\u0430 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 \u0411\u0414, generated-\u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u0438 \u0447\u0430\u0441\u0442\u0438\u0447\u043d\u044b\u0435 \u043f\u0430\u0442\u0447\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e \u2014 \u0432\u044b \u043d\u0435 \u0437\u0430\u0442\u0438\u0440\u0430\u0435\u0442\u0435 NULL-\u043e\u043c \u0442\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0438\u0441\u044c \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0442\u044c.<\/p>\n<h4>4. \u0420\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 (kormium-observe)<\/h4>\n<p>\u041b\u044e\u0431\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0434\u043f\u0438\u0441\u0430\u0442\u044c \u043a\u0430\u043a Flow \u0438 \u0437\u0430\u0431\u044b\u0442\u044c \u043f\u0440\u043e \u0440\u0443\u0447\u043d\u043e\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445. \u041f\u043e\u0442\u043e\u043a \u0441\u0440\u0430\u0437\u0443 \u043e\u0442\u0434\u0430\u0435\u0442 \u0442\u0435\u043a\u0443\u0449\u0438\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u0430 \u043f\u043e\u0442\u043e\u043c \u0441\u0430\u043c \u043f\u0440\u0438\u0441\u044b\u043b\u0430\u0435\u0442 \u043d\u043e\u0432\u044b\u0439 \u043a\u0430\u0436\u0434\u044b\u0439 \u0440\u0430\u0437, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043e\u0442\u0441\u043b\u0435\u0436\u0438\u0432\u0430\u0435\u043c\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043f\u0440\u043e\u0448\u043b\u0430 \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<p>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<br \/><code>\u00a0 \u00a0 Users.observe(db) { where { Users.age gtEq 18 } }\u00a0 \u00a0 <br \/>\u00a0 \u00a0 \u00a0 \u00a0 .collect { adults -&gt; \/* UI\/\u043a\u044d\u0448 \u0441\u0430\u043c\u0438 \u043e\u0431\u043d\u043e\u0432\u044f\u0442\u0441\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u043a\u043e\u043c\u043c\u0438\u0442 *\/ }\u00a0 \u00a0 <br \/><\/code><\/p>\n<p>\u042d\u0442\u043e \u043a\u0430\u043a \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432 Room, \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f Kotlin Multiplatform: \u044d\u043a\u0440\u0430\u043d \u043d\u0430 Compose \u0438\u043b\u0438 \u043a\u044d\u0448 \u0432\u0441\u0435\u0433\u0434\u0430 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u0441\u0432\u0435\u0436\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0435, \u0438 \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0432\u0440\u0443\u0447\u043d\u0443\u044e \u0434\u0435\u0440\u0433\u0430\u0442\u044c \u0431\u0430\u0437\u0443, \u0447\u0442\u043e\u0431\u044b \u0438\u0445 \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c. \u0410 \u0435\u0441\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u044e\u0442 \u043f\u0430\u0447\u043a\u043e\u0439, Kormium \u043d\u0435 \u043f\u0435\u0440\u0435\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0435 \u2014 \u043e\u043d \u0441\u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u043e\u0434\u0438\u043d \u0440\u0430\u0437, \u043a\u043e\u0433\u0434\u0430 \u0432\u043e\u043b\u043d\u0430 \u0441\u0445\u043b\u044b\u043d\u0435\u0442.<\/p>\n<h4>5. SQL \u043d\u0435 \u043f\u0440\u044f\u0447\u0435\u0442\u0441\u044f<\/h4>\n<p>raw SQL \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u043b\u0435\u0433\u0430\u043b\u044c\u043d\u044b\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u043c (escape hatch) \u0434\u043b\u044f \u0441\u043b\u043e\u0436\u043d\u044b\u0445 DDL \u0438 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u044b\u0445 \u0444\u0438\u0447 \u0421\u0423\u0411\u0414 \u2014 Kormium \u043d\u0435 \u043f\u044b\u0442\u0430\u0435\u0442\u0441\u044f \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u043e\u0442 \u0432\u0430\u0441 \u0431\u0430\u0437\u0443. \u0424\u0438\u043b\u043e\u0441\u043e\u0444\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u0430\u044f: \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c \u0441\u0432\u043e\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0430 \u043d\u0435 \u0432\u043e\u0435\u0432\u0430\u0442\u044c \u0441 \u043f\u0440\u043e\u0442\u0435\u043a\u0430\u044e\u0449\u0435\u0439 \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0446\u0438\u0435\u0439. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0432\u0441\u0435, \u0447\u0442\u043e \u0438\u0434\u0435\u0442 \u0447\u0435\u0440\u0435\u0437 DSL, \u043f\u043e-\u043f\u0440\u0435\u0436\u043d\u0435\u043c\u0443 \u0441\u0442\u0440\u043e\u0433\u043e \u0431\u0438\u043d\u0434\u0438\u0442\u0441\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438, \u0442\u0430\u043a \u0447\u0442\u043e \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u043e escape hatch \u043d\u0435 \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0434\u0432\u0435\u0440\u044c SQL-\u0438\u043d\u044a\u0435\u043a\u0446\u0438\u044f\u043c.<\/p>\n<p>\u041f\u0440\u0438 \u044d\u0442\u043e\u043c raw SQL \u043d\u0435 \u0432\u044b\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0438\u0437 \u0444\u0438\u0447\u0438 \u21164. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0442\u043e \u043f\u043e \u0442\u043e\u0439 \u0436\u0435 \u043c\u043e\u0434\u0435\u043b\u0438, \u0447\u0442\u043e \u0438 \u0432 Room: \u043f\u043e\u0441\u043b\u0435 \u043a\u043e\u043c\u043c\u0438\u0442\u0430 Kormium \u0441\u043c\u043e\u0442\u0440\u0438\u0442, \u043a\u0430\u043a\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0431\u044b\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u044b, \u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u043f\u043e\u0434\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u043d\u0430 \u043d\u0438\u0445 observe-\u0437\u0430\u043f\u0440\u043e\u0441\u044b. \u0415\u0441\u043b\u0438 \u0441\u044b\u0440\u043e\u0439 SQL \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d \u0447\u0435\u0440\u0435\u0437 \u043e\u0431\u044a\u0435\u043a\u0442 \u0442\u0430\u0431\u043b\u0438\u0446\u044b (Users.execSql(&#8230;)), \u043e\u043d\u0430 \u043f\u043e\u043c\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u043d\u043e\u0439 \u0441\u0430\u043c\u0430 \u0441\u043e\u0431\u043e\u0439 \u2014 \u0438 \u043f\u043e\u0434\u043f\u0438\u0441\u043a\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0431\u0435\u0437 \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439. \u0414\u043b\u044f \u0441\u043e\u0432\u0441\u0435\u043c \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e raw SQL, \u043d\u0435 \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0435, \u043e\u0442 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 \u043d\u0443\u0436\u043d\u043e \u043b\u0438\u0448\u044c \u043e\u0434\u043d\u043e \u2014 \u044f\u0432\u043d\u043e \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u0437\u0430\u0442\u0440\u043e\u043d\u0443\u0442\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b (\u0442\u043e\u0447\u043d\u043e \u043a\u0430\u043a observedEntities \u0434\u043b\u044f @RawQuery \u0432 Room), \u0438 \u0438\u043d\u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0441\u043d\u043e\u0432\u0430 \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<\/p>\n<h3>\u041f\u043e\u0447\u0435\u043c\u0443 \u0432 Kormium \u043d\u0435\u0442 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0433\u043e \u043a\u044d\u0448\u0430?<\/h3>\n<p>\u042d\u0442\u043e \u043e\u0434\u0438\u043d \u0438\u0437 \u0447\u0430\u0441\u0442\u044b\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u0442\u0432\u0435\u0447\u0443 \u043f\u0440\u044f\u043c\u043e: \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0433\u043e L2-\u043a\u044d\u0448\u0430 (\u0432 \u0434\u0443\u0445\u0435 second-level cache \u0432 Hibernate) \u0432 Kormium \u043d\u0435\u0442, \u0438 \u044d\u0442\u043e \u043e\u0441\u043e\u0437\u043d\u0430\u043d\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u0430 \u043d\u0435 \u00ab\u043d\u0435 \u0443\u0441\u043f\u0435\u043b\u00bb.<\/p>\n<ul>\n<li>\n<p><strong>\u041a\u043e\u043c\u043f\u0435\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u0447\u0435\u0433\u043e.<\/strong> L2-\u043a\u044d\u0448 \u0432 Hibernate \u0432\u043e \u043c\u043d\u043e\u0433\u043e\u043c \u043b\u0435\u0447\u0438\u0442 \u0435\u0433\u043e \u0436\u0435 \u043c\u043e\u0434\u0435\u043b\u044c: identity map, \u043b\u0435\u043d\u0438\u0432\u044b\u0435 \u0433\u0440\u0430\u0444\u044b, N+1, \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u0443\u044e \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. Kormium \u2014 \u0442\u043e\u043d\u043a\u0438\u0439 \u044f\u0432\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u043d\u0430\u0434 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u043e\u043c, \u0432\u0441\u0435\u0433\u043e \u044d\u0442\u043e\u0433\u043e \u0432 \u043d\u0435\u043c \u043d\u0435\u0442, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0438 \u043f\u0440\u044f\u0442\u0430\u0442\u044c \u0437\u0430 \u043a\u044d\u0448\u0435\u043c \u043d\u0435\u0447\u0435\u0433\u043e.<\/p>\n<\/li>\n<li>\n<p><strong>\u041f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u044b\u0439 \u043a\u044d\u0448 \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u0440\u0435\u0447\u0438\u0442 \u0444\u0438\u043b\u043e\u0441\u043e\u0444\u0438\u0438.<\/strong> \u041e\u043d \u043f\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044e \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0441\u0435\u0442\u0435\u0432\u044b\u0435 round-trip&#8217;\u044b, \u0430 \u0432\u0435\u0441\u044c \u0441\u043c\u044b\u0441\u043b Kormium \u2014 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0441 \u0431\u0430\u0437\u043e\u0439. \u041d\u0435\u0437\u0430\u043c\u0435\u0442\u043d\u044b\u0439 \u0441\u043b\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0438\u043d\u043e\u0433\u0434\u0430 \u0445\u043e\u0434\u0438\u0442 \u0432 \u0411\u0414, \u0430 \u0438\u043d\u043e\u0433\u0434\u0430 \u043d\u0435\u0442, \u043b\u043e\u043c\u0430\u0435\u0442 \u044d\u0442\u0443 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e\u0441\u0442\u044c.<\/p>\n<\/li>\n<li>\n<p><strong>\u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0439 \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u044b\u0439 \u043a\u044d\u0448 \u0434\u043e\u0440\u043e\u0433 \u0438 \u043e\u043f\u0430\u0441\u0435\u043d.<\/strong> \u0414\u043b\u044f \u0446\u0435\u043b\u0435\u0432\u043e\u0433\u043e multi-instance \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044f \u0447\u0435\u0441\u0442\u043d\u044b\u0439 L2 \u2014 \u044d\u0442\u043e Redis \u043f\u043b\u044e\u0441 \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043a\u043e\u043d\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438, \u0438\u043d\u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u043f\u043e \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u043c\u0443 \u043a\u043b\u044e\u0447\u0443 \u0438 TTL-\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u043a\u0430. \u042d\u0442\u043e \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u044c \u0434\u043b\u044f \u0442\u0438\u0445\u0438\u0445 stale-after-write \u0431\u0430\u0433\u043e\u0432 \u2014 \u0445\u0443\u0434\u0448\u0435\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u043e\u0448\u0438\u0431\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043f\u0430\u0434\u0430\u044e\u0442, \u0430 \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u0434\u0430\u044e\u0442 \u0443\u0441\u0442\u0430\u0440\u0435\u0432\u0448\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0435.<\/p>\n<\/li>\n<li>\n<p><strong>\u041f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0441\u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u043b\u0443\u0447\u0448\u0435.<\/strong> \u041e\u043d\u043e \u0437\u043d\u0430\u0435\u0442 \u0441\u0432\u043e\u0439 \u0434\u043e\u043c\u0435\u043d: \u0433\u0434\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0433\u043e\u0440\u044f\u0447\u0438\u0435, \u043a\u0430\u043a\u043e\u0439 TTL \u0434\u043e\u043f\u0443\u0441\u0442\u0438\u043c, \u0433\u0434\u0435 \u043c\u043e\u0436\u043d\u043e \u0436\u0438\u0442\u044c \u0441 eventual consistency. \u041a\u044d\u0448 \u0432 \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u043e\u043c \u0441\u043b\u043e\u0435 (Caffeine \u0438\u043b\u0438 Redis, read-through) \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0449\u0435, \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u0435\u0435 \u0438 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0435\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u043e\u0433\u043e.<\/p>\n<\/li>\n<\/ul>\n<p>\u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0442\u0435\u043c\u0430 \u043a\u044d\u0448\u0430 \u043d\u0435 \u0437\u0430\u043a\u0440\u044b\u0442\u0430 \u2014 \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u044b\u043d\u0435\u0441\u0435\u043d\u0430 \u043d\u0430\u0440\u0443\u0436\u0443. Kormium \u0434\u0430\u0435\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0441\u0442\u0440\u043e\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0431\u043b\u043e\u043a \u2014 \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439 observe: \u043f\u043e\u0432\u0435\u0440\u0445 \u043d\u0435\u0433\u043e \u043a\u044d\u0448 \u0441 \u043d\u0443\u0436\u043d\u043e\u0439 \u0438\u043c\u0435\u043d\u043d\u043e \u0432\u0430\u043c \u043f\u043e\u043b\u0438\u0442\u0438\u043a\u043e\u0439 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0432 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0440\u043e\u043a. \u0410 \u0432 \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0435\u043c \u0440\u0435\u043b\u0438\u0437\u0435 \u043f\u043e\u0434\u044a\u0435\u0434\u0443\u0442 \u0438 \u043a\u0440\u043e\u0441\u0441-\u0438\u043d\u0441\u0442\u0430\u043d\u0441\u043d\u044b\u0435 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f \u043e\u0431 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f\u0445 (\u0447\u0435\u0440\u0435\u0437 Postgres LISTEN\/NOTIFY, R2DBC \u0438\u043b\u0438 \u0432\u043d\u0435\u0448\u043d\u0438\u0439 \u0431\u0440\u043e\u043a\u0435\u0440 \u0432\u0440\u043e\u0434\u0435 Redis), \u0447\u0442\u043e\u0431\u044b \u0438\u043d\u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0430 \u0438 \u043c\u0435\u0436\u0434\u0443 \u043f\u043e\u0434\u0430\u043c\u0438 \u2014 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u0443\u0436\u0435 \u043b\u0435\u0436\u0438\u0442 \u0432 <u>samples\/cross-instance-cache<\/u>.<\/p>\n<h3>\u0427\u0442\u043e \u0441 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c\u044e?<\/h3>\n<p>\u042f \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u043e \u0433\u043e\u043d\u044f\u044e \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0438 (\u0432\u0441\u0435 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438 \u0438 runnable-\u043f\u0440\u0438\u043c\u0435\u0440\u044b \u0441\u043e \u0441\u043a\u0432\u043e\u0437\u043d\u044b\u043c \u043b\u043e\u0433\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c, \u0448\u0430\u0440\u0434\u0438\u043d\u0433\u043e\u043c \u0438 Ktor CRUD \u043b\u0435\u0436\u0430\u0442 \u0432 <u>samples\/<\/u>).<\/p>\n<p>\u041d\u0430 JVM: Kormium \u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0441\u043e\u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043c \u0441 Exposed. \u0411\u043e\u043b\u0435\u0435 \u0442\u043e\u0433\u043e, \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 0.5.0 \u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0431\u0438\u043d\u0434\u0438\u043d\u0433 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u0434\u043b\u044f Postgres, \u0443\u0431\u0440\u0430\u0432 \u043b\u0438\u0448\u043d\u0438\u0439 round-trip \u043f\u0440\u043e\u0442\u043e\u043a\u043e\u043b\u0430, \u0447\u0442\u043e \u043f\u043e wire-\u0442\u0440\u0435\u0439\u0441\u0443 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0437\u0430\u043a\u0440\u044b\u043b\u043e \u0440\u0430\u0437\u0440\u044b\u0432 \u043f\u043e \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f\u043c \u0447\u0442\u0435\u043d\u0438\u044f \u0441 Hibernate.<\/p>\n<p>\u041d\u0430 Native (Linux\/macOS): \u041d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u044d\u043a\u0435\u043d\u0434 \u043d\u0430 \u0431\u0430\u0437\u0435 libpq \u0437\u0430 \u0441\u0447\u0435\u0442 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u044f \u043e\u0432\u0435\u0440\u0445\u0435\u0434\u0430 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u043e\u0439 \u043c\u0430\u0448\u0438\u043d\u044b \u043d\u0430 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f\u0445 \u0447\u0442\u0435\u043d\u0438\u044f \u043e\u0431\u0445\u043e\u0434\u0438\u0442 JVM-\u0432\u0430\u0440\u0438\u0430\u043d\u0442 (\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0438\u0440\u0443\u044f \u043f\u043e\u0440\u044f\u0434\u043a\u0430 ~13k \u043f\u0440\u043e\u0442\u0438\u0432 ~8k ops\/s \u0432 8 \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u043d\u0430 \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u043c \u0441\u0442\u0435\u043d\u0434\u0435).<\/p>\n<p>\u0423\u0441\u043b\u043e\u0432\u0438\u044f \u0437\u0430\u043c\u0435\u0440\u0430: PostgreSQL 16 (postgres:16-alpine) \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u043d\u0430 tmpfs \u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044b\u043c\u0438 fsync \/ synchronous_commit \/ full_page_writes \u2014 \u043c\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043e\u0432\u0435\u0440\u0445\u0435\u0434 ORM \u0438 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430, \u0430 \u043d\u0435 \u043b\u0430\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u0434\u0438\u0441\u043a\u0430; 8 \u0440\u0430\u0431\u043e\u0447\u0438\u0445 \u043f\u043e\u0442\u043e\u043a\u043e\u0432, \u043f\u0443\u043b \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 8, \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f findById (SELECT \u043f\u043e \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u043c\u0443 \u043a\u043b\u044e\u0447\u0443, autocommit). JVM-\u0446\u0438\u0444\u0440\u044b \u2014 \u0447\u0435\u0440\u0435\u0437 JMH (2 \u0444\u043e\u0440\u043a\u0430, 5\u00d72s \u043f\u0440\u043e\u0433\u0440\u0435\u0432 + 5\u00d72s \u0437\u0430\u043c\u0435\u0440), \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u2014 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 release-\u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a \u043e\u0434\u043d\u0438\u043c \u043f\u0440\u043e\u0433\u043e\u043d\u043e\u043c (\u0431\u0435\u0437 JMH, \u043f\u043e\u0442\u043e\u043c\u0443 \u0433\u0440\u0443\u0431\u0435\u0435). \u0416\u0435\u043b\u0435\u0437\u043e: \u00a0Apple m4 16gb.<\/p>\n<p>\u0415\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0432\u0441\u0435 \u0446\u0438\u0444\u0440\u044b \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u044b \u2014 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0439\u0442\u0435 \u043d\u0430 \u0441\u0432\u043e\u0435\u043c \u0436\u0435\u043b\u0435\u0437\u0435 \u0438 \u0441\u0432\u043e\u0438\u0445 \u043f\u0440\u043e\u0444\u0438\u043b\u044f\u0445 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438.<\/p>\n<h3>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h3>\n<p>Kormium \u0432\u044b\u0440\u043e\u0441 \u0438\u0437 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u043e\u0439 \u0431\u043e\u043b\u0438 \u2014 Cold Start \u0432 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u043e\u0439 \u0441\u0440\u0435\u0434\u0435 \u2014 \u0438 \u0437\u0430\u0442\u0430\u0447\u0438\u0432\u0430\u043b\u0441\u044f \u043f\u043e\u0434 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438, \u0433\u0434\u0435 \u0431\u044b\u0441\u0442\u0440\u044b\u0439 \u0438 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u044b\u0439 \u0441\u0442\u0430\u0440\u0442 \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u0440\u0435\u0448\u0430\u0435\u0442. \u041b\u0443\u0447\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u043e\u043d \u0440\u0430\u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u0432\u044b:<\/p>\n<ul>\n<li>\n<p>\u0438\u0434\u0435\u0442\u0435 \u0441 Kotlin Multiplatform \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440 \u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u043e\u0434\u0438\u043d \u0438 \u0442\u043e\u0442 \u0436\u0435 \u0442\u0438\u043f\u043e\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 JVM \u0438 Native;<\/p>\n<\/li>\n<li>\n<p>\u0441\u0442\u0440\u043e\u0438\u0442\u0435 Serverless- \u0438\u043b\u0438 scale-to-zero-\u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443, \u0433\u0434\u0435 \u0432\u0440\u0435\u043c\u044f \u0441\u0442\u0430\u0440\u0442\u0430 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0441\u0442\u044c;<\/p>\n<\/li>\n<li>\n<p>\u043f\u0438\u0448\u0435\u0442\u0435 \u043b\u0435\u0433\u043a\u0438\u0435 CLI-\u0443\u0442\u0438\u043b\u0438\u0442\u044b \u0438\u043b\u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 PostgreSQL \u0438\u043b\u0438 MySQL \u0431\u0435\u0437 JVM \u043f\u043e\u0434 \u043d\u043e\u0433\u0430\u043c\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0446\u0435\u043d\u0438\u0442\u0435, \u043a\u043e\u0433\u0434\u0430 SQL \u043d\u0435 \u043f\u0440\u044f\u0447\u0435\u0442\u0441\u044f, \u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0438 \u0438 \u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440, \u0430 \u043d\u0435 \u0440\u0430\u043d\u0442\u0430\u0439\u043c.<\/p>\n<\/li>\n<\/ul>\n<p>\u041e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u043b\u044e\u0441 \u2014 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u043d\u0435 \u043e\u0431\u044f\u0437\u0430\u043d\u043e \u0431\u044b\u0442\u044c \u00ab\u0432\u0441\u0435 \u0438\u043b\u0438 \u043d\u0438\u0447\u0435\u0433\u043e\u00bb: shared-\u043c\u043e\u0434\u0443\u043b\u044c \u0441 \u0434\u043e\u043c\u0435\u043d\u043d\u043e\u0439 \u043b\u043e\u0433\u0438\u043a\u043e\u0439 \u0438 DSL Kormium \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u043e\u0439 JVM \u0443\u0436\u0435 \u0441\u0435\u0433\u043e\u0434\u043d\u044f, \u0430 \u043d\u0430 Native \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u0440\u043e\u0432\u043d\u043e \u0442\u043e\u0433\u0434\u0430, \u043a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e \u0441\u0442\u0430\u043d\u0435\u0442 \u0432\u044b\u0433\u043e\u0434\u043d\u043e \u043f\u043e \u0437\u0430\u043c\u0435\u0440\u0430\u043c. \u0422\u0430\u043a \u0447\u0442\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0431\u0435\u0437 \u0440\u0435\u0437\u043a\u0438\u0445 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0439 \u0432 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435.<\/p>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0435\u0442\u0441\u044f: \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f, \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u0433\u0430\u0439\u0434 \u0438 compatibility policy \u043d\u0430 \u043c\u0435\u0441\u0442\u0435. \u0415\u0441\u043b\u0438 \u0445\u043e\u0442\u044c \u043e\u0434\u0438\u043d \u0438\u0437 \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u0432\u044b\u0448\u0435 \u2014 \u043f\u0440\u043e \u0432\u0430\u0441, \u0437\u0430\u0433\u043b\u044f\u0434\u044b\u0432\u0430\u0439\u0442\u0435 \u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439, \u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u043d\u0430 \u0441\u0432\u043e\u0435\u043c \u043a\u0435\u0439\u0441\u0435 \u0438 \u0437\u0430\u0432\u043e\u0434\u0438\u0442\u0435 issues: \u043e\u0431\u0440\u0430\u0442\u043d\u0430\u044f \u0441\u0432\u044f\u0437\u044c \u043d\u0430 \u0441\u0442\u0430\u0434\u0438\u0438 pre-1.0 \u0441\u0435\u0439\u0447\u0430\u0441 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0446\u0435\u043d\u043d\u0430.<\/p>\n<p>\u041f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435, \u043e \u0447\u0435\u043c \u0448\u043b\u0430 \u0440\u0435\u0447\u044c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435, \u0435\u0441\u0442\u044c \u0440\u0430\u0431\u043e\u0447\u0438\u043c\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u043c\u0438 \u0432 <u>samples<\/u>: \u043c\u0443\u043b\u044c\u0442\u0438\u043a\u0430\u0442\u0430\u043b\u043e\u0433 \u0438 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043a\u044d\u0448 (sqlite-cache), \u0448\u0430\u0440\u0434\u0438\u043d\u0433 (sharding), Ktor CRUD \u0441 DI (ktor-di, ktor-koin), async \u0447\u0435\u0440\u0435\u0437 R2DBC (r2dbc) \u0438 \u043a\u0440\u043e\u0441\u0441-\u0438\u043d\u0441\u0442\u0430\u043d\u0441\u043d\u044b\u0439 \u043a\u044d\u0448 \u043d\u0430 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f\u0445 (cross-instance-cache, \u043d\u0430 \u043f\u043e\u0434\u0445\u043e\u0434\u0435 \u043a \u0440\u0435\u043b\u0438\u0437\u0443). \u0418\u0445 \u043c\u043e\u0436\u043d\u043e \u043a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c, \u0430 \u043d\u0435 \u0432\u0435\u0440\u0438\u0442\u044c \u043d\u0430 \u0441\u043b\u043e\u0432\u043e.<\/p>\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u0441 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u0442\u044c\u0441\u044f \u043d\u0430 gihtub: <a href=\"https:\/\/github.com\/kormium\/kormium\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/kormium\/kormium<\/a><\/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\/1050588\/\">https:\/\/habr.com\/ru\/articles\/1050588\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0412\u0441\u0435 \u043d\u0430\u0447\u0430\u043b\u043e\u0441\u044c \u0441 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0433\u043e \u0442\u0443\u043f\u0438\u043a\u0430. \u042f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u0431\u044d\u043a\u0435\u043d\u0434-\u0447\u0430\u0441\u0442\u044c\u044e low-code \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b, \u0434\u043b\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0432 \u043a\u0440\u0443\u043f\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0439. \u0423 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b \u0431\u044b\u043b\u0430 \u0436\u0435\u0441\u0442\u043a\u0430\u044f \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430 \u2014 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0438 \u0445\u0430\u0440\u0434\u043a\u043e\u0440\u043d\u044b\u0439 \u043e\u0444\u0444\u043b\u0430\u0439\u043d-\u0440\u0435\u0436\u0438\u043c. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438\u00a0 \u2014\u00a0 \u043f\u0440\u043e\u0440\u0430\u0431\u044b \u043d\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0442\u0440\u043e\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u0445 \u0438 \u0433\u0435\u043e\u043b\u043e\u0433\u0438 \u0432 \u0442\u0430\u0439\u0433\u0435, \u0433\u0434\u0435 \u0441\u0432\u044f\u0437\u044c \u043f\u0440\u043e\u043f\u0430\u0434\u0430\u0435\u0442 \u043d\u0435 \u043d\u0430 \u043f\u0430\u0440\u0443 \u043c\u0438\u043d\u0443\u0442, \u0430 \u043d\u0430 \u0446\u0435\u043b\u044b\u0435 \u0434\u043d\u0438.\u041f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0434\u043e\u043b\u0436\u043d\u043e \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u043e \u0436\u0438\u0442\u044c \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e: \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0437\u0430\u0431\u0438\u0432\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435, \u043c\u0435\u043d\u044f\u0435\u0442 \u0441\u0442\u0430\u0442\u0443\u0441\u044b \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439, \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u044b, \u043f\u0440\u0438\u043a\u0440\u0435\u043f\u043b\u044f\u0435\u0442 \u0444\u043e\u0442\u043e. \u0410 \u0437\u0430\u0442\u0435\u043c, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0435\u0442\u044c, \u043d\u0430 \u0431\u044d\u043a\u0435\u043d\u0434 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u0435\u0442 \u043b\u0430\u0432\u0438\u043d\u0430 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0439.\u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0430 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u0430\u044f, \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u043d\u0430\u044f \u0438 \u043a\u0440\u0443\u0442\u0438\u0442\u0441\u044f \u0432 Kubernetes, \u044f \u0431\u044b\u0441\u0442\u0440\u043e \u0443\u043f\u0435\u0440\u0441\u044f \u0432 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u043d\u0435\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0440\u0435\u0441\u0443\u0440\u0441\u043e\u0432. \u0422\u0435\u043d\u0430\u043d\u0442 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u043c\u043e\u0436\u0435\u0442 \u00ab\u0441\u043f\u0430\u0442\u044c\u00bb \u0447\u0430\u0441\u0430\u043c\u0438 \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0434\u043d\u044f\u043c\u0438, \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0442\u0440\u0430\u0444\u0438\u043a\u0430, \u0430 \u043f\u043e\u0442\u043e\u043c \u043f\u0430\u0447\u043a\u0430 \u044e\u0437\u0435\u0440\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0438\u0437 \u043e\u0444\u0444\u043b\u0430\u0439\u043d\u0430, \u0438 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0430 \u043d\u0430 \u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0437\u043b\u0435\u0442\u0430\u0435\u0442 \u043f\u043e \u044d\u043a\u0441\u043f\u043e\u043d\u0435\u043d\u0442\u0435. \u0414\u0435\u0440\u0436\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u043d\u0430\u043d\u0442 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u0437\u0430\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u0435 \u0438 \u043f\u0440\u043e\u0441\u0442\u0430\u0438\u0432\u0430\u044e\u0449\u0438\u0435 \u043f\u043e\u0434\u044b\u00a0 \u0431\u0435\u0437\u0443\u043c\u043d\u043e \u0434\u043e\u0440\u043e\u0433\u043e.\u041b\u043e\u0433\u0438\u0447\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0442\u044c \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043f\u043e \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044e \u0431\u043b\u0438\u0436\u0435 \u043a \u043c\u043e\u043c\u0435\u043d\u0442\u0443 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438. \u0412 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u0435\u0442 \u0431\u044b\u0442\u044c \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0442\u043d\u043e\u0439 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043c\u0435\u0442\u0440\u0438\u043a\u043e\u0439 \u0438 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432\u043b\u0438\u044f\u0442\u044c \u043d\u0430 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0432\u0441\u0435\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b. \u0415\u0441\u043b\u0438 Cold Start \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u0435\u0442\u0441\u044f, \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0443\u043f\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0432 \u043a\u0430\u0441\u043a\u0430\u0434\u043d\u044b\u0439 \u043e\u0442\u043a\u0430\u0437: \u0442\u0430\u0439\u043c\u0430\u0443\u0442\u044b \u0440\u0432\u0443\u0442\u0441\u044f, \u043a\u043b\u0438\u0435\u043d\u0442\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0430\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u044b\u0435 \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u044b\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 (retry storms), \u0430 \u0437\u0430\u0449\u0438\u0442\u043d\u044b\u0435 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u044b \u0432\u0440\u043e\u0434\u0435 Rate Limiting \u0438 Circuit Breaker \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0432\u0435\u0435\u0440\u043d\u043e \u043e\u0442\u0440\u0443\u0431\u0430\u0442\u044c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439, \u0447\u0442\u043e\u0431\u044b \u0441\u043f\u0430\u0441\u0442\u0438 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043e\u0442 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u0435\u0433\u0440\u0430\u0434\u0430\u0446\u0438\u0438. \u0411\u044b\u0441\u0442\u0440\u044b\u0439 \u0441\u0442\u0430\u0440\u0442 \u0441\u0442\u0430\u043b \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c \u0443\u0441\u043f\u0435\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u0432\u0441\u043f\u043b\u0435\u0441\u043a \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0430\u0432\u0430\u0440\u0438\u0439\u043d\u044b\u0435 \u043f\u0440\u0435\u0434\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435\u043b\u0438.\u041a\u0430\u043a \u044f \u0443\u0445\u043e\u0434\u0438\u043b \u043e\u0442 JVM\u042f \u043d\u0435 \u0441\u0442\u0430\u043b \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0432\u0441\u0435 \u0437\u0430 \u043e\u0434\u0438\u043d \u0440\u0430\u0437, \u0430 \u0434\u0432\u0438\u0433\u0430\u043b\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043f\u043e \u043c\u0435\u0440\u0435 \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433\u0430 \u0438\u043b\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043d\u043e\u0432\u044b\u0445 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432.Ktor + Exposed \u0432\u043c\u0435\u0441\u0442\u043e Spring Boot + Hibernate. \u0422\u0438\u043f\u0438\u0447\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430 Spring \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u0437\u0430 25\u201330 \u0441\u0435\u043a\u0443\u043d\u0434, \u0430 \u043b\u0435\u043d\u0438\u0432\u043e\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0434\u043e \u0411\u0414 \u0432 \u043c\u0443\u043b\u044c\u0442\u0438\u0442\u0435\u043d\u0430\u043d\u0442\u043d\u043e\u0439 \u0441\u0440\u0435\u0434\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u043b\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441. \u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430 Ktor (JVM) \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u043b \u0443\u0436\u0435 \u0437\u0430 2\u20133 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. \u041c\u043d\u0435 \u0431\u044b\u043b \u043a\u0440\u0438\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0430\u0436\u0435\u043d \u043b\u0435\u0433\u043a\u0438\u0439 \u0441\u0442\u0430\u0440\u0442 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c \u043d\u0430\u0434 SQL, \u0430 \u043d\u0435 \u0442\u044f\u0436\u0435\u043b\u0430\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u0430\u044f \u043c\u043e\u0434\u0435\u043b\u044c. \u041d\u0430 \u0432\u0440\u0435\u043c\u044f \u044d\u0442\u043e\u0433\u043e \u0445\u0432\u0430\u0442\u0438\u043b\u043e.GraalVM Native Image. \u0418\u0434\u0435\u044f \u043f\u043e\u043d\u044f\u0442\u043d\u0430\u044f: \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c JVM-\u043b\u0438\u0431\u044b, \u043d\u043e \u0441\u043e\u0431\u0440\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a. \u041d\u043e \u044f \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441 \u0436\u0435\u0441\u0442\u043a\u0438\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438 Closed-World \u2014 GraalVM \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0437\u043d\u0430\u0442\u044c \u0432\u0435\u0441\u044c \u043a\u043e\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u043d\u0435 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0432 runtime. \u041f\u043e\u043c\u0438\u043c\u043e \u0432\u043e\u0439\u043d\u044b \u0441 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u0435\u0439 \u0434\u043b\u044f \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, AOT-\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u043b\u0438\u0448\u0438\u043b\u0430 \u043c\u0435\u043d\u044f JIT-\u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0439 \u043d\u0430 \u0434\u0438\u0441\u0442\u0430\u043d\u0446\u0438\u0438. \u0412\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0432 Community-\u0432\u0435\u0440\u0441\u0438\u0438 GraalVM \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0441\u0442\u0430\u0442\u044c\u0438 \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u044b\u0439 Serial GC, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430 \u0442\u044f\u0436\u0435\u043b\u044b\u0445 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u044f\u0445 \u0443\u0432\u043e\u0434\u0438\u043b \u043f\u043e\u0434\u044b \u0432 Stop-The-World.\u00a0\u0414\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u043a \u044d\u0442\u043e\u043c\u0443 \u0441\u0431\u043e\u0440\u043a\u0438 \u043d\u0430 CI\/CD \u043f\u043e 10 \u043c\u0438\u043d\u0443\u0442 \u0441 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435\u043c \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0433\u0438\u0433\u0430\u0431\u0430\u0439\u0442 RAM \u2014 \u0438 GraalVM \u0441\u0442\u0430\u043b \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043a\u0430\u043a \u0442\u044f\u0436\u0435\u043b\u044b\u0439 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043d\u0430\u043b\u043e\u0433.\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0433\u0438\u043f\u043e\u0442\u0435\u0437\u0443: \u043f\u043e\u0447\u0435\u043c\u0443 \u0434\u043b\u044f R&amp;D \u0431\u044b\u043b \u0432\u044b\u0431\u0440\u0430\u043d Kotlin\/Native?\u0427\u0442\u043e\u0431\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0441\u0430\u043c\u0443 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u044e Scale-to-zero \u0431\u0435\u0437 \u0431\u043e\u043b\u0438 \u0441 GraalVM, \u043c\u043d\u0435 \u043d\u0443\u0436\u0435\u043d \u0431\u044b\u043b \u0447\u0438\u0441\u0442\u044b\u0439 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f. \u0418 \u0438\u0434\u0435\u044f \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c Kotlin\/Native \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u043b\u0430 \u043a\u0430\u043a \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u0448\u0430\u0433 \u0434\u043b\u044f R&amp;D.\u0425\u043e\u0442\u044f Kotlin\/Native \u0441\u0435\u0439\u0447\u0430\u0441 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0440\u043e\u0441\u0442\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0438 \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u043e\u0439 \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u0435\u0433\u043e \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442\u043e\u043c \u0441\u043b\u0443\u0436\u0438\u0442 \u043c\u043e\u0449\u043d\u044b\u0439 \u0438\u043d\u0434\u0443\u0441\u0442\u0440\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 LLVM. \u0411\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0441\u0435\u0440\u044c\u0435\u0437\u043d\u044b\u043c \u0438\u043d\u0432\u0435\u0441\u0442\u0438\u0446\u0438\u044f\u043c \u0441\u043e \u0441\u0442\u043e\u0440\u043e\u043d\u044b JetBrains, \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f \u0441\u0442\u0440\u0435\u043c\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u044d\u0432\u043e\u043b\u044e\u0446\u0438\u043e\u043d\u0438\u0440\u0443\u0435\u0442, \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u044f \u0445\u043e\u0440\u043e\u0448\u0438\u0435 \u043f\u0435\u0440\u0441\u043f\u0435\u043a\u0442\u0438\u0432\u044b \u0434\u043b\u044f \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f Kotlin\/Native \u0432 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u044b\u0439, \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0439 \u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0434\u043b\u044f \u0431\u044d\u043a\u0435\u043d\u0434-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438.\u0412 \u0440\u0430\u043c\u043a\u0430\u0445 \u043c\u043e\u0435\u0433\u043e \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0433\u043b\u0430\u0432\u043d\u044b\u043c \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0435\u043c \u0431\u044b\u043b \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0430\u0440\u0442 \u0437\u0434\u0435\u0441\u044c \u0438 \u0441\u0435\u0439\u0447\u0430\u0441 \u0440\u0430\u0434\u0438 \u0431\u043e\u0440\u044c\u0431\u044b \u0441 Cold Start. \u0418 \u0434\u043b\u044f \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u044d\u0442\u043e\u0439 \u0433\u0438\u043f\u043e\u0442\u0435\u0437\u044b Kotlin\/Native \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u043b \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u043e \u043f\u043e \u0434\u0432\u0443\u043c \u043f\u0440\u0438\u0447\u0438\u043d\u0430\u043c:\u041f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u044b\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0440\u0430\u043d\u0442\u0430\u0439\u043c. \u041a\u043e\u0434 \u0447\u0435\u0440\u0435\u0437 LLVM \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a \u043f\u043e\u0434 Linux x64. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u043c\u0430\u0448\u0438\u043d, \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u043e\u0432\u0435\u0440\u0445\u0435\u0434\u0430 \u0438 \u0441\u043a\u0440\u044b\u0442\u044b\u0445 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0441\u0431\u043e\u0440\u043a\u0438. \u041e\u043d \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e \u0438 \u0432\u0435\u0434\u0435\u0442 \u0441\u0435\u0431\u044f \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e, \u0432\u044b\u0434\u0430\u0432\u0430\u044f \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 memory footprint \u043f\u0440\u044f\u043c\u043e \u0441\u043e \u0441\u0442\u0430\u0440\u0442\u0430.\u041d\u0438\u0437\u043a\u0438\u0439 \u043f\u043e\u0440\u043e\u0433 \u0432\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044f \u0437\u0430 \u0441\u0447\u0435\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0435\u043d\u043d\u043e\u0441\u0442\u0438 (KMP). \u042d\u0442\u043e, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0433\u043b\u0430\u0432\u043d\u044b\u0439 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442. \u041c\u043d\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0443\u0447\u0438\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u043d\u044b\u0439 Go \u0438\u043b\u0438 Rust \u0438 \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u044b \u043d\u0430 \u0447\u0443\u0436\u043e\u043c \u044f\u0437\u044b\u043a\u0435. \u042f \u043c\u043e\u0433 \u0432\u0437\u044f\u0442\u044c \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0443\u044e \u0434\u043e\u043c\u0435\u043d\u043d\u0443\u044e \u043b\u043e\u0433\u0438\u043a\u0443, \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0435\u0435 \u0432 shared-\u043c\u043e\u0434\u0443\u043b\u044c \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u043a \u0432 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u043c \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0435, \u0442\u0430\u043a \u0438 \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0445 JVM-\u0441\u0435\u0440\u0432\u0438\u0441\u0430\u0445.\u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0446\u0435\u043b\u0435\u0432\u043e\u0439 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b JVM \u0438\u043b\u0438 K\/N &#8212; \u044d\u0442\u043e \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0432\u043e\u0431\u043e\u0434\u0430, \u044f \u043c\u043e\u0433\u0443 \u043f\u0440\u044f\u043c\u043e \u0441\u0435\u0439\u0447\u0430\u0441 \u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434 \u0438 \u043a\u0440\u0443\u0442\u0438\u0442\u044c \u0435\u0433\u043e \u043d\u0430 \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u043e\u0439, \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0439 JVM. \u0410 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442, \u043a\u043e\u0433\u0434\u0430 \u0431\u044d\u043a\u0435\u043d\u0434-\u0447\u0430\u0441\u0442\u044c \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440\u0430 Kotlin\/Native \u043e\u043a\u043e\u043d\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u0443\u044e\u0442, \u044f \u0441\u043c\u043e\u0433\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0441\u0431\u043e\u0440\u043a\u0443 \u043d\u0430 Native, \u0435\u0441\u043b\u0438 \u0437\u0430\u043c\u0435\u0440\u044b \u043f\u043e\u043a\u0430\u0436\u0443\u0442, \u0447\u0442\u043e \u0442\u0430\u043a \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u0432\u044b\u0433\u043e\u0434\u043d\u0435\u0435 \u0434\u043b\u044f \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b.\u0414\u043b\u044f \u0446\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0430 \u0432\u0441\u0435 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u043b\u043e\u0441\u044c \u043e\u0442\u043b\u0438\u0447\u043d\u043e. \u0421\u0435\u0442\u0435\u0432\u043e\u0439 \u0441\u043b\u043e\u0439 \u0438 HTTP-\u043a\u043b\u0438\u0435\u043d\u0442\u044b \u0431\u0435\u0437 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0437\u0430\u043a\u0440\u044b\u043b \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0435\u043d\u043d\u044b\u0439 Ktor. \u0414\u043b\u044f \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438 \u0441 Apache Kafka \u0442\u043e\u0436\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u043d\u0430\u0439\u0442\u0438 \u0440\u0430\u0431\u043e\u0447\u0443\u044e \u043e\u0431\u0435\u0440\u0442\u043a\u0443. \u0411\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u0430\u0440\u043a\u0430\u0441 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u0430 \u0441\u043a\u043b\u0435\u0438\u0432\u0430\u043b\u0441\u044f \u0432\u043f\u043e\u043b\u043d\u0435 \u0443\u0441\u043f\u0435\u0448\u043d\u043e.\u0420\u043e\u0432\u043d\u043e \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043d\u0435 \u0434\u043e\u0448\u0435\u043b \u0434\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0431\u0430\u0437\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445. \u0418 \u0432\u043e\u0442 \u0442\u0443\u0442 \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043f\u043e\u043a\u0430 Kotlin\/Native \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u043b\u0441\u044f \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0442\u0443\u043b\u0438\u043d\u0433\u0430, \u0448\u0430\u0440\u0438\u043d\u0433\u0430 \u043a\u043e\u0434\u0430 \u0438 \u0441\u0435\u0442\u0435\u0432\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442.\u0412\u0435\u043b\u0438\u043a\u0430\u044f \u0441\u0442\u0435\u043d\u0430 PostgreSQL \u0432 Kotlin\/Native\u041d\u0430 JVM \u044f \u043f\u0440\u0438\u0432\u044b\u043a \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e JDBC \u0435\u0441\u0442\u044c \u0432\u0441\u0435\u0433\u0434\u0430. \u042d\u0442\u043e \u043d\u0430\u0434\u0435\u0436\u043d\u044b\u0439, \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0439 \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u0438 \u043c\u043e\u043d\u0443\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0441\u0442\u043e\u044f\u0442 Hibernate, Exposed, jOOQ \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0435. JDBC \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0431\u0435\u0440\u0435\u0442 \u043d\u0430 \u0441\u0435\u0431\u044f \u0432\u0441\u044e \u043d\u0438\u0437\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u0443\u044e \u0440\u0443\u0442\u0438\u043d\u0443 \u043e\u0431\u0449\u0435\u043d\u0438\u044f \u0441 \u0421\u0423\u0411\u0414. \u0412 Kotlin\/Native \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e JDBC, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u043d\u0435\u0442.\u0412\u0441\u0435, \u0447\u0442\u043e \u0431\u044b\u043b\u043e \u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432 \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u2014 \u044d\u0442\u043e pgkn, \u043d\u0438\u0437\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u044b\u0439 \u0434\u0440\u0430\u0439\u0432\u0435\u0440, \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0449\u0438\u0439 \u0441\u043e\u0431\u043e\u0439 \u0442\u043e\u043d\u043a\u0438\u0435 \u0431\u0438\u043d\u0434\u0438\u043d\u0433\u0438 \u0432\u043e\u043a\u0440\u0443\u0433 \u0441\u0438\u0448\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 libpq. \u0422\u043e \u0435\u0441\u0442\u044c \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u043a PostgreSQL \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u043c\u043e\u0436\u043d\u043e. \u041d\u043e \u0434\u0430\u043b\u044c\u0448\u0435 \u0432\u044b \u043e\u0441\u0442\u0430\u0435\u0442\u0435\u0441\u044c \u043e\u0434\u0438\u043d \u043d\u0430 \u043e\u0434\u0438\u043d \u0441 \u043d\u0435\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c, \u0441\u044b\u0440\u044b\u043c\u0438 Result Set, \u0440\u0443\u0447\u043d\u044b\u043c \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u043e\u043c \u0438 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u043c\u0438 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u044f\u043c\u0438 DAO-\u043a\u043e\u0434\u0430.\u0412\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0442\u0438\u043f\u0438\u0447\u043d\u043e\u0433\u043e \u0438, \u0447\u0435\u0441\u0442\u043d\u043e \u0433\u043e\u0432\u043e\u0440\u044f, \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u0438\u0441\u0430\u0442\u044c \u043d\u0430 pgkn:\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \u00a0 val list = driver.execute(&#171;SELECT * FROM users&#187;) {\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 mapOf(\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;id&#187; to it.getLong(0),\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;name&#187; to it.getString(1),\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;email&#187; to it.getString(2),\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;bool&#187; to it.getBoolean(3),\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;int&#187; to it.getInt(5),\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 &#171;timestamp&#187; to it.getLocalDateTime(11)\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ &#8230; \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0442\u0438\u043f\u0430 \u0434\u0430\u043d\u043d\u044b\u0445\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 )\u00a0 \u00a0 \u00a0 \u00a0 }\u00a0 \u00a0 \u041e\u0442 \u043f\u0430\u0440\u044b \u0445\u0435\u043b\u043f\u0435\u0440\u043e\u0432 \u043a Kormium\u0421\u0430\u043c\u043e\u0435 \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u2014 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442 \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0443\u0434\u0430\u0447\u043d\u044b\u043c. \u041d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u0440\u0432\u0438\u0441\u0430 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u043c\u0435\u043d\u0435\u0435 \u0447\u0435\u043c \u0437\u0430 0.3 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0438 \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0430\u043b\u0441\u044f \u0432 \u0440\u0430\u0431\u043e\u0442\u0443, \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043b\u0438\u043a\u0432\u0438\u0434\u0438\u0440\u0443\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 Cold Start. \u0413\u0438\u043f\u043e\u0442\u0435\u0437\u0430 \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043b\u0430\u0441\u044c, \u043d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u044f \u0441\u043f\u043e\u0442\u043a\u043d\u0443\u043b\u0441\u044f \u043e \u0441\u0443\u0440\u043e\u0432\u0443\u044e \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u0443\u044e \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c.\u041f\u0438\u0441\u0430\u0442\u044c \u0440\u0443\u0447\u043d\u043e\u0439 \u043c\u0430\u043f\u043f\u0438\u043d\u0433 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u0434\u043b\u044f \u043f\u0430\u0440\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e\u0433\u043e R&amp;D \u2014 \u0442\u0435\u0440\u043f\u0438\u043c\u043e. \u041d\u043e \u044d\u0442\u043e\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043d\u0435 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0438\u0440\u0443\u0435\u0442\u0441\u044f, \u043a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u0442\u044c \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u0443\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443 \u0441 \u0434\u0435\u0441\u044f\u0442\u043a\u0430\u043c\u0438 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041b\u044e\u0431\u043e\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0441\u0445\u0435\u043c\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 PostgreSQL (\u0431\u0430\u043d\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u043c\u0435\u043d\u0430 \u0442\u0438\u043f\u0430 \u0438\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 nullable-\u043f\u043e\u043b\u044f) \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u043b\u043e\u0441\u044c \u0432 \u043a\u043e\u0448\u043c\u0430\u0440: \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u043b\u043e\u0441\u044c \u0440\u0443\u043a\u0430\u043c\u0438 \u0438\u0434\u0442\u0438 \u0432\u043e \u0432\u0441\u0435 \u0444\u0430\u0439\u043b\u044b \u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0432 \u0434\u0443\u0445\u0435 it.getString(X), \u043d\u0430\u0434\u0435\u044f\u0441\u044c \u043d\u0435 \u043e\u0448\u0438\u0431\u0438\u0442\u044c\u0441\u044f \u0441 \u0446\u0438\u0444\u0440\u043e\u0439. \u041e\u0448\u0438\u0431\u043a\u0438 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u043e\u0432\u0430\u043b \u2014 \u0432\u0441\u0435 \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0438\u0441\u044c \u0441\u0442\u0440\u043e\u0433\u043e \u0432 \u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0435.\u041f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0434\u0438\u043b\u0435\u043c\u043c\u0430. \u0421 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u043a\u0430\u043a-\u0442\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u043a\u043e\u0434, \u043d\u0435 \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0432 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u0443\u044e \u0440\u0443\u0442\u0438\u043d\u0443. \u0421 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u0431\u044b\u043b\u043e \u043d\u0435 \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u0435\u0441\u043b\u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e\u0432\u0435\u0440\u0445 libpq \u0432\u044b\u0441\u043e\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u0443\u044e \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0446\u0438\u044e, \u043d\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043b\u0438 \u0442\u0430\u043c \u043e\u0432\u0435\u0440\u0445\u0435\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u0432\u0435\u0434\u0435\u0442 \u043d\u0430 \u043d\u0435\u0442 \u0432\u0441\u044e \u0432\u044b\u0433\u043e\u0434\u0443 \u043e\u0442 \u0431\u044b\u0441\u0442\u0440\u043e\u0433\u043e \u0441\u0442\u0430\u0440\u0442\u0430?\u041c\u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043d\u0440\u0430\u0432\u0438\u043b\u0441\u044f DSL \u0432 Exposed. \u0418\u0445 \u043f\u043e\u0434\u0445\u043e\u0434 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0430\u0436\u043d\u0443\u044e \u0432\u0435\u0449\u044c: API \u0434\u043b\u044f \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 Kotlin \u0434\u043e\u043b\u0436\u0435\u043d \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043a\u0430\u043a \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 Kotlin, \u0430 \u043d\u0435 \u043a\u0430\u043a \u0444\u0440\u0430\u043d\u043a\u0435\u043d\u0448\u0442\u0435\u0439\u043d \u0438\u0437 \u0447\u0443\u0436\u043e\u0433\u043e \u044f\u0437\u044b\u043a\u0430. \u0411\u043b\u0430\u0433\u043e, \u044f\u0437\u044b\u043a \u0434\u0430\u0435\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0432\u0441\u0435 \u043a\u0430\u0440\u0442\u044b \u0432 \u0440\u0443\u043a\u0438: \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u044b, \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, lambdas with receiver. \u042f \u0440\u0435\u0448\u0438\u043b \u0440\u0438\u0441\u043a\u043d\u0443\u0442\u044c \u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e \u0432\u0435\u0447\u0435\u0440\u0430\u043c \u043e\u0431\u0435\u0440\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u044b\u043b\u0430 \u0431\u044b \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043b\u0435\u0433\u043a\u043e\u0432\u0435\u0441\u043d\u043e\u0439.\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043f\u043b\u0430\u043d \u0431\u044b\u043b \u0441\u043a\u0440\u043e\u043c\u043d\u044b\u043c \u2014 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u0439-\u043f\u043e\u043c\u043e\u0449\u043d\u0438\u043a\u043e\u0432 \u043f\u043e\u0432\u0435\u0440\u0445 pgkn, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u0443\u0431\u0440\u0430\u0442\u044c \u0440\u0443\u0442\u0438\u043d\u0443. \u041d\u043e \u043a\u043e\u0434 \u043d\u0430\u0447\u0430\u043b \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043b\u0430\u0432\u0438\u043d\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u0434\u043d\u0430 \u0440\u0435\u0448\u0435\u043d\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0442\u0443\u0442 \u0436\u0435 \u043e\u0431\u043d\u0430\u0436\u0430\u043b\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e. \u042d\u0432\u043e\u043b\u044e\u0446\u0438\u044f \u0448\u043b\u0430 \u043f\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u043b\u043e\u0433\u0438\u0447\u043d\u044b\u043c \u0448\u0430\u0433\u0430\u043c:\u0411\u043e\u0440\u044c\u0431\u0430 \u0441\u043e \u0441\u0434\u0432\u0438\u0433\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 (ResultSet). \u041f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b extension-\u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0432\u0440\u043e\u0434\u0435 fun ResultSet.toUser(), \u0447\u0442\u043e\u0431\u044b \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u0442\u0443\u0434\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u0435\u0439. \u041d\u043e \u0441\u0442\u043e\u0438\u043b\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043a\u043e\u043b\u043e\u043d\u043a\u0443 \u0432 \u0441\u0435\u0440\u0435\u0434\u0438\u043d\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u043a\u0430\u043a \u0432\u0441\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b it.getString(2), it.getInt(3) \u0441\u044a\u0435\u0437\u0436\u0430\u043b\u0438. \u0421\u0442\u0430\u043b\u043e \u043f\u043e\u043d\u044f\u0442\u043d\u043e: \u043c\u0430\u043f\u0438\u0442\u044c \u043d\u0443\u0436\u043d\u043e \u043d\u0435 \u043f\u043e \u0445\u0430\u0440\u0434\u043a\u043e\u0434\u043d\u044b\u043c \u043d\u043e\u043c\u0435\u0440\u0430\u043c, \u0430 \u043f\u043e \u0438\u043c\u0435\u043d\u0430\u043c \u043a\u043e\u043b\u043e\u043d\u043e\u043a.\u041f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432-\u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u0427\u0442\u043e\u0431\u044b \u0447\u0438\u0442\u0430\u0442\u044c \u043f\u043e \u0438\u043c\u0435\u043d\u0430\u043c \u0438 \u043d\u0435 \u043e\u043f\u0435\u0447\u0430\u0442\u0430\u0442\u044c\u0441\u044f \u0432 \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u0445 \u043b\u0438\u0442\u0435\u0440\u0430\u043b\u0430\u0445, \u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0438\u043c\u0435\u043d\u0430 \u0432 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u044b. \u041d\u043e \u0440\u0430\u0437 \u0443\u0436 \u044f \u0441\u043e\u0437\u0434\u0430\u044e \u043e\u0431\u044a\u0435\u043a\u0442 \u0434\u043b\u044f \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u043f\u043e\u0447\u0435\u043c\u0443 \u0431\u044b \u043d\u0435 \u0441\u0432\u044f\u0437\u0430\u0442\u044c \u0435\u0433\u043e \u0441 \u0442\u0438\u043f\u043e\u043c \u0434\u0430\u043d\u043d\u044b\u0445? \u0422\u0430\u043a \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0431\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 Column&lt;T&gt;, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u043d\u0430\u043b \u0438 \u0438\u043c\u044f \u043f\u043e\u043b\u044f \u0432 \u0411\u0414, \u0438 \u0442\u043e, \u043a\u0430\u043a \u0435\u0433\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0438\u043b\u0438 \u0437\u0430\u043a\u043e\u0434\u0438\u0440\u043e\u0432\u0430\u0442\u044c.DSL \u0434\u043b\u044f \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0442\u0430\u0431\u043b\u0438\u0446. \u0420\u0430\u0437 \u0435\u0441\u0442\u044c \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u0438\u0445 \u043d\u0443\u0436\u043d\u043e \u0433\u0434\u0435-\u0442\u043e \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c. \u0422\u0430\u043a \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u0441\u0438\u043d\u0433\u043b\u0442\u043e\u043d object Users : Table(&#8230;) (\u043f\u043e\u0437\u0436\u0435 \u0441\u0438\u0433\u043d\u0430\u0442\u0443\u0440\u0430 \u043e\u0431\u0440\u0430\u0441\u0442\u0435\u0442 \u0442\u0438\u043f\u0430\u043c\u0438 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u0438 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438 \u2014 \u043a \u044d\u0442\u043e\u043c\u0443 \u0432\u0435\u0440\u043d\u0435\u043c\u0441\u044f). \u041d\u0430 \u044d\u0442\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0430 \u043c\u0430\u0433\u0438\u044f Kotlin: \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u043e\u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432 (val id by Column.UUID()) \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0441\u043c\u043e\u0433\u043b\u0430 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0438\u043c\u0435\u043d\u0430 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0438\u0437 \u043a\u043e\u0434\u0430 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u043a\u0430\u043a \u0438\u043c\u0435\u043d\u0430 \u043a\u043e\u043b\u043e\u043d\u043e\u043a \u0432 \u0431\u0430\u0437\u0435, \u0438\u0437\u0431\u0430\u0432\u043b\u044f\u044f \u043e\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u0443\u0431\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u043c\u0438 \u043b\u0438\u0442\u0435\u0440\u0430\u043b\u0430\u043c\u0438.Query Builder \u043f\u0440\u043e\u0442\u0438\u0432 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u0438 \u0441\u0442\u0440\u043e\u043a. \u0418\u043c\u0435\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043a\u043e\u043b\u043e\u043d\u043e\u043a, \u043f\u0438\u0441\u0430\u0442\u044c raw SQL \u0432 \u0434\u0443\u0445\u0435 &#171;SELECT * FROM &#187; + Users.tableName \u0441\u0442\u0430\u043b\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e. \u0417\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u043f\u0438\u0441\u0430\u0442\u044c Users.select(). \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0438\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u0435\u0440 SQL, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0440\u0430\u043b \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044f \u043f\u043b\u0435\u0439\u0441\u0445\u043e\u043b\u0434\u0435\u0440\u044b ($1, $2) \u0432\u043c\u0435\u0441\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439, \u0447\u0442\u043e\u0431\u044b \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0449\u0438\u0442\u0443 \u043e\u0442 SQL-\u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0439.\u0422\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u044f \u0443\u0441\u043b\u043e\u0432\u0438\u0439 (\u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u044b). \u0421\u0430\u043c\u044b\u0439 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0432\u044b\u0437\u043e\u0432 \u2014 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u044f. \u041f\u0438\u0441\u0430\u0442\u044c .where(&#171;age &gt;= 18&#187;) \u2014 \u044d\u0442\u043e \u0441\u043d\u043e\u0432\u0430 runtime-\u0440\u0438\u0441\u043a\u0438. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0437\u0430\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u044d\u0442\u043e \u0432 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0432\u0438\u0434: where { Users.age gtEq 18 }. \u041f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 gtEq&#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-484584","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/484584","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=484584"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/484584\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=484584"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=484584"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=484584"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}