{"id":482841,"date":"2026-06-08T13:41:30","date_gmt":"2026-06-08T13:41:30","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=482841"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=482841","title":{"rendered":"\u042d\u0442\u0443 \u0437\u0430\u0434\u0430\u0447\u0443 \u0441\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442 \u0432 ASTON, \u0410\u043b\u044c\u0444\u0435 \u0438 \u0421\u043e\u0432\u043a\u043e\u043c\u0431\u0430\u043d\u043a\u0435 \u043d\u0430 java-\u0441\u043e\u0431\u0435\u0441\u0435. \u041d\u0430\u0439\u0434\u0438\u0442\u0435 8 \u0431\u0430\u0433\u043e\u0432 \u0432 47 \u0441\u0442\u0440\u043e\u043a\u0430\u0445 Spring \u2014 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0441\u0430\u043c\u0438"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<figure class=\"\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/881\/732\/767\/8817327677353ce7954dfdcea73701ba.jpg\" alt=\"https:\/\/images.unsplash.com\/photo-1555066931-4365d14bab8c?w=1200&amp;q=80&amp;auto=format&amp;fit=crop\" sizes=\"(max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/\/post_images\/881\/732\/767\/8817327677353ce7954dfdcea73701ba.jpg 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/881\/732\/767\/8817327677353ce7954dfdcea73701ba.jpg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>https:\/\/images.unsplash.com\/photo-1555066931-4365d14bab8c?w=1200&amp;q=80&amp;auto=format&amp;fit=crop<\/figcaption><\/div>\n<\/figure>\n<hr\/>\n<h3>\u041c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u0435 \u043f\u0440\u0438\u0437\u043d\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0434 \u0442\u0435\u043c, \u043a\u0430\u043a \u043c\u044b \u043d\u0430\u0447\u043d\u0451\u043c<\/h3>\n<p>\u0412 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043e\u0431\u0435\u0449\u0430\u043b, \u0447\u0442\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0432\u043e\u0437\u044c\u043c\u0443\u0441\u044c \u0437\u0430 Senior System Design. \u041d\u0435 \u043e\u0431\u043c\u0430\u043d\u0443\u043b, \u0432\u043e\u0437\u044c\u043c\u0443\u0441\u044c, \u043d\u043e \u043d\u0435 \u0441\u0435\u0439\u0447\u0430\u0441.<\/p>\n<p>\u0417\u0430 \u044d\u0442\u0438 \u0434\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445 \u0438 \u0432 \u043b\u0438\u0447\u043a\u0435 \u043c\u043d\u0435 \u043f\u0440\u0438\u0441\u043b\u0430\u043b\u0438 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u043e\u043a \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043e\u0431\u0435\u0441\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0439. \u042f \u0434\u0443\u043c\u0430\u043b \u2014 \u043e\u0442\u0434\u043e\u0445\u043d\u0443. \u0410 \u043f\u043e\u0442\u043e\u043c \u0441\u0435\u043b \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0438 \u043d\u0430\u0442\u043a\u043d\u0443\u043b\u0441\u044f \u043d\u0430 \u043e\u0434\u043d\u0443 \u0438 \u0442\u0443 \u0436\u0435 \u0437\u0430\u0434\u0430\u0447\u0443 \u043f\u043e\u0434\u0440\u044f\u0434 \u0432 \u0434\u0435\u0432\u044f\u0442\u0438 \u0440\u0430\u0437\u043d\u044b\u0445 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e: ASTON, \u0422\u0411\u0430\u043d\u043a, \u0410\u043b\u044c\u0444\u0430, \u0421\u043e\u0432\u043a\u043e\u043c\u0431\u0430\u043d\u043a, \u0418\u043d\u043d\u043e\u0442\u0435\u0445. \u0412\u0435\u0437\u0434\u0435 \u043e\u0434\u043d\u043e \u0438 \u0442\u043e \u0436\u0435 \u2014 <strong>\u00ab\u043d\u0430\u0439\u0434\u0438\u0442\u0435 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432\u043e\u0441\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u0432 \u044d\u0442\u043e\u043c \u043a\u0443\u0441\u043a\u0435 Spring-\u043a\u043e\u0434\u0430, \u0443 \u0432\u0430\u0441 \u0434\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442\u00bb.<\/strong> \u0420\u0430\u0437\u043d\u044b\u0435 \u043e\u0431\u0451\u0440\u0442\u043a\u0438, \u0440\u0430\u0437\u043d\u044b\u0435 \u0434\u043e\u043c\u0435\u043d\u044b: \u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u043e\u0437\u043d\u0430\u0433\u0440\u0430\u0436\u0434\u0435\u043d\u0438\u0439, \u0431\u0440\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043c\u0435\u0441\u0442\u0430 \u0432 \u0441\u0430\u043c\u043e\u043b\u0451\u0442\u0435, \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0446\u0435\u043d \u0438\u0437 \u043f\u0440\u0430\u0439\u0441-\u043b\u0438\u0441\u0442\u0430, \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439. \u041d\u043e <strong>\u0441\u043a\u0435\u043b\u0435\u0442 \u043e\u0434\u0438\u043d<\/strong>: \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043d\u0430 \u043f\u043e\u043b\u0441\u043e\u0442\u043d\u0438 \u0441\u0442\u0440\u043e\u043a, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0437\u0430\u0448\u0438\u0442\u044b \u043b\u043e\u0432\u0443\u0448\u043a\u0438 \u043e\u0442 Junior \u0434\u043e Senior \u0443\u0440\u043e\u0432\u043d\u044f.<\/p>\n<p>\u042f \u0432\u044b\u043f\u0438\u0441\u0430\u043b \u0432\u043e\u0441\u0435\u043c\u044c \u0442\u0438\u043f\u043e\u0432\u044b\u0445 \u0431\u0430\u0433\u043e\u0432, \u0441\u043e\u0431\u0440\u0430\u043b \u0432 \u043e\u0434\u0438\u043d \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u2014 \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u044e \u043a\u0430\u043a \u0442\u0435\u0441\u0442. \u0425\u043e\u0447\u0443, \u0447\u0442\u043e\u0431\u044b \u0432\u044b \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b\u0438 \u0441\u0430\u043c\u0438, \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044f \u043d\u0430\u0447\u043d\u0443 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c. \u042d\u0442\u043e \u0442\u0430 \u0441\u0430\u043c\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0432\u0430\u043c, \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, \u0434\u0430\u0434\u0443\u0442 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0441\u043e\u0431\u0435\u0441\u0435 \u0432 \u043a\u0440\u0443\u043f\u043d\u043e\u043c \u0431\u0430\u043d\u043a\u0435.<\/p>\n<p>\u0417\u0430\u0441\u0435\u043a\u0438\u0442\u0435 \u043f\u044f\u0442\u043d\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442 \u043d\u0430 \u0442\u0430\u0439\u043c\u0435\u0440\u0435. \u0421\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u2014 \u043d\u043e\u0440\u043c\u0430 Middle, \u0447\u0435\u0442\u044b\u0440\u0435 \u2014 Junior, \u0432\u043e\u0441\u0435\u043c\u044c \u0438 \u0432\u044b\u0448\u0435 \u2014 Senior \u0441 \u043e\u043f\u044b\u0442\u043e\u043c code review. \u0411\u043e\u043d\u0443\u0441\u043d\u044b\u0439 \u0434\u0435\u0432\u044f\u0442\u044b\u0439 \u044f \u0437\u0430\u0448\u0438\u043b \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e: \u0435\u0433\u043e \u0432 \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435 \u043e\u0431\u044b\u0447\u043d\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u043d\u0430\u0445\u043e\u0434\u044f\u0442, \u0438 \u043e\u043d \u043d\u0435 \u043f\u0440\u043e \u043a\u043e\u0434, \u0430 \u043f\u0440\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443.<\/p>\n<hr\/>\n<h3>\u041a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0437\u0430\u0434\u0430\u0447\u0438<\/h3>\n<p>\u0414\u0430\u043d\u043e \u2014 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u0432 Spring. \u041d\u0430 \u0432\u0445\u043e\u0434\u0435: \u0441\u0447\u0451\u0442 \u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044f, \u0441\u0447\u0451\u0442 \u0437\u0430\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0441\u0443\u043c\u043c\u0430. \u0412\u043d\u0443\u0442\u0440\u0438 \u2014 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0447\u0435\u0440\u0435\u0437 \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434, \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0432 \u0411\u0414, \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u044f \u0441\u043e\u0431\u044b\u0442\u0438\u044f \u0432 Kafka, \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u043f\u043b\u0430\u0442\u0435\u043b\u044c\u0449\u0438\u043a\u0443. \u0421\u0442\u0435\u043a \u043a\u0430\u043a \u0443 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0431\u0430\u043d\u043a\u043e\u0432 \u0438\u0437 \u043c\u043e\u0435\u0439 \u0431\u0430\u0437\u044b: Spring Boot 3, PostgreSQL, Kafka, JPA, REST-\u043a\u043b\u0438\u0435\u043d\u0442 \u0434\u043b\u044f \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434\u0430.<\/p>\n<blockquote>\n<p><strong>\u0424\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u043e\u0442 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u0430<\/strong> (\u0431\u043b\u0438\u0437\u043a\u043e \u043a \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u0443 \u0438\u0437 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e \u0422\u0411\u0430\u043d\u043a #531):<\/p>\n<p>\u00ab\u0423 \u0432\u0430\u0441 \u0434\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442. \u041d\u0430\u0439\u0434\u0438\u0442\u0435 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432\u043e\u0441\u0435\u043c\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u2014 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445, \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0445, \u043b\u044e\u0431\u044b\u0445. \u0421\u0447\u0438\u0442\u0430\u044e\u0442\u0441\u044f \u043d\u0430\u0439\u0434\u0435\u043d\u043d\u044b\u043c\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435, \u0447\u0442\u043e \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u0431\u044a\u044f\u0441\u043d\u0438\u0442\u044c \u0432\u0441\u043b\u0443\u0445: \u043f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e \u0431\u0430\u0433, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442 \u0432 \u043f\u0440\u043e\u0434\u0435, \u043a\u0430\u043a \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c. \u041d\u0430\u0437\u0432\u0430\u0442\u044c \u043e\u0448\u0438\u0431\u043a\u0443, \u043d\u043e \u043d\u0435 \u043e\u0431\u044a\u044f\u0441\u043d\u0438\u0442\u044c \u2014 \u043d\u0435 \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f.\u00bb<\/p>\n<\/blockquote>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u2014 \u043a\u043e\u0434. <strong>\u041f\u0440\u043e\u043a\u0440\u0443\u0442\u0438\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0434\u043e \u043a\u043e\u043d\u0446\u0430 \u043a\u043e\u0434\u0430 \u0438 \u043d\u0435 \u043f\u043e\u0434\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0439\u0442\u0435 \u0432 \u0440\u0430\u0437\u0431\u043e\u0440<\/strong> \u2014 \u0438\u043d\u0430\u0447\u0435 \u0432\u0441\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0442\u0435\u0440\u044f\u0435\u0442 \u0441\u043c\u044b\u0441\u043b.<\/p>\n<hr\/>\n<h3>\u041a\u043e\u0434<\/h3>\n<pre><code class=\"java\">@RestController@RequestMapping(\"\/payments\")public class PaymentController {    @Autowired private PaymentRepository repo;    @Autowired private KafkaTemplate&lt;String, String&gt; kafka;    @Autowired private NotificationService notifications;    @Autowired private AntifraudClient antifraud;    private static Map&lt;UUID, Payment&gt; cache = new HashMap&lt;&gt;();    @PostMapping    @Transactional    public ResponseEntity&lt;?&gt; create(@RequestBody Map&lt;String, Object&gt; body) {        try {            String from = (String) body.get(\"from\");            String to = (String) body.get(\"to\");            double amount = (double) body.get(\"amount\");            if (amount &gt; 1000000) {                System.out.println(\"Large: \" + amount);            }            Payment p = new Payment();            p.setId(UUID.randomUUID());            p.setFromAccount(from);            p.setToAccount(to);            p.setAmount(amount);            p.setCreatedAt(new Date());            p.setStatus(\"PENDING\");            String r = antifraud.check(p);            if (!\"OK\".equals(r))                throw new RuntimeException(\"Declined: \" + r);            repo.save(p);            cache.put(p.getId(), p);            kafka.send(\"payments\", p.toString());            this.sendNotification(p);            return ResponseEntity.ok(p);        } catch (Exception e) {            e.printStackTrace();            return ResponseEntity.status(500).body(e.getMessage());        }    }    @Transactional(propagation = Propagation.REQUIRES_NEW)    public void sendNotification(Payment p) {        notifications.send(p.getFromAccount(),            \"Payment \" + p.getAmount() + \" sent\");    }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<figure class=\"\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/020\/855\/a78\/020855a787687b3357fcf6e50e8b60b6.jpg\" alt=\"Pause. https:\/\/images.unsplash.com\/photo-1495364141860-b0d03eccd065?w=1200&amp;q=80&amp;auto=format&amp;fit=crop\" sizes=\"(max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/\/post_images\/020\/855\/a78\/020855a787687b3357fcf6e50e8b60b6.jpg 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/020\/855\/a78\/020855a787687b3357fcf6e50e8b60b6.jpg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>Pause. https:\/\/images.unsplash.com\/photo-1495364141860-b0d03eccd065?w=1200&amp;q=80&amp;auto=format&amp;fit=crop<\/figcaption><\/div>\n<\/figure>\n<blockquote>\n<p>\u041f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0430: \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u0447\u0438\u0442\u0430\u0442\u044c \u0434\u0430\u043b\u044c\u0448\u0435, <strong>\u043f\u0440\u043e\u043a\u0440\u0443\u0442\u0438\u0442\u0435 \u0432\u0432\u0435\u0440\u0445 \u0438 \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u043d\u0430 \u043a\u043e\u0434 \u043f\u044f\u0442\u043d\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442<\/strong>. \u0418\u043d\u0430\u0447\u0435 \u0440\u0430\u0437\u0431\u043e\u0440 \u043d\u0435 \u043e\u0442\u043b\u043e\u0436\u0438\u0442\u0441\u044f \u2014 \u0433\u043b\u0430\u0437\u0430 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u0431\u0435\u0433\u0443\u0442 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 \u043e\u0442\u0432\u0435\u0442\u044b.<\/p>\n<\/blockquote>\n<p>\u0413\u043e\u0442\u043e\u0432\u044b? \u041f\u043e\u0435\u0445\u0430\u043b\u0438.<\/p>\n<hr\/>\n<h3>\u0420\u0430\u0437\u0431\u043e\u0440. \u0412\u043e\u0441\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u043e\u0442 Junior \u0434\u043e Senior<\/h3>\n<p>\u042f \u0440\u0430\u0437\u043b\u043e\u0436\u0438\u043b \u0431\u0430\u0433\u0438 \u043f\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u2014 \u043e\u0442 \u0441\u0430\u043c\u043e\u0433\u043e \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e\u0433\u043e \u0434\u043e \u0441\u0430\u043c\u043e\u0433\u043e \u043a\u043e\u0432\u0430\u0440\u043d\u043e\u0433\u043e. \u0423 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0432 \u043a\u043e\u043d\u0446\u0435 \u0443\u043a\u0430\u0436\u0443 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e \u043e\u0446\u0435\u043d\u043a\u0443 \u2014 \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0447\u0430\u0441\u0442\u043e \u044d\u0442\u043e\u0442 \u0431\u0430\u0433 \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u044e\u0442 \u043a\u0430\u043a \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u0443\u043d\u043a\u0442 Code Review-\u0441\u0435\u043a\u0446\u0438\u0438 \u0432 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e.<\/p>\n<h4>\u0411\u0430\u0433 \u21161. Field injection \u0432\u043c\u0435\u0441\u0442\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0430<\/h4>\n<p>\u0427\u0435\u0442\u044b\u0440\u0435 <code>@Autowired<\/code> \u043d\u0430 \u043f\u043e\u043b\u044f\u0445, \u0438 \u043d\u0438 \u043e\u0434\u043d\u043e \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 <code>final<\/code>. \u042d\u0442\u043e \u043f\u0435\u0440\u0432\u043e\u0435, \u0447\u0442\u043e \u0434\u043e\u043b\u0436\u0435\u043d \u0443\u0432\u0438\u0434\u0435\u0442\u044c Middle-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a. Field injection \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u043b\u0430\u0441\u0441 \u043d\u0435\u043f\u0440\u0438\u0433\u043e\u0434\u043d\u044b\u043c \u043a \u044e\u043d\u0438\u0442-\u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \u0431\u0435\u0437 \u043f\u043e\u0434\u043d\u044f\u0442\u0438\u044f Spring-\u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430, \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u043e runtime, \u0438 \u2014 \u0447\u0442\u043e \u0445\u0443\u0436\u0435 \u0432\u0441\u0435\u0433\u043e \u2014 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e \u043c\u0443\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e.<\/p>\n<pre><code class=\"java\">\/\/ \u274c@Autowiredprivate PaymentRepository repo;\/\/ \u2705private final PaymentRepository repo;public PaymentController(PaymentRepository repo, \/* \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 *\/) { ... }\/\/ \u0438\u043b\u0438 Lombok @RequiredArgsConstructor + private final<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430 \u043d\u0430 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0441\u043e\u0431\u0435\u0441\u0430\u0445: \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 Code Review-\u0437\u0430\u0434\u0430\u0447\u0435.<\/strong> \u0411\u0435\u0437 \u043d\u0435\u0433\u043e \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0430 \u0432\u043e\u043e\u0431\u0449\u0435 \u0440\u0435\u0434\u043a\u043e\u0441\u0442\u044c.<\/p>\n<h4>\u0411\u0430\u0433 \u21162. double \u0434\u043b\u044f \u0434\u0435\u043d\u0435\u0433<\/h4>\n<p>\u0421\u0443\u043c\u043c\u0430 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442 \u043a\u0430\u043a <code>double<\/code>, \u0434\u0430\u043b\u044c\u0448\u0435 \u0441 \u043d\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u042d\u0442\u043e \u0443\u0440\u043e\u0432\u0435\u043d\u044c \u0434\u0435\u0442\u0441\u043a\u043e\u0433\u043e \u0441\u0430\u0434\u0430 \u0432 \u0444\u0438\u043d\u0442\u0435\u0445\u0435. <code>0.1 + 0.2<\/code> \u0432 Java \u0434\u0430\u0451\u0442 <code>0.30000000000000004<\/code>. \u041d\u0430 \u043e\u0434\u043d\u043e\u043c \u043f\u043b\u0430\u0442\u0435\u0436\u0435 \u044d\u0442\u043e \u043a\u043e\u043f\u0435\u0439\u043a\u0430. \u041d\u0430 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0435 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u2014 \u0440\u0430\u0441\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u0441\u043e \u0441\u0447\u0451\u0442\u043e\u043c \u0431\u0430\u043d\u043a\u0430, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043a \u0432\u0430\u043c \u0447\u0435\u0440\u0435\u0437 \u043d\u0435\u0434\u0435\u043b\u044e \u043f\u0440\u0438\u0434\u0451\u0442 \u0431\u0443\u0445\u0433\u0430\u043b\u0442\u0435\u0440\u0438\u044f \u0441 \u0432\u043e\u043f\u0440\u043e\u0441\u0430\u043c\u0438.<\/p>\n<pre><code class=\"java\">\/\/ \u274cdouble amount = (double) body.get(\"amount\");\/\/ \u2705BigDecimal amount = new BigDecimal(body.get(\"amount\").toString());\/\/ \u0434\u0430\u043b\u044c\u0448\u0435 \u2014 amount.add(...), amount.multiply(...).setScale(2, RoundingMode.HALF_EVEN)<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u2014 <code>(double) body.get(\"amount\")<\/code> \u0443\u043f\u0430\u0434\u0451\u0442 \u0441 <code>ClassCastException<\/code>, \u0435\u0441\u043b\u0438 \u0444\u0440\u043e\u043d\u0442 \u043f\u0440\u0438\u0448\u043b\u0451\u0442 \u0447\u0438\u0441\u043b\u043e \u043a\u0430\u043a <code>Integer<\/code> (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0440\u043e\u0432\u043d\u043e <code>100<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>100.0<\/code>). \u041d\u0430 \u043f\u0440\u043e\u0434\u0435 \u0442\u0430\u043a\u043e\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u2014 \u0443 \u043c\u0435\u043d\u044f \u0432 \u0431\u0430\u0437\u0435 \u0442\u0440\u0438 \u0441\u043b\u0443\u0447\u0430\u044f, \u043a\u043e\u0433\u0434\u0430 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u043d \u0443\u043f\u0430\u043b \u0438\u043c\u0435\u043d\u043d\u043e \u0438\u0437-\u0437\u0430 \u044d\u0442\u043e\u0433\u043e.<\/p>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0447\u0435\u043d\u044c \u0447\u0430\u0441\u0442\u043e.<\/strong> \u0412 \u043f\u043b\u0430\u0442\u0451\u0436\u043d\u044b\u0445 \u0438 \u0444\u0438\u043d\u0442\u0435\u0445-\u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044f\u0445 \u2014 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e.<\/p>\n<h4>\u0411\u0430\u0433 \u21163. System.out.println \u0432\u043c\u0435\u0441\u0442\u043e \u043b\u043e\u0433\u0433\u0435\u0440\u0430<\/h4>\n<p>\u0421\u0430\u043c\u0430\u044f \u043a\u0430\u043d\u043e\u043d\u0438\u0447\u043d\u0430\u044f \u043c\u0435\u043b\u043e\u0447\u044c, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0443\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0440\u0435\u0442\u0438\u0439 Junior. <code>System.out<\/code> \u2014 \u044d\u0442\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 PrintStream, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u043f\u043e\u0442\u043e\u043a, \u043d\u0435 \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u0432 \u0444\u0430\u0439\u043b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u043d\u0435 \u0443\u0440\u043e\u0432\u043d\u0435\u043c INFO\/WARN\/ERROR \u0438 \u0442\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u0440\u043e\u0442\u0430\u0446\u0438\u0438 stdout. \u0412 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0435 \u043d\u0430 Kubernetes \u0432\u0430\u0448 \u00ab\u0432\u0438\u0436\u0443 \u0436\u0435 \u2014 \u0432\u044b\u0432\u043e\u0434\u0438\u0442\u00bb \u0443\u0445\u043e\u0434\u0438\u0442 \u0432 <code>\/dev\/null<\/code> \u043f\u043e\u0441\u043b\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e rotate.<\/p>\n<pre><code class=\"java\">\/\/ \u274cSystem.out.println(\"Large: \" + amount);\/\/ \u2705log.warn(\"Large payment detected: amount={}, from={}, to={}\", amount, from, to);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0411\u043e\u043d\u0443\u0441: \u043c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0447\u0438\u0441\u043b\u043e <code>1000000<\/code> \u0432 <code>if (amount &gt; 1000000)<\/code> \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0432 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u0443 <code>LARGE_PAYMENT_THRESHOLD<\/code> \u0438\u043b\u0438 <code>@ConfigurationProperties<\/code>. \u0418\u043d\u0430\u0447\u0435 \u0447\u0435\u0440\u0435\u0437 \u043f\u043e\u043b\u0433\u043e\u0434\u0430 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u0442, <strong>\u0440\u0443\u0431\u043b\u0438 \u044d\u0442\u043e \u0438\u043b\u0438 \u043a\u043e\u043f\u0435\u0439\u043a\u0438<\/strong>.<\/p>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0447\u0435\u043d\u044c \u0447\u0430\u0441\u0442\u043e.<\/strong> \u041a\u0430\u043d\u043e\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043f\u0443\u043d\u043a\u0442 \u0447\u0435\u043a-\u043b\u0438\u0441\u0442\u0430 Code Review.<\/p>\n<h4>\u0411\u0430\u0433 \u21164. catch (Exception e) + e.printStackTrace() + \u0443\u0442\u0435\u0447\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a \u0432 response<\/h4>\n<p>\u0422\u0440\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0432 \u043e\u0434\u043d\u043e\u043c \u0431\u043b\u043e\u043a\u0435.<\/p>\n<p>\u041f\u0435\u0440\u0432\u0430\u044f \u2014 <code>catch (Exception e)<\/code> \u0433\u043b\u043e\u0442\u0430\u0435\u0442 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0432\u0441\u0451, \u0432\u043a\u043b\u044e\u0447\u0430\u044f <code>OutOfMemoryError<\/code>-\u043e\u0431\u0451\u0440\u0442\u043a\u0438, \u043f\u0440\u0435\u0440\u044b\u0432\u0430\u043d\u0438\u044f \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u0438 checked-\u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u043b\u0438 \u043d\u0435 \u0433\u043b\u043e\u0442\u0430\u0442\u044c, \u0430 \u043f\u0440\u043e\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c. \u041f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u2014 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c <strong>\u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435<\/strong> \u0434\u043e\u043c\u0435\u043d\u043d\u044b\u0435 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u0430 \u0432\u0441\u0451 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u043e\u0442\u0434\u0430\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 <code>@ControllerAdvice<\/code>.<\/p>\n<p>\u0412\u0442\u043e\u0440\u0430\u044f \u2014 <code>e.printStackTrace()<\/code> \u043f\u0438\u0448\u0435\u0442 \u0432 <code>System.err<\/code>. \u042d\u0442\u043e \u0442\u043e\u0442 \u0436\u0435 \u0430\u0434, \u0447\u0442\u043e \u0438 \u0441 <code>println<\/code>, \u0442\u043e\u043b\u044c\u043a\u043e \u0445\u0443\u0436\u0435: \u0432 Kibana \u0432\u044b \u0441\u0432\u043e\u0439 stack trace \u043d\u0435 \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u043d\u0438\u043a\u043e\u0433\u0434\u0430.<\/p>\n<p>\u0422\u0440\u0435\u0442\u044c\u044f \u2014 <code>e.getMessage()<\/code> \u0443\u0445\u043e\u0434\u0438\u0442 \u043a\u043b\u0438\u0435\u043d\u0442\u0443 \u0432 \u0442\u0435\u043b\u0435 \u043e\u0442\u0432\u0435\u0442\u0430. \u0415\u0441\u043b\u0438 \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043b\u0435\u0442\u0435\u043b Hibernate, \u0432 <code>getMessage()<\/code> \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u0430 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 \u0438\u043c\u0435\u043d\u0430\u043c\u0438 \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u042d\u0442\u043e \u0443\u0442\u0435\u0447\u043a\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0431\u0430\u0437\u044b \u043d\u0430\u0440\u0443\u0436\u0443, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043b\u044e\u0431\u043e\u0439 \u043f\u0435\u043d\u0442\u0435\u0441\u0442\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c.<\/p>\n<pre><code class=\"java\">\/\/ \u274c} catch (Exception e) {    e.printStackTrace();    return ResponseEntity.status(500).body(e.getMessage());}\/\/ \u2705 \u2014 \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u043e \u0447\u0435\u0440\u0435\u0437 @ControllerAdvice@ExceptionHandler(AntifraudDeclinedException.class)public ResponseEntity&lt;ProblemDetail&gt; handle(AntifraudDeclinedException ex) {    log.warn(\"Antifraud declined\", ex);    return ResponseEntity.status(HttpStatus.UNPROCESSABLE_ENTITY)        .body(ProblemDetail.forStatusAndDetail(422, \"Operation declined\"));}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u0447\u0430\u0441\u0442\u043e.<\/strong> \u041b\u044e\u0431\u0438\u043c\u044b\u0439 \u043f\u0443\u043d\u043a\u0442 \u0441\u0435\u043d\u0438\u043e\u0440\u043e\u0432-\u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u043e\u0432 \u2014 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0442\u0430 \u0447\u0430\u0441\u0442\u044c, \u0447\u0442\u043e \u043f\u0440\u043e <code>e.getMessage()<\/code> \u0432 response. \u041d\u043e <strong>\u043f\u043e\u043b\u043d\u0443\u044e \u0442\u0440\u043e\u0439\u043a\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c<\/strong> \u0432 \u043e\u0434\u043d\u043e\u043c \u0431\u043b\u043e\u043a\u0435 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u044b \u043e\u0431\u044b\u0447\u043d\u043e \u0440\u0430\u0441\u0447\u043b\u0435\u043d\u044f\u044e\u0442 \u043d\u0435 \u0441\u0440\u0430\u0437\u0443.<\/p>\n<h4>\u0411\u0430\u0433 \u21165. \ud83d\udea8 this.sendNotification(p) \u2014 self-invocation<\/h4>\n<p>\u0412\u043e\u0442 \u043e\u043d \u2014 <strong>\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u0432\u043e\u043f\u0440\u043e\u0441 \u21167<\/strong> \u0438\u0437 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438, \u0432 \u0440\u0430\u0437\u0432\u0451\u0440\u043d\u0443\u0442\u043e\u043c \u0432\u0438\u0434\u0435 \u0438 \u0437\u0430\u0448\u0438\u0442\u044b\u0439 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u043a\u043e\u0434.<\/p>\n<p>\u0412 \u043a\u043e\u0434\u0435 \u0435\u0441\u0442\u044c \u043c\u0435\u0442\u043e\u0434 <code>sendNotification<\/code>, \u043f\u043e\u043c\u0435\u0447\u0435\u043d\u043d\u044b\u0439 <code>@Transactional(propagation = REQUIRES_NEW)<\/code>. \u041f\u043e \u0437\u0430\u0434\u0443\u043c\u043a\u0435, \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u0430 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c\u0441\u044f \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u2014 \u0447\u0442\u043e\u0431\u044b \u0435\u0441\u043b\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044f \u043f\u043b\u0430\u0442\u0435\u0436\u0430 \u043e\u0442\u043a\u0430\u0442\u0438\u0442\u0441\u044f, <strong>\u0437\u0430\u043f\u0438\u0441\u044c \u043e \u043f\u043e\u043f\u044b\u0442\u043a\u0435 \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e \u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c<\/strong>. \u042d\u0442\u043e \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0439 \u0430\u0443\u0434\u0438\u0442-\u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0439.<\/p>\n<p>\u041d\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u043d\u0430 \u043a\u0430\u043a <code>this.sendNotification(p)<\/code> \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0447\u0435\u0440\u0435\u0437 \u0431\u0430\u0439\u0442-\u043a\u043e\u0434, \u043c\u0438\u043d\u0443\u044f Spring-\u043f\u0440\u043e\u043a\u0441\u0438. \u0410\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f <code>@Transactional(REQUIRES_NEW)<\/code> \u043c\u043e\u043b\u0447\u0430 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f. \u041d\u0438\u043a\u0430\u043a\u043e\u0439 \u043d\u043e\u0432\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f. \u041d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0438\u0434\u0451\u0442 \u0432 <strong>\u0442\u043e\u0439 \u0436\u0435<\/strong> \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0447\u0442\u043e \u0438 \u043f\u043b\u0430\u0442\u0451\u0436. \u0415\u0441\u043b\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044f \u043f\u0430\u0434\u0430\u0435\u0442 \u2014 \u0437\u0430\u043f\u0438\u0441\u044c \u043e \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u043e\u0442\u043a\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u043f\u043b\u0430\u0442\u0435\u0436\u043e\u043c.<\/p>\n<p><strong>\u0412 \u043f\u0440\u043e\u0434\u0435 \u044d\u0442\u043e \u0432\u044b\u0441\u0442\u0440\u0435\u043b\u0438\u0442 \u043a\u0430\u043a \u00ab\u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0438 SMS, \u0430 \u043f\u043b\u0430\u0442\u0435\u0436\u0430 \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043d\u0435\u0442\u00bb.<\/strong> \u0418\u043b\u0438 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u2014 \u00ab\u043f\u043b\u0430\u0442\u0451\u0436 \u043f\u0440\u043e\u0448\u0451\u043b, \u0430 SMS \u043d\u0435 \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0438\u00bb. \u0412 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0441\u043b\u0443\u0436\u0431\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0447\u0435\u0440\u0435\u0437 \u043d\u0435\u0434\u0435\u043b\u044e \u0440\u0430\u0437\u0432\u0435\u0434\u0451\u0442 \u0440\u0443\u043a\u0430\u043c\u0438.<\/p>\n<pre><code class=\"java\">\/\/ \u274cthis.sendNotification(p);\/\/ \u2705 \u2014 \u0447\u0435\u0442\u044b\u0440\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430 (\u043f\u043e \u0443\u0431\u044b\u0432\u0430\u043d\u0438\u044e \u0447\u0430\u0441\u0442\u043e\u0442\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f)\/\/ 1. Self-injection \u0447\u0435\u0440\u0435\u0437 @Lazypublic PaymentController(@Lazy PaymentController self, ...) { this.self = self; }self.sendNotification(p);\/\/ 2. \u0412\u044b\u043d\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 NotificationOrchestratornotificationOrchestrator.sendNotification(p);\/\/ 3. AspectJ Mode \u0434\u043b\u044f @Transactional@EnableTransactionManagement(mode = AdviceMode.ASPECTJ)\/\/ 4. TransactionTemplate \u0432\u0440\u0443\u0447\u043d\u0443\u044etransactionTemplate.execute(status -&gt; { notifications.send(...); return null; });<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0434\u0438\u043d \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043b\u044e\u0431\u0438\u043c\u044b\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432 \u0441\u0435\u043d\u0438\u043e\u0440\u043e\u0432-\u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u043e\u0432.<\/strong> \u0421\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442 \u0438 \u0443\u0441\u0442\u043d\u043e, \u0438 \u0437\u0430\u0448\u0438\u0442\u044b\u043c \u0432 \u043a\u043e\u0434 \u2014 \u043a\u0430\u043a \u0437\u0434\u0435\u0441\u044c. \u041f\u043e\u0434\u0432\u043e\u0445 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e <code>@Transactional(REQUIRES_NEW)<\/code> \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u043a\u0440\u0438\u0447\u0438\u0442 \u00ab\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u00bb, \u0430 \u043d\u0430 \u0434\u0435\u043b\u0435 \u043c\u043e\u043b\u0447\u0430 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f.<\/p>\n<h4>\u0411\u0430\u0433 \u21166. Antifraud REST-\u0432\u044b\u0437\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 @Transactional<\/h4>\n<p><code>antifraud.check(p)<\/code> \u2014 \u044d\u0442\u043e, \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, HTTP-\u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u043e \u0432\u043d\u0435\u0448\u043d\u0438\u0439 \u0441\u0435\u0440\u0432\u0438\u0441. \u041f\u043e \u0434\u0435\u0444\u043e\u043b\u0442\u0443 \u0442\u0430\u0439\u043c\u0430\u0443\u0442 \u0443 <code>RestTemplate<\/code> \u0438\u043b\u0438 <code>WebClient<\/code> \u2014 <strong>\u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u044c<\/strong>. \u0415\u0441\u043b\u0438 \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434 \u0437\u0430\u043b\u0438\u043f \u043d\u0430 \u043c\u0438\u043d\u0443\u0442\u0443, \u0432\u0430\u0448\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u0441 PostgreSQL \u0434\u0435\u0440\u0436\u0438\u0442\u0441\u044f \u043e\u0442\u043a\u0440\u044b\u0442\u044b\u043c \u0432\u0441\u044e \u044d\u0442\u0443 \u043c\u0438\u043d\u0443\u0442\u0443. \u0423 HikariCP \u043f\u043e \u0434\u0435\u0444\u043e\u043b\u0442\u0443 \u0432 \u043f\u0443\u043b\u0435 \u0434\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439. \u0414\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u043f\u0440\u0438 \u0437\u0430\u043b\u0438\u043f\u0448\u0435\u043c \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434\u0435 \u2014 \u0438 \u0441\u0435\u0440\u0432\u0438\u0441 <strong>\u0432\u0441\u0442\u0430\u043b \u043a\u043e\u043b\u043e\u043c<\/strong>, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043d\u043e\u0432\u044b\u0435 \u043f\u043e\u0442\u043e\u043a\u0438 \u0436\u0434\u0443\u0442 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u0441 \u0411\u0414.<\/p>\n<p>\u042d\u0442\u043e \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 case study, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043b\u044e\u0431\u044f\u0442 \u0434\u0430\u0432\u0430\u0442\u044c \u0422\u0411\u0430\u043d\u043a (#419, #531) \u0438 \u0418\u043d\u043d\u043e\u0442\u0435\u0445. \u041b\u0435\u0447\u0438\u0442\u0441\u044f \u043b\u0438\u0431\u043e \u0432\u044b\u043d\u043e\u0441\u043e\u043c \u0432\u043d\u0435\u0448\u043d\u0435\u0433\u043e \u0432\u044b\u0437\u043e\u0432\u0430 <strong>\u0434\u043e<\/strong> \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u043b\u0438\u0431\u043e \u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c \u0442\u0430\u0439\u043c\u0430\u0443\u0442\u043e\u043c + circuit breaker.<\/p>\n<pre><code class=\"java\">\/\/ \u2705 \u2014 \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u0434\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438public ResponseEntity&lt;?&gt; create(...) {    AntifraudVerdict verdict = antifraud.check(request); \/\/ \u0432\u043d\u0435 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438!    if (verdict.declined()) throw new AntifraudDeclinedException(verdict);    paymentService.persist(request); \/\/ \u0432\u043e\u0442 \u0442\u0435\u043f\u0435\u0440\u044c @Transactional \u043d\u0430 \u0441\u0435\u0440\u0432\u0438\u0441\u0435    ...}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u0447\u0430\u0441\u0442\u043e.<\/strong> \u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 \u043b\u043e\u0432\u0443\u0448\u0435\u043a \u2014 \u043f\u043e\u0441\u043b\u0435 Code Review \u0435\u0433\u043e \u043b\u044e\u0431\u044f\u0442 \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u0432 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u0435 \u00ab\u0430 \u043a\u0430\u043a \u0443 \u0432\u0430\u0441 \u0432 \u043f\u0440\u043e\u0434\u0435, \u0438 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0443 \u0432\u0430\u0441 \u0432 HikariCP \u0432 \u043f\u0443\u043b\u0435\u00bb.<\/p>\n<h4>\u0411\u0430\u0433 \u21167. Kafka \u0432\u043d\u0443\u0442\u0440\u0438 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u2014 \u043d\u0435\u0442 Outbox<\/h4>\n<p><code>repo.save(p)<\/code> \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043f\u043b\u0430\u0442\u0451\u0436 \u0432 Postgres. <code>kafka.send(...)<\/code> \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u0442 \u0441\u043e\u0431\u044b\u0442\u0438\u0435 \u0432 \u0431\u0440\u043e\u043a\u0435\u0440. \u042d\u0442\u0438 \u0434\u0432\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u044b\u043c\u0438 \u2014 \u043b\u0438\u0431\u043e \u043e\u0431\u0430, \u043b\u0438\u0431\u043e \u043d\u0438 \u043e\u0434\u043d\u043e. \u0421\u0435\u0439\u0447\u0430\u0441 \u043e\u043d\u0438 <strong>\u043d\u0435<\/strong> \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u044b.<\/p>\n<p>\u0421\u0446\u0435\u043d\u0430\u0440\u0438\u0438, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u044b \u043f\u043e\u043f\u0430\u0434\u0430\u0435\u0442\u0435:<\/p>\n<ol>\n<li>\n<p>\u0411\u0414 \u043e\u0442\u0432\u0435\u0442\u0438\u043b\u0430 \u00abcommit\u00bb, Kafka \u0432 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0430 \u2014 Kafka-\u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0435 <strong>\u043d\u0435 \u0443\u0439\u0434\u0451\u0442<\/strong>. \u041f\u043b\u0430\u0442\u0451\u0436 \u0441\u043e\u0445\u0440\u0430\u043d\u0451\u043d, downstream-\u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0431\u0430\u043b\u0430\u043d\u0441, \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434-\u0430\u043d\u0430\u043b\u0438\u0442\u0438\u043a\u0430, BI) \u043e \u043d\u0451\u043c \u043d\u0435 \u0443\u0437\u043d\u0430\u044e\u0442.<\/p>\n<\/li>\n<li>\n<p>Kafka \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043b\u0430 \u043f\u0440\u0438\u0451\u043c, \u0411\u0414 \u0443\u043f\u0430\u043b\u0430 \u043d\u0430 commit \u2014 Kafka-\u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0435 <strong>\u0443\u0436\u0435 \u0443\u043b\u0435\u0442\u0435\u043b\u043e<\/strong>. Downstream \u0432\u044b\u0447\u0438\u0442\u0430\u0435\u0442 \u0441\u043e\u0431\u044b\u0442\u0438\u0435, \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u00ab\u043f\u043b\u0430\u0442\u0451\u0436\u00bb, \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u043f\u043b\u0430\u0442\u0435\u0436\u0430 \u043d\u0435\u0442.<\/p>\n<\/li>\n<\/ol>\n<p>\u041b\u0435\u0447\u0435\u043d\u0438\u0435 \u2014 <strong>Transactional Outbox<\/strong>: \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u044c \u0432 \u0411\u0414 \u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u0435, \u0438 \u043f\u0440\u043e\u0432\u043e\u0434\u043a\u0443 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0432\u043e\u0440\u043a\u0435\u0440 \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 <code>outbox<\/code> \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u0442 \u0432 Kafka. \u0413\u0430\u0440\u0430\u043d\u0442\u0438\u044f \u2014 at-least-once \u0441 \u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u044b\u043c consumer\u2019\u043e\u043c.<\/p>\n<pre><code class=\"java\">\/\/ \u2705 \u2014 Outbox-\u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0432 \u0442\u043e\u0439 \u0436\u0435 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438@Transactionalpublic void process(...) {    repo.save(payment);    outboxRepo.save(new OutboxEvent(\"payments\", serialize(payment)));}\/\/ + \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 @Scheduled \/ debezium-pipeline publisher<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u0447\u0430\u0441\u0442\u043e \u043d\u0430 Middle+ \u0438 Senior.<\/strong> \u041f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u043e \u2014 \u00ab\u0443 \u0432\u0430\u0441 Kafka \u0432 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u044d\u0442\u043e \u043f\u043b\u043e\u0445\u043e\u00bb. \u0413\u043b\u0443\u0431\u043e\u043a\u043e \u2014 \u0432\u044b\u0445\u043e\u0434\u0438\u043c \u043d\u0430 Transactional Outbox \u0438 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438 \u0440\u0430\u0437\u044a\u0435\u0437\u0434\u0430 commit \u0411\u0414 \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u044f.<\/p>\n<h4>\u0411\u0430\u0433 \u21168. static Map cache \u2014 \u0433\u043e\u043d\u043a\u0430, \u0443\u0442\u0435\u0447\u043a\u0430 \u0438 stale data<\/h4>\n<p>\u041f\u043e\u043b\u0435 <code>private static Map&lt;UUID, Payment&gt; cache = new HashMap&lt;&gt;();<\/code> \u2014 \u044d\u0442\u043e, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u043c\u043e\u0439 \u043b\u044e\u0431\u0438\u043c\u044b\u0439 \u0431\u0430\u0433 \u0432\u043e \u0432\u0441\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0435.<\/p>\n<p>\u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, <code>HashMap<\/code> <strong>\u043d\u0435 \u043f\u043e\u0442\u043e\u043a\u043e\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u0435\u043d<\/strong>. \u0412 Spring-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u043e\u0442\u043e\u043a\u0430\u0445 Tomcat (\u043f\u043e \u0434\u0435\u0444\u043e\u043b\u0442\u0443 \u0434\u0432\u0435\u0441\u0442\u0438), \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u044b\u0439 <code>put<\/code> \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u043a \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u043c\u0443 \u0446\u0438\u043a\u043b\u0443 \u043f\u0440\u0438 resize. \u0414\u043e Java 8 \u044d\u0442\u043e \u0431\u044b\u043b \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u00abhashmap loop\u00bb \u0441 100% CPU; \u0432 Java 8+ \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u0442\u0435\u0440\u044f \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 <code>NullPointerException<\/code> \u043f\u0440\u0438 \u0447\u0442\u0435\u043d\u0438\u0438.<\/p>\n<p>\u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, <code>static<\/code> \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0441\u0441\u044b\u043b\u043a\u0430 \u0436\u0438\u0432\u0451\u0442 \u0432\u0441\u0451 \u0432\u0440\u0435\u043c\u044f \u0436\u0438\u0437\u043d\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f. \u041f\u043b\u0430\u0442\u0435\u0436\u0438 \u0432 \u043d\u0435\u0451 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f, <strong>\u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0443\u0434\u0430\u043b\u044f\u044e\u0442\u0441\u044f<\/strong>. \u0417\u0430 \u043d\u0435\u0434\u0435\u043b\u044e \u0432 \u043f\u0440\u043e\u0434\u0435 \u0442\u0430\u043c \u043d\u0430\u043a\u043e\u043f\u0438\u0442\u0441\u044f \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0437\u0430\u043f\u0438\u0441\u0435\u0439. \u042d\u0442\u043e \u0443\u0442\u0435\u0447\u043a\u0430 \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432\u044b\u043b\u0435\u0437\u0435\u0442 \u043d\u0430\u0440\u0443\u0436\u0443 \u0447\u0435\u0440\u0435\u0437 \u0434\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 OOMKilled-\u043f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0430\u043c\u0438 \u0432 Kubernetes.<\/p>\n<p>\u0412-\u0442\u0440\u0435\u0442\u044c\u0438\u0445, \u044d\u0442\u0430 \u043a\u044d\u0448-\u043a\u043e\u043f\u0438\u044f \u0431\u0443\u0434\u0435\u0442 <strong>\u0440\u0430\u0437\u044a\u0435\u0437\u0436\u0430\u0442\u044c\u0441\u044f<\/strong> \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435\u043c \u0432 \u0411\u0414, \u043a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u0442\u043e-\u0442\u043e \u043f\u043e\u043c\u0435\u043d\u044f\u0435\u0442 \u043f\u043b\u0430\u0442\u0451\u0436 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0447\u0435\u0440\u0435\u0437 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044e \u0438\u043b\u0438 \u0434\u0440\u0443\u0433\u043e\u0439 \u0438\u043d\u0441\u0442\u0430\u043d\u0441. Stale data \u0432 \u043f\u043b\u0430\u0442\u0451\u0436\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u2014 \u044d\u0442\u043e \u044d\u0432\u0444\u0435\u043c\u0438\u0437\u043c \u0434\u043b\u044f \u00ab\u0434\u0435\u043d\u044c\u0433\u0438 \u043d\u0435 \u0442\u0430\u043c, \u0433\u0434\u0435 \u043d\u0430\u0434\u043e\u00bb.<\/p>\n<pre><code class=\"java\">\/\/ \u274c \u2014 \u043c\u0438\u043d\u0430 \u0437\u0430\u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044fprivate static Map&lt;UUID, Payment&gt; cache = new HashMap&lt;&gt;();\/\/ \u2705 \u2014 Caffeine \u0441 TTL \u0438 max sizeprivate final Cache&lt;UUID, Payment&gt; cache = Caffeine.newBuilder()    .maximumSize(10_000)    .expireAfterWrite(Duration.ofMinutes(5))    .build();\/\/ \u0438\u043b\u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u0431\u0440\u0430\u0442\u044c \u2014 \u043a\u044d\u0448\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u0411\u0414 \u0447\u0435\u0440\u0435\u0437 Hibernate L2 cache<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u0440\u0435\u0436\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445, \u043d\u043e \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u2014 \u043d\u0430 Senior-\u0437\u0430\u0434\u0430\u0447\u0430\u0445.<\/strong> \u042d\u0442\u043e \u0441\u0430\u043c\u044b\u0439 Senior-level \u0431\u0430\u0433 \u0438\u0437 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0432\u043e\u0441\u044c\u043c\u0451\u0440\u043a\u0438, \u0438 \u0435\u0433\u043e \u0443\u043c\u0435\u044e\u0442 \u0440\u0430\u0437\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435, \u043a\u0442\u043e \u0443\u0436\u0435 \u0445\u043e\u0442\u044c \u0440\u0430\u0437 \u043b\u043e\u0432\u0438\u043b \u0443 \u0441\u0435\u0431\u044f production memory leak.<\/p>\n<hr\/>\n<h3>\ud83d\udea8 \u0411\u043e\u043d\u0443\u0441-\u0431\u0430\u0433 \u21169. \u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u043a\u0430\u0442\u0430\u0441\u0442\u0440\u043e\u0444\u0430: \u043d\u0435\u0442 \u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438<\/h3>\n<p>\u042d\u0442\u043e \u0442\u043e\u0442 \u0431\u0430\u0433, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u00ab\u043d\u0430\u0439\u0434\u0438\u0442\u0435 8 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u00bb <strong>\u043e\u0431\u044b\u0447\u043d\u043e \u043d\u0435 \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u0432\u043e\u043e\u0431\u0449\u0435<\/strong> \u2014 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0437\u0430\u0434\u0430\u0447\u0430 \u0442\u043e\u043b\u043a\u0430\u0435\u0442 \u0438\u0441\u043a\u0430\u0442\u044c \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u043a\u043e\u0434\u0435, \u0430 \u043d\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u0435\u043b\u044b \u0434\u0438\u0437\u0430\u0439\u043d\u0430. \u042f \u0432 \u0441\u0432\u043e\u0438\u0445 \u0440\u0430\u0437\u0431\u043e\u0440\u0430\u0445 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u043f\u043e\u0434 \u0431\u0430\u043d\u043a\u0438 \u0432\u0438\u0434\u0435\u043b \u0435\u0433\u043e \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u043c <strong>\u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e<\/strong> \u0441\u0447\u0438\u0442\u0430\u043d\u043e\u0435 \u0447\u0438\u0441\u043b\u043e \u0440\u0430\u0437 \u2014 \u0438 \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u043d\u0435 \u0432 Code Review-\u0441\u0435\u043a\u0446\u0438\u0438, \u0430 \u043d\u0430 System Design.<\/p>\n<p>\u041a\u043e\u043d\u0442\u0435\u043a\u0441\u0442. \u041a\u043b\u0438\u0435\u043d\u0442 \u043d\u0430\u0436\u0430\u043b \u00ab\u043e\u043f\u043b\u0430\u0442\u0438\u0442\u044c\u00bb. \u0417\u0430\u043f\u0440\u043e\u0441 \u0443\u0448\u0451\u043b \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440. \u041f\u043e \u0434\u043e\u0440\u043e\u0433\u0435 \u2014 connection timeout. \u041a\u043b\u0438\u0435\u043d\u0442 \u0432\u0438\u0434\u0438\u0442 \u00ab\u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c\u00bb, \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u0442 \u00ab\u043e\u043f\u043b\u0430\u0442\u0438\u0442\u044c\u00bb <strong>\u0435\u0449\u0451 \u0440\u0430\u0437<\/strong>. \u041d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440 \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u0435\u0442 \u0432\u0442\u043e\u0440\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 <strong>\u0442\u0435\u043c\u0438 \u0436\u0435<\/strong> \u0434\u0430\u043d\u043d\u044b\u043c\u0438. \u0427\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442?<\/p>\n<p>\u0412 \u044d\u0442\u043e\u043c \u043a\u043e\u0434\u0435 \u2014 <strong>\u0434\u0432\u0430 \u043f\u043b\u0430\u0442\u0435\u0436\u0430<\/strong>. \u0414\u0435\u043d\u044c\u0433\u0438 \u0441\u043f\u0438\u0441\u0430\u043b\u0438\u0441\u044c \u0434\u0432\u0430\u0436\u0434\u044b. \u041a\u043b\u0438\u0435\u043d\u0442 \u043f\u0438\u0448\u0435\u0442 \u0432 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u043f\u0438\u0448\u0435\u0442 \u0432\u0430\u043c, \u0432\u044b \u0438\u0437\u0432\u0438\u043d\u044f\u0435\u0442\u0435\u0441\u044c \u0438 \u0434\u0435\u043b\u0430\u0435\u0442\u0435 \u0432\u043e\u0437\u0432\u0440\u0430\u0442 \u0432\u0440\u0443\u0447\u043d\u0443\u044e. \u0412 \u043a\u0440\u0443\u043f\u043d\u043e\u043c \u0431\u0430\u043d\u043a\u0435 \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0442\u044c\u0441\u044f <strong>\u0441\u043e\u0442\u043d\u0438 \u0440\u0430\u0437 \u0432 \u0434\u0435\u043d\u044c<\/strong>.<\/p>\n<p>\u041f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 <strong>Idempotency-Key header<\/strong>. \u041a\u043b\u0438\u0435\u043d\u0442 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 UUID, \u043a\u043b\u0430\u0434\u0451\u0442 \u0432 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a <code>Idempotency-Key<\/code>. \u0421\u0435\u0440\u0432\u0435\u0440 \u0445\u0440\u0430\u043d\u0438\u0442 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 UNIQUE constraint. \u041f\u043e\u0432\u0442\u043e\u0440\u043d\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 \u0442\u0435\u043c \u0436\u0435 \u043a\u043b\u044e\u0447\u043e\u043c \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 <strong>\u0442\u043e\u0442 \u0436\u0435<\/strong> \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u043b\u0430\u0442\u0435\u0436\u0430.<\/p>\n<pre><code class=\"java\">\/\/ \u2705@PostMappingpublic ResponseEntity&lt;PaymentDto&gt; create(    @RequestHeader(\"Idempotency-Key\") UUID idempotencyKey,    @Valid @RequestBody CreatePaymentRequest request) {    return idempotencyService.executeOnce(idempotencyKey,        () -&gt; paymentService.create(request));}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412 \u043f\u043b\u0430\u0442\u0451\u0436\u043d\u044b\u0445 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e \u044d\u0442\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u044e\u0442 \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u2014 \u043d\u043e \u043a\u0430\u043a \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435, \u043d\u0435 \u043a\u0430\u043a \u0447\u0430\u0441\u0442\u044c Code Review. \u041a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u043e\u0441\u0435\u043c\u044c \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u0432 \u043a\u043e\u0434\u0435, \u0434\u043e\u0445\u043e\u0434\u0438\u0442 \u0434\u043e Senior-\u0443\u0440\u043e\u0432\u043d\u044f, \u043d\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u043f\u0440\u043e\u0431\u0435\u043b \u0432 \u0432\u0438\u0434\u0435 \u00ab\u0430 \u0435\u0441\u043b\u0438 \u0444\u0440\u043e\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u00bb \u043e\u0431\u044b\u0447\u043d\u043e \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0437\u0430 \u043a\u0430\u0434\u0440\u043e\u043c. \u042d\u0442\u043e \u043d\u0435 \u0432\u0438\u043d\u0430 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u0430 \u2014 \u0444\u043e\u0440\u043c\u0430\u0442 \u00ab\u043d\u0430\u0439\u0434\u0438\u0442\u0435 N \u0431\u0430\u0433\u043e\u0432\u00bb <strong>\u0441\u0430\u043c \u043f\u043e \u0441\u0435\u0431\u0435<\/strong> \u0442\u043e\u043b\u043a\u0430\u0435\u0442 \u0438\u0441\u043a\u0430\u0442\u044c \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0448\u0438\u0431\u043a\u0438, \u0430 \u043d\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0435.<\/p>\n<blockquote>\n<p><strong>\u0414\u043e\u0447\u0438\u0442\u0430\u0432\u0448\u0438\u0435 \u2014 \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u044d\u0442\u043e \u043c\u0435\u0441\u0442\u043e.<\/strong> \u0417\u0434\u0435\u0441\u044c \u0441\u0430\u043c\u0430\u044f \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u00ab\u043f\u0440\u043e\u0447\u0438\u0442\u0430\u043b Bloch\u2019\u0430\u00bb \u0438 \u00ab\u0440\u0430\u0437\u0431\u0438\u0440\u0430\u043b\u0441\u044f \u0441 \u043f\u0440\u043e\u0434-\u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442\u0430\u043c\u0438\u00bb. \u0418\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u2014 \u044d\u0442\u043e \u043d\u0435 \u0442\u043e, \u0447\u0442\u043e \u0432\u044b \u0432\u044b\u0443\u0447\u0438\u0442\u0435 \u0437\u0430 \u0432\u0435\u0447\u0435\u0440. \u042d\u0442\u043e \u043f\u0440\u0438\u0432\u044b\u0447\u043a\u0430.<\/p>\n<\/blockquote>\n<hr\/>\n<h3>\u0427\u0442\u043e \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0443\u0440\u043e\u0432\u043d\u0435<\/h3>\n<figure class=\"\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/ba4\/bca\/f37\/ba4bcaf37e9befc794dd1c51b8fa6489.jpg\" alt=\"https:\/\/images.unsplash.com\/photo-1551434678-e076c223a692?w=1200&amp;q=80&amp;auto=format&amp;fit=cro\" sizes=\"(max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/\/post_images\/ba4\/bca\/f37\/ba4bcaf37e9befc794dd1c51b8fa6489.jpg 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/ba4\/bca\/f37\/ba4bcaf37e9befc794dd1c51b8fa6489.jpg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>https:\/\/images.unsplash.com\/photo-1551434678-e076c223a692?w=1200&amp;q=80&amp;auto=format&amp;fit=cro<\/figcaption><\/div>\n<\/figure>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">\u0423\u0440\u043e\u0432\u0435\u043d\u044c<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u041c\u0438\u043d\u0438\u043c\u0443\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0436\u0434\u0443\u0442<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0411\u0430\u0433\u0438 \u2116\u2116<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Junior<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">3 \u0431\u0430\u0433\u0430: field injection, <code>double<\/code>, <code>System.out<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">1, 2, 3<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Junior+<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">4-5 \u0431\u0430\u0433\u043e\u0432 + \u043f\u043e\u0434\u043d\u044f\u0442\u044b\u0439 \u0432\u043e\u043f\u0440\u043e\u0441 \u043f\u0440\u043e error handling<\/p>\n<\/td>\n<td>\n<p align=\"left\">1\u20134<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Middle<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">6 \u0431\u0430\u0433\u043e\u0432 \u0441 \u0440\u0430\u0437\u0431\u043e\u0440\u043e\u043c transactional-\u0433\u0440\u0430\u043d\u0438\u0446<\/p>\n<\/td>\n<td>\n<p align=\"left\">1\u20136<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Middle+<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">7 \u0431\u0430\u0433\u043e\u0432 + Outbox-\u043f\u0430\u0442\u0442\u0435\u0440\u043d<\/p>\n<\/td>\n<td>\n<p align=\"left\">1\u20137<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Senior<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">8 \u0431\u0430\u0433\u043e\u0432 + \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 cache \u043a\u0430\u043a \u0430\u043d\u0442\u0438-\u043f\u0430\u0442\u0442\u0435\u0440\u043d<\/p>\n<\/td>\n<td>\n<p align=\"left\">1\u20138<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>Senior+<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">8 + <strong>\u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u0432\u043e\u043f\u0440\u043e\u0441 \u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">1\u20139<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b \u043f\u0440\u0438 \u0440\u0430\u0437\u0431\u043e\u0440\u0435 \u0441\u0430\u043c\u0438 \u043d\u0430\u0437\u0432\u0430\u043b\u0438 \u0432\u043e\u0441\u0435\u043c\u044c \u2014 \u043f\u043e\u0437\u0434\u0440\u0430\u0432\u043b\u044f\u044e, \u0443 \u0432\u0430\u0441 \u0443\u0440\u043e\u0432\u0435\u043d\u044c Senior-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 \u0441 \u043e\u043f\u044b\u0442\u043e\u043c code review \u0432 \u043f\u0440\u043e\u0434\u0435. \u0428\u0435\u0441\u0442\u044c \u2014 \u044d\u0442\u043e \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0439 Middle, \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e. \u0415\u0441\u043b\u0438 \u043c\u0435\u043d\u044c\u0448\u0435 \u2014 \u043e\u0431\u044b\u0447\u043d\u043e \u0434\u0435\u043b\u043e \u043d\u0435 \u0432 \u043d\u0435\u0437\u043d\u0430\u043d\u0438\u0438, \u0430 \u0432 <strong>\u0442\u0435\u043c\u043f\u0435 \u0447\u0442\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430<\/strong>: \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u0432 \u043b\u044e\u0431\u043e\u043c Code Review-\u0437\u0430\u0434\u0430\u043d\u0438\u0438 \u2014 \u043d\u0435 \u0447\u0438\u0442\u0430\u0442\u044c \u0441\u0432\u0435\u0440\u0445\u0443 \u0432\u043d\u0438\u0437, \u0430 \u0441\u043d\u0430\u0447\u0430\u043b\u0430 <strong>\u0431\u0435\u0433\u043b\u043e \u043f\u0440\u043e\u0439\u0442\u0438 \u0432\u0435\u0441\u044c \u043a\u043e\u0434<\/strong>, \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c \u00ab\u0441\u0442\u0440\u0430\u043d\u043d\u043e\u0441\u0442\u0438\u00bb \u0433\u0430\u043b\u043e\u0447\u043a\u043e\u0439 \u043d\u0430 \u043f\u043e\u043b\u044f\u0445, \u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0442\u043e\u043c \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0442\u044c\u0441\u044f \u043a \u043a\u0430\u0436\u0434\u043e\u0439 \u043f\u043e \u043e\u0447\u0435\u0440\u0435\u0434\u0438. \u0418\u043d\u0430\u0447\u0435 \u0432\u044b \u0437\u0430\u0432\u0438\u0441\u0430\u0435\u0442\u0435 \u043d\u0430 \u0442\u0440\u0435\u0442\u044c\u0435\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u0438 \u0434\u043e \u043a\u043e\u043d\u0446\u0430 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0434\u043e\u0445\u043e\u0434\u0438\u0442\u0435.<\/p>\n<hr\/>\n<h3>\u0422\u043e\u043f-25 \u00ab\u0437\u0430\u0448\u0438\u0442\u044b\u0445 \u0431\u0430\u0433\u043e\u0432\u00bb \u2014 \u043c\u0438\u043d\u0438-\u0447\u0435\u043a-\u043b\u0438\u0441\u0442 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043e\u0431\u0435\u0441<\/h3>\n<p>\u042f \u0441\u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0441\u043f\u0438\u0441\u043e\u043a \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u0432 Code Review-\u0437\u0430\u0434\u0430\u0447\u0430\u0445 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0441\u043e\u0431\u0435\u0441\u043e\u0432. \u0421\u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u043b \u043f\u043e \u0447\u0430\u0441\u0442\u043e\u0442\u0435, \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u044d\u0442\u0438 \u043f\u0443\u043d\u043a\u0442\u044b \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u044e\u0442 \u043a\u0430\u043a \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043f\u0440\u0438 \u0440\u0430\u0437\u0431\u043e\u0440\u0435. \u041d\u0435 \u0434\u043b\u044f \u0437\u0430\u0443\u0447\u0438\u0432\u0430\u043d\u0438\u044f \u2014 \u0434\u043b\u044f \u043a\u0430\u043b\u0438\u0431\u0440\u043e\u0432\u043a\u0438. \u0415\u0441\u043b\u0438 \u0432\u044b \u0437\u043d\u0430\u0435\u0442\u0435 \u043a\u0430\u0436\u0434\u044b\u0439 \u043f\u0443\u043d\u043a\u0442 \u0438 \u0437\u043d\u0430\u0435\u0442\u0435 <strong>\u043a\u0430\u043a \u0438\u043c\u0435\u043d\u043d\u043e<\/strong> \u043e\u043d \u043b\u0435\u0447\u0438\u0442\u0441\u044f, \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0441 \u044d\u0442\u043e\u0439 \u0441\u0435\u043a\u0446\u0438\u0435\u0439 \u0441\u043e\u0431\u0435\u0441\u0430 \u0443 \u0432\u0430\u0441 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442.<\/p>\n<details class=\"spoiler\">\n<summary>\ud83d\udccb \u0420\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0442\u043e\u043f-25<\/summary>\n<div class=\"spoiler__content\">\n<p><strong>\u041b\u0435\u0433\u0435\u043d\u0434\u0430 \u0433\u0440\u0443\u043f\u043f:<\/strong> \ud83d\udd34 \u2014 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 (\u0431\u0435\u0437 \u044d\u0442\u0438\u0445 \u043f\u0443\u043d\u043a\u0442\u043e\u0432 Code Review-\u0441\u0435\u043a\u0446\u0438\u044f \u0441\u043e\u0431\u0435\u0441\u0430 \u043d\u0435 \u0437\u0430\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f) \ud83d\udfe0 \u2014 \u0447\u0430\u0441\u0442\u043e (\u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0435 \u043f\u0443\u043d\u043a\u0442\u044b \u0434\u043b\u044f Middle+) \ud83d\udfe1 \u2014 \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u043e (\u0445\u0430\u0440\u0430\u043a\u0442\u0435\u0440\u043d\u044b \u0434\u043b\u044f Senior-\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u044b\u0445 \u0437\u0430\u0434\u0430\u0447) \ud83d\udfe2 \u2014 \u0440\u0435\u0436\u0435, \u043d\u043e \u0438\u043a\u043e\u043d\u0438\u0447\u043d\u043e (\u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0442 \u0441\u0435\u043d\u0438\u043e\u0440\u043e\u0432 \u0441 \u043f\u0440\u043e\u0434-\u043e\u043f\u044b\u0442\u043e\u043c)<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">#<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0411\u0430\u0433<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0413\u0440\u0443\u043f\u043f\u0430<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>1<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">Field injection \u0432\u043c\u0435\u0441\u0442\u043e constructor + <code>final<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udd34<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>2<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>double<\/code> \u0434\u043b\u044f \u0434\u0435\u043d\u0435\u0433 \u0432\u043c\u0435\u0441\u0442\u043e <code>BigDecimal<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udd34<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>3<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>System.out.println<\/code> \u0432\u043c\u0435\u0441\u0442\u043e SLF4J<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udd34<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>4<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>catch (Exception e)<\/code> + <code>e.printStackTrace()<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udd34<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>5<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>Optional.get()<\/code> \u0431\u0435\u0437 <code>isPresent()<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udd34<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>6<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>if (opt.isPresent()) ... else ...<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>.map().orElseGet()<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>7<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>findAll().stream().filter()<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>findById<\/code> \/ <code>existsById<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>8<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>@Transactional<\/code> \u0431\u0435\u0437 <code>isolation<\/code> \/ <code>propagation<\/code> \/ <code>rollbackFor<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>9<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">REST-\u0432\u044b\u0437\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 <code>@Transactional<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>10<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>this.method()<\/code> \u043e\u0431\u0445\u043e\u0434\u0438\u0442 \u043f\u0440\u043e\u043a\u0441\u0438 (self-invocation)<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>11<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">Kafka.send \u0431\u0435\u0437 Outbox \u0432 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u0411\u0414<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>12<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0412\u043e\u0437\u0432\u0440\u0430\u0442 <code>Entity<\/code> \u043d\u0430\u0440\u0443\u0436\u0443 \u0431\u0435\u0437 DTO<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>13<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>new RestTemplate()<\/code> \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 \u0432\u043c\u0435\u0441\u0442\u043e \u0431\u0438\u043d\u0430 \u0441 \u043f\u0443\u043b\u043e\u043c<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe0<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>14<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>static HashMap<\/code> \u043a\u044d\u0448 \u0431\u0435\u0437 \u043f\u043e\u0442\u043e\u043a\u043e\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>15<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">Hardcoded URL \/ config \u0432\u043c\u0435\u0441\u0442\u043e <code>@ConfigurationProperties<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>16<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">Endpoint \u0431\u0435\u0437 \u043f\u0430\u0433\u0438\u043d\u0430\u0446\u0438\u0438 (<code>@PageableDefault<\/code>)<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>17<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">N+1 \u0432 Hibernate \u0447\u0435\u0440\u0435\u0437 <code>.forEach(x -&gt; x.getRelation())<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>18<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041d\u0435\u0442 \u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>19<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>Map&lt;String, Object&gt;<\/code> \u043a\u0430\u043a \u0442\u0435\u043b\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432\u043c\u0435\u0441\u0442\u043e typed DTO<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe1<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>20<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0412\u043e\u0437\u0432\u0440\u0430\u0442 <code>null<\/code> \u0438\u0437 \u043c\u0435\u0442\u043e\u0434\u0430 \u0432\u043c\u0435\u0441\u0442\u043e <code>Optional<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>21<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041d\u0435\u0442 <code>@Valid<\/code> \u043d\u0430 \u0432\u0445\u043e\u0434\u043d\u044b\u0445 DTO<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>22<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>new Date()<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>Instant.now()<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>23<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0447\u0438\u0441\u043b\u0430 \u0438 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432\u043c\u0435\u0441\u0442\u043e \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>24<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 <code>Date<\/code> \/ <code>SimpleDateFormat<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>java.time<\/code><\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\"><strong>25<\/strong><\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>e.getMessage()<\/code> \u0443\u0445\u043e\u0434\u0438\u0442 \u043a\u043b\u0438\u0435\u043d\u0442\u0443 \u043d\u0430\u0440\u0443\u0436\u0443<\/p>\n<\/td>\n<td>\n<p align=\"left\">\ud83d\udfe2<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/details>\n<hr\/>\n<h3>\u0427\u0442\u043e \u0434\u0430\u043b\u044c\u0448\u0435<\/h3>\n<p>\u0412 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043e\u0431\u0435\u0449\u0430\u043b Senior System Design. \u041d\u0435 \u0437\u0430\u0431\u044b\u043b \u2014 \u043e\u043d \u0438\u0434\u0451\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c. \u041d\u043e \u043e\u0431\u0435\u0449\u0430\u044e \u0438 \u043a\u043e\u0435-\u0447\u0442\u043e \u043f\u043e\u0431\u043e\u0447\u043d\u043e\u0435: \u0435\u0441\u043b\u0438 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445 \u0441\u043e\u0431\u0435\u0440\u0451\u0442\u0441\u044f \u0445\u043e\u0442\u044f \u0431\u044b \u043f\u044f\u0442\u044c\u0434\u0435\u0441\u044f\u0442 \u0447\u0435\u043b\u043e\u0432\u0435\u043a \u0441\u043e \u0441\u0432\u043e\u0438\u043c \u043a\u043e\u0434\u043e\u043c \u0438\u0437 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043e\u0431\u0435\u0441\u043e\u0432, \u044f \u0441\u0434\u0435\u043b\u0430\u044e <strong>\u0432\u0442\u043e\u0440\u043e\u0439 \u0440\u0430\u0443\u043d\u0434<\/strong> \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u2014 \u0443\u0436\u0435 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c\u0438, \u0431\u043e\u043b\u0435\u0435 \u0438\u0437\u043e\u0449\u0440\u0451\u043d\u043d\u044b\u043c\u0438 \u043b\u043e\u0432\u0443\u0448\u043a\u0430\u043c\u0438. \u0423\u0440\u043e\u0432\u0435\u043d\u044c \u0431\u0443\u0434\u0435\u0442 Middle+ \/ Senior.<\/p>\n<figure class=\"\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/09b\/f94\/1cc\/09bf941ccfcb915ec7c2203dd73ac894.jpg\" alt=\"https:\/\/images.unsplash.com\/photo-1542435503-956c469947f6?w=1200&amp;q=80&amp;auto=format&amp;fit=crop\" sizes=\"(max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/\/post_images\/09b\/f94\/1cc\/09bf941ccfcb915ec7c2203dd73ac894.jpg 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/\/post_images\/09b\/f94\/1cc\/09bf941ccfcb915ec7c2203dd73ac894.jpg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>https:\/\/images.unsplash.com\/photo-1542435503-956c469947f6?w=1200&amp;q=80&amp;auto=format&amp;fit=crop<\/figcaption><\/div>\n<\/figure>\n<p>\u0421\u0432\u043e\u0439 \u0443\u043b\u043e\u0432 \u2014 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438. \u041a\u0430\u043a\u0438\u0435 \u0438\u0437 \u0432\u043e\u0441\u044c\u043c\u0438 \u0431\u0430\u0433\u043e\u0432 \u043d\u0430\u0448\u043b\u0438 \u0441 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0437\u0430\u0445\u043e\u0434\u0430, \u043a\u0430\u043a\u0438\u0435 \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u043b\u0438, \u0447\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u0441\u0432\u0435\u0440\u0445\u0443 \u0441\u0432\u043e\u0435\u0433\u043e. \u0427\u0435\u0440\u0435\u0437 \u0441\u0443\u0442\u043a\u0438 \u043b\u0443\u0447\u0448\u0438\u0439 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439 \u2014 \u0432 \u0437\u0430\u043a\u0440\u0435\u043f, \u0430 \u0441\u0430\u043c\u044b\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435 \u00ab\u043d\u0430\u0445\u043e\u0434\u043a\u0438 \u0441\u0432\u0435\u0440\u0445 \u0432\u043e\u0441\u044c\u043c\u0438\u00bb \u044f \u0440\u0430\u0437\u0431\u0435\u0440\u0443 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0437\u0430\u043c\u0435\u0442\u043a\u0435 \u0443 \u0441\u0435\u0431\u044f \u0432 \u043a\u0430\u043d\u0430\u043b\u0435 <a href=\"https:\/\/t.me\/+vhnTcI92D1k1M2Qy\" rel=\"noopener noreferrer nofollow\">@Java_Jub<\/a>.<\/p>\n<p>\u041e\u0441\u043e\u0431\u043e\u0435 \u0441\u043f\u0430\u0441\u0438\u0431\u043e \u0442\u0435\u043c, \u043a\u0442\u043e \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u0437\u0430\u0441\u0451\u043a \u043f\u044f\u0442\u043d\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442 \u0442\u0430\u0439\u043c\u0435\u0440\u0430 \u0438 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b \u0441\u0430\u043c. \u0415\u0441\u043b\u0438 \u043f\u043e\u043f\u0430\u043b\u043e \u0432 \u0431\u043e\u043b\u044c\u043d\u043e\u0435 \u043c\u0435\u0441\u0442\u043e \u2014 \u0437\u043d\u0430\u0447\u0438\u0442, \u0441\u0442\u0430\u0442\u044c\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0423\u0434\u0430\u0447\u0438 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0441\u043e\u0431\u0435\u0441\u0435. \ud83c\udf40<\/p>\n<hr\/>\n<h3>\ud83d\udd25 \u041a\u043e\u043c\u0443 \u043f\u043e\u043d\u0440\u0430\u0432\u0438\u043b\u043e\u0441\u044c<\/h3>\n<p>\u0415\u0441\u043b\u0438 \u0437\u0430\u0448\u043b\u043e \u2014 \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0438\u0442\u0435, \u0438 \u044f \u043f\u0438\u0448\u0443 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e <strong>\u0442\u0443\u0442 \u0436\u0435<\/strong>. \u0415\u0441\u043b\u0438 \u043d\u0435 \u0437\u0430\u0448\u043b\u043e \u2014 \u0442\u043e\u0436\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0438\u0442\u0435, \u043f\u043e\u043f\u0440\u0430\u0432\u043b\u044e \u0444\u043e\u0440\u043c\u0430\u0442. \u0421\u0435\u0440\u0438\u044f \u043f\u0440\u043e \u0440\u0430\u0437\u0431\u043e\u0440 \u0440\u0443\u0441\u0441\u043a\u0438\u0445 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0441\u043e\u0431\u0435\u0441\u043e\u0432 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0430\u0435\u0442\u0441\u044f, \u0438 <strong>\u044f \u0434\u0435\u043b\u0430\u044e \u0435\u0451 \u0434\u043b\u044f \u0432\u0430\u0441<\/strong>.<\/p>\n<p>\u2014 <em>\u0412\u0430\u0448<\/em> <a href=\"https:\/\/t.me\/+vhnTcI92D1k1M2Qy\" rel=\"noopener noreferrer nofollow\">@Java_Jub<\/a><\/p>\n<p><strong>P.S.<\/strong> \u042d\u0442\u043e \u0431\u044b\u043b\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u0435\u0440\u0445\u0443\u0448\u043a\u0430. \u0412 \u043c\u043e\u0451\u043c \u043a\u0430\u043d\u0430\u043b\u0435 <a href=\"https:\/\/t.me\/+vhnTcI92D1k1M2Qy\" rel=\"noopener noreferrer nofollow\">@Java_Jub<\/a> \u0431\u0430\u0437\u0430 \u0443\u0436\u0435 \u043f\u0435\u0440\u0435\u0432\u0430\u043b\u0438\u043b\u0430 \u0437\u0430 10 000 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432, \u0438 \u043f\u043e\u0434 \u043a\u0430\u0436\u0434\u0443\u044e \u0432\u0430\u043a\u0430\u043d\u0441\u0438\u044e \u0435\u0441\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0433\u0430\u0439\u0434 \u2014 \u0447\u0442\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0441\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442 \u0432 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u043d\u0430 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u0438, \u0441 \u0440\u0430\u0437\u0431\u043e\u0440\u043e\u043c \u043e\u0442\u0432\u0435\u0442\u043e\u0432 \u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u0430\u043c\u0438 \u043a\u043e\u0434\u0430. \u0417\u0430\u0445\u043e\u0434\u0438\u0442\u0435: \u043f\u0440\u043e\u0449\u0435 \u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c\u0441\u044f \u0442\u043e\u0447\u0435\u0447\u043d\u043e \u043f\u043e\u0434 \u0441\u0432\u043e\u0439 \u0441\u043e\u0431\u0435\u0441, \u0447\u0435\u043c \u0443\u0447\u0438\u0442\u044c \u00ab\u0442\u043e\u043f-50 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432\u00bb.<\/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\/1045050\/\">https:\/\/habr.com\/ru\/articles\/1045050\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>https:\/\/images.unsplash.com\/photo-1555066931-4365d14bab8c?w=1200&amp;q=80&amp;auto=format&amp;fit=crop\u041c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u0435 \u043f\u0440\u0438\u0437\u043d\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0434 \u0442\u0435\u043c, \u043a\u0430\u043a \u043c\u044b \u043d\u0430\u0447\u043d\u0451\u043c\u0412 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043e\u0431\u0435\u0449\u0430\u043b, \u0447\u0442\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0432\u043e\u0437\u044c\u043c\u0443\u0441\u044c \u0437\u0430 Senior System Design. \u041d\u0435 \u043e\u0431\u043c\u0430\u043d\u0443\u043b, \u0432\u043e\u0437\u044c\u043c\u0443\u0441\u044c, \u043d\u043e \u043d\u0435 \u0441\u0435\u0439\u0447\u0430\u0441.\u0417\u0430 \u044d\u0442\u0438 \u0434\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445 \u0438 \u0432 \u043b\u0438\u0447\u043a\u0435 \u043c\u043d\u0435 \u043f\u0440\u0438\u0441\u043b\u0430\u043b\u0438 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u043e\u043a \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043e\u0431\u0435\u0441\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0439. \u042f \u0434\u0443\u043c\u0430\u043b \u2014 \u043e\u0442\u0434\u043e\u0445\u043d\u0443. \u0410 \u043f\u043e\u0442\u043e\u043c \u0441\u0435\u043b \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0438 \u043d\u0430\u0442\u043a\u043d\u0443\u043b\u0441\u044f \u043d\u0430 \u043e\u0434\u043d\u0443 \u0438 \u0442\u0443 \u0436\u0435 \u0437\u0430\u0434\u0430\u0447\u0443 \u043f\u043e\u0434\u0440\u044f\u0434 \u0432 \u0434\u0435\u0432\u044f\u0442\u0438 \u0440\u0430\u0437\u043d\u044b\u0445 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e: ASTON, \u0422\u0411\u0430\u043d\u043a, \u0410\u043b\u044c\u0444\u0430, \u0421\u043e\u0432\u043a\u043e\u043c\u0431\u0430\u043d\u043a, \u0418\u043d\u043d\u043e\u0442\u0435\u0445. \u0412\u0435\u0437\u0434\u0435 \u043e\u0434\u043d\u043e \u0438 \u0442\u043e \u0436\u0435 \u2014 \u00ab\u043d\u0430\u0439\u0434\u0438\u0442\u0435 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432\u043e\u0441\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u0432 \u044d\u0442\u043e\u043c \u043a\u0443\u0441\u043a\u0435 Spring-\u043a\u043e\u0434\u0430, \u0443 \u0432\u0430\u0441 \u0434\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442\u00bb. \u0420\u0430\u0437\u043d\u044b\u0435 \u043e\u0431\u0451\u0440\u0442\u043a\u0438, \u0440\u0430\u0437\u043d\u044b\u0435 \u0434\u043e\u043c\u0435\u043d\u044b: \u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u043e\u0437\u043d\u0430\u0433\u0440\u0430\u0436\u0434\u0435\u043d\u0438\u0439, \u0431\u0440\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043c\u0435\u0441\u0442\u0430 \u0432 \u0441\u0430\u043c\u043e\u043b\u0451\u0442\u0435, \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0446\u0435\u043d \u0438\u0437 \u043f\u0440\u0430\u0439\u0441-\u043b\u0438\u0441\u0442\u0430, \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439. \u041d\u043e \u0441\u043a\u0435\u043b\u0435\u0442 \u043e\u0434\u0438\u043d: \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043d\u0430 \u043f\u043e\u043b\u0441\u043e\u0442\u043d\u0438 \u0441\u0442\u0440\u043e\u043a, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0437\u0430\u0448\u0438\u0442\u044b \u043b\u043e\u0432\u0443\u0448\u043a\u0438 \u043e\u0442 Junior \u0434\u043e Senior \u0443\u0440\u043e\u0432\u043d\u044f.\u042f \u0432\u044b\u043f\u0438\u0441\u0430\u043b \u0432\u043e\u0441\u0435\u043c\u044c \u0442\u0438\u043f\u043e\u0432\u044b\u0445 \u0431\u0430\u0433\u043e\u0432, \u0441\u043e\u0431\u0440\u0430\u043b \u0432 \u043e\u0434\u0438\u043d \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u2014 \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u044e \u043a\u0430\u043a \u0442\u0435\u0441\u0442. \u0425\u043e\u0447\u0443, \u0447\u0442\u043e\u0431\u044b \u0432\u044b \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b\u0438 \u0441\u0430\u043c\u0438, \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044f \u043d\u0430\u0447\u043d\u0443 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c. \u042d\u0442\u043e \u0442\u0430 \u0441\u0430\u043c\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0432\u0430\u043c, \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, \u0434\u0430\u0434\u0443\u0442 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0441\u043e\u0431\u0435\u0441\u0435 \u0432 \u043a\u0440\u0443\u043f\u043d\u043e\u043c \u0431\u0430\u043d\u043a\u0435.\u0417\u0430\u0441\u0435\u043a\u0438\u0442\u0435 \u043f\u044f\u0442\u043d\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442 \u043d\u0430 \u0442\u0430\u0439\u043c\u0435\u0440\u0435. \u0421\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u2014 \u043d\u043e\u0440\u043c\u0430 Middle, \u0447\u0435\u0442\u044b\u0440\u0435 \u2014 Junior, \u0432\u043e\u0441\u0435\u043c\u044c \u0438 \u0432\u044b\u0448\u0435 \u2014 Senior \u0441 \u043e\u043f\u044b\u0442\u043e\u043c code review. \u0411\u043e\u043d\u0443\u0441\u043d\u044b\u0439 \u0434\u0435\u0432\u044f\u0442\u044b\u0439 \u044f \u0437\u0430\u0448\u0438\u043b \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e: \u0435\u0433\u043e \u0432 \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435 \u043e\u0431\u044b\u0447\u043d\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u043d\u0430\u0445\u043e\u0434\u044f\u0442, \u0438 \u043e\u043d \u043d\u0435 \u043f\u0440\u043e \u043a\u043e\u0434, \u0430 \u043f\u0440\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443.\u041a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0437\u0430\u0434\u0430\u0447\u0438\u0414\u0430\u043d\u043e \u2014 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u0432 Spring. \u041d\u0430 \u0432\u0445\u043e\u0434\u0435: \u0441\u0447\u0451\u0442 \u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044f, \u0441\u0447\u0451\u0442 \u0437\u0430\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0441\u0443\u043c\u043c\u0430. \u0412\u043d\u0443\u0442\u0440\u0438 \u2014 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0447\u0435\u0440\u0435\u0437 \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434, \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0432 \u0411\u0414, \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u044f \u0441\u043e\u0431\u044b\u0442\u0438\u044f \u0432 Kafka, \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u043f\u043b\u0430\u0442\u0435\u043b\u044c\u0449\u0438\u043a\u0443. \u0421\u0442\u0435\u043a \u043a\u0430\u043a \u0443 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0431\u0430\u043d\u043a\u043e\u0432 \u0438\u0437 \u043c\u043e\u0435\u0439 \u0431\u0430\u0437\u044b: Spring Boot 3, PostgreSQL, Kafka, JPA, REST-\u043a\u043b\u0438\u0435\u043d\u0442 \u0434\u043b\u044f \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434\u0430.\u0424\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u043e\u0442 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u0430 (\u0431\u043b\u0438\u0437\u043a\u043e \u043a \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u0443 \u0438\u0437 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e \u0422\u0411\u0430\u043d\u043a #531):\u00ab\u0423 \u0432\u0430\u0441 \u0434\u0432\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442. \u041d\u0430\u0439\u0434\u0438\u0442\u0435 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432\u043e\u0441\u0435\u043c\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u2014 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445, \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0445, \u043b\u044e\u0431\u044b\u0445. \u0421\u0447\u0438\u0442\u0430\u044e\u0442\u0441\u044f \u043d\u0430\u0439\u0434\u0435\u043d\u043d\u044b\u043c\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435, \u0447\u0442\u043e \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u0431\u044a\u044f\u0441\u043d\u0438\u0442\u044c \u0432\u0441\u043b\u0443\u0445: \u043f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e \u0431\u0430\u0433, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442 \u0432 \u043f\u0440\u043e\u0434\u0435, \u043a\u0430\u043a \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c. \u041d\u0430\u0437\u0432\u0430\u0442\u044c \u043e\u0448\u0438\u0431\u043a\u0443, \u043d\u043e \u043d\u0435 \u043e\u0431\u044a\u044f\u0441\u043d\u0438\u0442\u044c \u2014 \u043d\u0435 \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f.\u00bb\u0414\u0430\u043b\u044c\u0448\u0435 \u2014 \u043a\u043e\u0434. \u041f\u0440\u043e\u043a\u0440\u0443\u0442\u0438\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0434\u043e \u043a\u043e\u043d\u0446\u0430 \u043a\u043e\u0434\u0430 \u0438 \u043d\u0435 \u043f\u043e\u0434\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0439\u0442\u0435 \u0432 \u0440\u0430\u0437\u0431\u043e\u0440 \u2014 \u0438\u043d\u0430\u0447\u0435 \u0432\u0441\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0442\u0435\u0440\u044f\u0435\u0442 \u0441\u043c\u044b\u0441\u043b.\u041a\u043e\u0434@RestController@RequestMapping(&#171;\/payments&#187;)public class PaymentController {    @Autowired private PaymentRepository repo;    @Autowired private KafkaTemplate&lt;String, String&gt; kafka;    @Autowired private NotificationService notifications;    @Autowired private AntifraudClient antifraud;    private static Map&lt;UUID, Payment&gt; cache = new HashMap&lt;&gt;();    @PostMapping    @Transactional    public ResponseEntity&lt;?&gt; create(@RequestBody Map&lt;String, Object&gt; body) {        try {            String from = (String) body.get(&#171;from&#187;);            String to = (String) body.get(&#171;to&#187;);            double amount = (double) body.get(&#171;amount&#187;);            if (amount &gt; 1000000) {                System.out.println(&#171;Large: &#187; + amount);            }            Payment p = new Payment();            p.setId(UUID.randomUUID());            p.setFromAccount(from);            p.setToAccount(to);            p.setAmount(amount);            p.setCreatedAt(new Date());            p.setStatus(&#171;PENDING&#187;);            String r = antifraud.check(p);            if (!&#187;OK&#187;.equals(r))                throw new RuntimeException(&#171;Declined: &#187; + r);            repo.save(p);            cache.put(p.getId(), p);            kafka.send(&#171;payments&#187;, p.toString());            this.sendNotification(p);            return ResponseEntity.ok(p);        } catch (Exception e) {            e.printStackTrace();            return ResponseEntity.status(500).body(e.getMessage());        }    }    @Transactional(propagation = Propagation.REQUIRES_NEW)    public void sendNotification(Payment p) {        notifications.send(p.getFromAccount(),            &#171;Payment &#187; + p.getAmount() + &#187; sent&#187;);    }}Pause. https:\/\/images.unsplash.com\/photo-1495364141860-b0d03eccd065?w=1200&amp;q=80&amp;auto=format&amp;fit=crop\u041f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0430: \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u0447\u0438\u0442\u0430\u0442\u044c \u0434\u0430\u043b\u044c\u0448\u0435, \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u0438\u0442\u0435 \u0432\u0432\u0435\u0440\u0445 \u0438 \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u043d\u0430 \u043a\u043e\u0434 \u043f\u044f\u0442\u043d\u0430\u0434\u0446\u0430\u0442\u044c \u043c\u0438\u043d\u0443\u0442. \u0418\u043d\u0430\u0447\u0435 \u0440\u0430\u0437\u0431\u043e\u0440 \u043d\u0435 \u043e\u0442\u043b\u043e\u0436\u0438\u0442\u0441\u044f \u2014 \u0433\u043b\u0430\u0437\u0430 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u0431\u0435\u0433\u0443\u0442 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 \u043e\u0442\u0432\u0435\u0442\u044b.\u0413\u043e\u0442\u043e\u0432\u044b? \u041f\u043e\u0435\u0445\u0430\u043b\u0438.\u0420\u0430\u0437\u0431\u043e\u0440. \u0412\u043e\u0441\u0435\u043c\u044c \u0431\u0430\u0433\u043e\u0432 \u043e\u0442 Junior \u0434\u043e Senior\u042f \u0440\u0430\u0437\u043b\u043e\u0436\u0438\u043b \u0431\u0430\u0433\u0438 \u043f\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u2014 \u043e\u0442 \u0441\u0430\u043c\u043e\u0433\u043e \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e\u0433\u043e \u0434\u043e \u0441\u0430\u043c\u043e\u0433\u043e \u043a\u043e\u0432\u0430\u0440\u043d\u043e\u0433\u043e. \u0423 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0432 \u043a\u043e\u043d\u0446\u0435 \u0443\u043a\u0430\u0436\u0443 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e \u043e\u0446\u0435\u043d\u043a\u0443 \u2014 \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0447\u0430\u0441\u0442\u043e \u044d\u0442\u043e\u0442 \u0431\u0430\u0433 \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u044e\u0442 \u043a\u0430\u043a \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u0443\u043d\u043a\u0442 Code Review-\u0441\u0435\u043a\u0446\u0438\u0438 \u0432 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e.\u0411\u0430\u0433 \u21161. Field injection \u0432\u043c\u0435\u0441\u0442\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0430\u0427\u0435\u0442\u044b\u0440\u0435 @Autowired \u043d\u0430 \u043f\u043e\u043b\u044f\u0445, \u0438 \u043d\u0438 \u043e\u0434\u043d\u043e \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 final. \u042d\u0442\u043e \u043f\u0435\u0440\u0432\u043e\u0435, \u0447\u0442\u043e \u0434\u043e\u043b\u0436\u0435\u043d \u0443\u0432\u0438\u0434\u0435\u0442\u044c Middle-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a. Field injection \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u043b\u0430\u0441\u0441 \u043d\u0435\u043f\u0440\u0438\u0433\u043e\u0434\u043d\u044b\u043c \u043a \u044e\u043d\u0438\u0442-\u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \u0431\u0435\u0437 \u043f\u043e\u0434\u043d\u044f\u0442\u0438\u044f Spring-\u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430, \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u043e runtime, \u0438 \u2014 \u0447\u0442\u043e \u0445\u0443\u0436\u0435 \u0432\u0441\u0435\u0433\u043e \u2014 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e \u043c\u0443\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e.\/\/ \u274c@Autowiredprivate PaymentRepository repo;\/\/ \u2705private final PaymentRepository repo;public PaymentController(PaymentRepository repo, \/* \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 *\/) { &#8230; }\/\/ \u0438\u043b\u0438 Lombok @RequiredArgsConstructor + private final\u0427\u0430\u0441\u0442\u043e\u0442\u0430 \u043d\u0430 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0441\u043e\u0431\u0435\u0441\u0430\u0445: \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 Code Review-\u0437\u0430\u0434\u0430\u0447\u0435. \u0411\u0435\u0437 \u043d\u0435\u0433\u043e \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0430 \u0432\u043e\u043e\u0431\u0449\u0435 \u0440\u0435\u0434\u043a\u043e\u0441\u0442\u044c.\u0411\u0430\u0433 \u21162. double \u0434\u043b\u044f \u0434\u0435\u043d\u0435\u0433\u0421\u0443\u043c\u043c\u0430 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442 \u043a\u0430\u043a double, \u0434\u0430\u043b\u044c\u0448\u0435 \u0441 \u043d\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u042d\u0442\u043e \u0443\u0440\u043e\u0432\u0435\u043d\u044c \u0434\u0435\u0442\u0441\u043a\u043e\u0433\u043e \u0441\u0430\u0434\u0430 \u0432 \u0444\u0438\u043d\u0442\u0435\u0445\u0435. 0.1 + 0.2 \u0432 Java \u0434\u0430\u0451\u0442 0.30000000000000004. \u041d\u0430 \u043e\u0434\u043d\u043e\u043c \u043f\u043b\u0430\u0442\u0435\u0436\u0435 \u044d\u0442\u043e \u043a\u043e\u043f\u0435\u0439\u043a\u0430. \u041d\u0430 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0435 \u043f\u043b\u0430\u0442\u0435\u0436\u0435\u0439 \u2014 \u0440\u0430\u0441\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u0441\u043e \u0441\u0447\u0451\u0442\u043e\u043c \u0431\u0430\u043d\u043a\u0430, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043a \u0432\u0430\u043c \u0447\u0435\u0440\u0435\u0437 \u043d\u0435\u0434\u0435\u043b\u044e \u043f\u0440\u0438\u0434\u0451\u0442 \u0431\u0443\u0445\u0433\u0430\u043b\u0442\u0435\u0440\u0438\u044f \u0441 \u0432\u043e\u043f\u0440\u043e\u0441\u0430\u043c\u0438.\/\/ \u274cdouble amount = (double) body.get(&#171;amount&#187;);\/\/ \u2705BigDecimal amount = new BigDecimal(body.get(&#171;amount&#187;).toString());\/\/ \u0434\u0430\u043b\u044c\u0448\u0435 \u2014 amount.add(&#8230;), amount.multiply(&#8230;).setScale(2, RoundingMode.HALF_EVEN)\u0418 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u2014 (double) body.get(&#171;amount&#187;) \u0443\u043f\u0430\u0434\u0451\u0442 \u0441 ClassCastException, \u0435\u0441\u043b\u0438 \u0444\u0440\u043e\u043d\u0442 \u043f\u0440\u0438\u0448\u043b\u0451\u0442 \u0447\u0438\u0441\u043b\u043e \u043a\u0430\u043a Integer (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0440\u043e\u0432\u043d\u043e 100 \u0432\u043c\u0435\u0441\u0442\u043e 100.0). \u041d\u0430 \u043f\u0440\u043e\u0434\u0435 \u0442\u0430\u043a\u043e\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u2014 \u0443 \u043c\u0435\u043d\u044f \u0432 \u0431\u0430\u0437\u0435 \u0442\u0440\u0438 \u0441\u043b\u0443\u0447\u0430\u044f, \u043a\u043e\u0433\u0434\u0430 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u043d \u0443\u043f\u0430\u043b \u0438\u043c\u0435\u043d\u043d\u043e \u0438\u0437-\u0437\u0430 \u044d\u0442\u043e\u0433\u043e.\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0447\u0435\u043d\u044c \u0447\u0430\u0441\u0442\u043e. \u0412 \u043f\u043b\u0430\u0442\u0451\u0436\u043d\u044b\u0445 \u0438 \u0444\u0438\u043d\u0442\u0435\u0445-\u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044f\u0445 \u2014 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e.\u0411\u0430\u0433 \u21163. System.out.println \u0432\u043c\u0435\u0441\u0442\u043e \u043b\u043e\u0433\u0433\u0435\u0440\u0430\u0421\u0430\u043c\u0430\u044f \u043a\u0430\u043d\u043e\u043d\u0438\u0447\u043d\u0430\u044f \u043c\u0435\u043b\u043e\u0447\u044c, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0443\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0440\u0435\u0442\u0438\u0439 Junior. System.out \u2014 \u044d\u0442\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 PrintStream, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u043f\u043e\u0442\u043e\u043a, \u043d\u0435 \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u0432 \u0444\u0430\u0439\u043b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u043d\u0435 \u0443\u0440\u043e\u0432\u043d\u0435\u043c INFO\/WARN\/ERROR \u0438 \u0442\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u0440\u043e\u0442\u0430\u0446\u0438\u0438 stdout. \u0412 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0435 \u043d\u0430 Kubernetes \u0432\u0430\u0448 \u00ab\u0432\u0438\u0436\u0443 \u0436\u0435 \u2014 \u0432\u044b\u0432\u043e\u0434\u0438\u0442\u00bb \u0443\u0445\u043e\u0434\u0438\u0442 \u0432 \/dev\/null \u043f\u043e\u0441\u043b\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e rotate.\/\/ \u274cSystem.out.println(&#171;Large: &#187; + amount);\/\/ \u2705log.warn(&#171;Large payment detected: amount={}, from={}, to={}&#187;, amount, from, to);\u0411\u043e\u043d\u0443\u0441: \u043c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0447\u0438\u0441\u043b\u043e 1000000 \u0432 if (amount &gt; 1000000) \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0432 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u0443 LARGE_PAYMENT_THRESHOLD \u0438\u043b\u0438 @ConfigurationProperties. \u0418\u043d\u0430\u0447\u0435 \u0447\u0435\u0440\u0435\u0437 \u043f\u043e\u043b\u0433\u043e\u0434\u0430 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u0442, \u0440\u0443\u0431\u043b\u0438 \u044d\u0442\u043e \u0438\u043b\u0438 \u043a\u043e\u043f\u0435\u0439\u043a\u0438.\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0447\u0435\u043d\u044c \u0447\u0430\u0441\u0442\u043e. \u041a\u0430\u043d\u043e\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043f\u0443\u043d\u043a\u0442 \u0447\u0435\u043a-\u043b\u0438\u0441\u0442\u0430 Code Review.\u0411\u0430\u0433 \u21164. catch (Exception e) + e.printStackTrace() + \u0443\u0442\u0435\u0447\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a \u0432 response\u0422\u0440\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0432 \u043e\u0434\u043d\u043e\u043c \u0431\u043b\u043e\u043a\u0435.\u041f\u0435\u0440\u0432\u0430\u044f \u2014 catch (Exception e) \u0433\u043b\u043e\u0442\u0430\u0435\u0442 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0432\u0441\u0451, \u0432\u043a\u043b\u044e\u0447\u0430\u044f OutOfMemoryError-\u043e\u0431\u0451\u0440\u0442\u043a\u0438, \u043f\u0440\u0435\u0440\u044b\u0432\u0430\u043d\u0438\u044f \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u0438 checked-\u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u043b\u0438 \u043d\u0435 \u0433\u043b\u043e\u0442\u0430\u0442\u044c, \u0430 \u043f\u0440\u043e\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c. \u041f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u2014 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435 \u0434\u043e\u043c\u0435\u043d\u043d\u044b\u0435 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u0430 \u0432\u0441\u0451 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u043e\u0442\u0434\u0430\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 @ControllerAdvice.\u0412\u0442\u043e\u0440\u0430\u044f \u2014 e.printStackTrace() \u043f\u0438\u0448\u0435\u0442 \u0432 System.err. \u042d\u0442\u043e \u0442\u043e\u0442 \u0436\u0435 \u0430\u0434, \u0447\u0442\u043e \u0438 \u0441 println, \u0442\u043e\u043b\u044c\u043a\u043e \u0445\u0443\u0436\u0435: \u0432 Kibana \u0432\u044b \u0441\u0432\u043e\u0439 stack trace \u043d\u0435 \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u043d\u0438\u043a\u043e\u0433\u0434\u0430.\u0422\u0440\u0435\u0442\u044c\u044f \u2014 e.getMessage() \u0443\u0445\u043e\u0434\u0438\u0442 \u043a\u043b\u0438\u0435\u043d\u0442\u0443 \u0432 \u0442\u0435\u043b\u0435 \u043e\u0442\u0432\u0435\u0442\u0430. \u0415\u0441\u043b\u0438 \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043b\u0435\u0442\u0435\u043b Hibernate, \u0432 getMessage() \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u0430 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 \u0438\u043c\u0435\u043d\u0430\u043c\u0438 \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u042d\u0442\u043e \u0443\u0442\u0435\u0447\u043a\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0431\u0430\u0437\u044b \u043d\u0430\u0440\u0443\u0436\u0443, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043b\u044e\u0431\u043e\u0439 \u043f\u0435\u043d\u0442\u0435\u0441\u0442\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c.\/\/ \u274c} catch (Exception e) {    e.printStackTrace();    return ResponseEntity.status(500).body(e.getMessage());}\/\/ \u2705 \u2014 \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u043e \u0447\u0435\u0440\u0435\u0437 @ControllerAdvice@ExceptionHandler(AntifraudDeclinedException.class)public ResponseEntity&lt;ProblemDetail&gt; handle(AntifraudDeclinedException ex) {    log.warn(&#171;Antifraud declined&#187;, ex);    return ResponseEntity.status(HttpStatus.UNPROCESSABLE_ENTITY)        .body(ProblemDetail.forStatusAndDetail(422, &#171;Operation declined&#187;));}\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u0447\u0430\u0441\u0442\u043e. \u041b\u044e\u0431\u0438\u043c\u044b\u0439 \u043f\u0443\u043d\u043a\u0442 \u0441\u0435\u043d\u0438\u043e\u0440\u043e\u0432-\u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u043e\u0432 \u2014 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0442\u0430 \u0447\u0430\u0441\u0442\u044c, \u0447\u0442\u043e \u043f\u0440\u043e e.getMessage() \u0432 response. \u041d\u043e \u043f\u043e\u043b\u043d\u0443\u044e \u0442\u0440\u043e\u0439\u043a\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0432 \u043e\u0434\u043d\u043e\u043c \u0431\u043b\u043e\u043a\u0435 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u044b \u043e\u0431\u044b\u0447\u043d\u043e \u0440\u0430\u0441\u0447\u043b\u0435\u043d\u044f\u044e\u0442 \u043d\u0435 \u0441\u0440\u0430\u0437\u0443.\u0411\u0430\u0433 \u21165. \ud83d\udea8 this.sendNotification(p) \u2014 self-invocation\u0412\u043e\u0442 \u043e\u043d \u2014 \u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u0432\u043e\u043f\u0440\u043e\u0441 \u21167 \u0438\u0437 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438, \u0432 \u0440\u0430\u0437\u0432\u0451\u0440\u043d\u0443\u0442\u043e\u043c \u0432\u0438\u0434\u0435 \u0438 \u0437\u0430\u0448\u0438\u0442\u044b\u0439 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u043a\u043e\u0434.\u0412 \u043a\u043e\u0434\u0435 \u0435\u0441\u0442\u044c \u043c\u0435\u0442\u043e\u0434 sendNotification, \u043f\u043e\u043c\u0435\u0447\u0435\u043d\u043d\u044b\u0439 @Transactional(propagation = REQUIRES_NEW). \u041f\u043e \u0437\u0430\u0434\u0443\u043c\u043a\u0435, \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u0430 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c\u0441\u044f \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u2014 \u0447\u0442\u043e\u0431\u044b \u0435\u0441\u043b\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044f \u043f\u043b\u0430\u0442\u0435\u0436\u0430 \u043e\u0442\u043a\u0430\u0442\u0438\u0442\u0441\u044f, \u0437\u0430\u043f\u0438\u0441\u044c \u043e \u043f\u043e\u043f\u044b\u0442\u043a\u0435 \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e \u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c. \u042d\u0442\u043e \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0439 \u0430\u0443\u0434\u0438\u0442-\u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0439.\u041d\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u043d\u0430 \u043a\u0430\u043a this.sendNotification(p) \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0447\u0435\u0440\u0435\u0437 \u0431\u0430\u0439\u0442-\u043a\u043e\u0434, \u043c\u0438\u043d\u0443\u044f Spring-\u043f\u0440\u043e\u043a\u0441\u0438. \u0410\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f @Transactional(REQUIRES_NEW) \u043c\u043e\u043b\u0447\u0430 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f. \u041d\u0438\u043a\u0430\u043a\u043e\u0439 \u043d\u043e\u0432\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f. \u041d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0438\u0434\u0451\u0442 \u0432 \u0442\u043e\u0439 \u0436\u0435 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0447\u0442\u043e \u0438 \u043f\u043b\u0430\u0442\u0451\u0436. \u0415\u0441\u043b\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u044f \u043f\u0430\u0434\u0430\u0435\u0442 \u2014 \u0437\u0430\u043f\u0438\u0441\u044c \u043e \u043d\u043e\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u043e\u0442\u043a\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u043f\u043b\u0430\u0442\u0435\u0436\u043e\u043c.\u0412 \u043f\u0440\u043e\u0434\u0435 \u044d\u0442\u043e \u0432\u044b\u0441\u0442\u0440\u0435\u043b\u0438\u0442 \u043a\u0430\u043a \u00ab\u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0438 SMS, \u0430 \u043f\u043b\u0430\u0442\u0435\u0436\u0430 \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043d\u0435\u0442\u00bb. \u0418\u043b\u0438 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u2014 \u00ab\u043f\u043b\u0430\u0442\u0451\u0436 \u043f\u0440\u043e\u0448\u0451\u043b, \u0430 SMS \u043d\u0435 \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0438\u00bb. \u0412 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0441\u043b\u0443\u0436\u0431\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0447\u0435\u0440\u0435\u0437 \u043d\u0435\u0434\u0435\u043b\u044e \u0440\u0430\u0437\u0432\u0435\u0434\u0451\u0442 \u0440\u0443\u043a\u0430\u043c\u0438.\/\/ \u274cthis.sendNotification(p);\/\/ \u2705 \u2014 \u0447\u0435\u0442\u044b\u0440\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430 (\u043f\u043e \u0443\u0431\u044b\u0432\u0430\u043d\u0438\u044e \u0447\u0430\u0441\u0442\u043e\u0442\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f)\/\/ 1. Self-injection \u0447\u0435\u0440\u0435\u0437 @Lazypublic PaymentController(@Lazy PaymentController self, &#8230;) { this.self = self; }self.sendNotification(p);\/\/ 2. \u0412\u044b\u043d\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0441\u0435\u0440\u0432\u0438\u0441 NotificationOrchestratornotificationOrchestrator.sendNotification(p);\/\/ 3. AspectJ Mode \u0434\u043b\u044f @Transactional@EnableTransactionManagement(mode = AdviceMode.ASPECTJ)\/\/ 4. TransactionTemplate \u0432\u0440\u0443\u0447\u043d\u0443\u044etransactionTemplate.execute(status -&gt; { notifications.send(&#8230;); return null; });\u0427\u0430\u0441\u0442\u043e\u0442\u0430: \u043e\u0434\u0438\u043d \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043b\u044e\u0431\u0438\u043c\u044b\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432 \u0441\u0435\u043d\u0438\u043e\u0440\u043e\u0432-\u0438\u043d\u0442\u0435\u0440\u0432\u044c\u044e\u0435\u0440\u043e\u0432. \u0421\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442 \u0438 \u0443\u0441\u0442\u043d\u043e, \u0438 \u0437\u0430\u0448\u0438\u0442\u044b\u043c \u0432 \u043a\u043e\u0434 \u2014 \u043a\u0430\u043a \u0437\u0434\u0435\u0441\u044c. \u041f\u043e\u0434\u0432\u043e\u0445 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e @Transactional(REQUIRES_NEW) \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u043a\u0440\u0438\u0447\u0438\u0442 \u00ab\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u00bb, \u0430 \u043d\u0430 \u0434\u0435\u043b\u0435 \u043c\u043e\u043b\u0447\u0430 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f.\u0411\u0430\u0433 \u21166. Antifraud REST-\u0432\u044b\u0437\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 @Transactionalantifraud.check(p) \u2014 \u044d\u0442\u043e, \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, HTTP-\u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u043e \u0432\u043d\u0435\u0448\u043d\u0438\u0439 \u0441\u0435\u0440\u0432\u0438\u0441. \u041f\u043e \u0434\u0435\u0444\u043e\u043b\u0442\u0443 \u0442\u0430\u0439\u043c\u0430\u0443\u0442 \u0443 RestTemplate \u0438\u043b\u0438 WebClient \u2014 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u044c. \u0415\u0441\u043b\u0438 \u0430\u043d\u0442\u0438\u0444\u0440\u043e\u0434 \u0437\u0430\u043b\u0438\u043f \u043d\u0430 \u043c\u0438\u043d\u0443\u0442\u0443, \u0432\u0430\u0448\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u0441&#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-482841","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/482841","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=482841"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/482841\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=482841"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=482841"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=482841"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}