{"id":269,"date":"2018-10-16T21:15:57","date_gmt":"2018-10-16T19:15:57","guid":{"rendered":"http:\/\/discreteempire.com\/?p=269"},"modified":"2021-02-28T15:17:58","modified_gmt":"2021-02-28T14:17:58","slug":"nie-korzystaj-z-axon-i-jpa","status":"publish","type":"post","link":"https:\/\/discreteempire.pl\/index.php\/2018\/10\/16\/nie-korzystaj-z-axon-i-jpa\/","title":{"rendered":"Nie korzystaj z Axon i JPA"},"content":{"rendered":"\n<p>Problemy z JPA i Axonem nie zaczynaj\u0105 si\u0119 od razu. Pocz\u0105tki s\u0105 wolne, chcesz aby wykona\u0142 si\u0119 jeden rozkaz, p\u00f3\u017aniej sto rozkaz\u00f3w, wszystko przechodzi swobodnie i szybko, nie wida\u0107 \u017cadnego problemu. Gdy zaczyna si\u0119 robi\u0107 powa\u017cnie i musisz wykona\u0107 np. czterdzie\u015bci tysi\u0119cy rozkaz\u00f3w to wtedy zauwa\u017casz dziwne zachowanie swojego komputera. Chrom p\u0142acze z g\u0142odu, Intellij przestaje funkcjonowa\u0107 i nagle dostajesz &#8220;Out of Memory exception&#8221;. Siedzisz zdziwiony przed komputerem i si\u0119 zastanawiasz jak prosta logika jednego ifa jest w stanie zje\u015b\u0107 szesna\u015bcie giga bajt\u00f3w pami\u0119ci RAM w kilka sekund.<br><\/p>\n\n\n\n<h2>Problem pami\u0119ci RAM<\/h2>\n\n\n\n<p>Podczas przetwarzania du\u017cej ilo\u015bci rozkaz\u00f3w dla Event Sourcing-owych agregat\u00f3w wyst\u0119puje du\u017ce zu\u017cycie pami\u0119ci RAM.<\/p>\n\n\n\n<h3><strong>Przyczyna<\/strong><\/h3>\n\n\n\n<p>Po profilowaniu aplikacji, mo\u017cna zauwa\u017cy\u0107 du\u017ce zu\u017cycie pami\u0119ci RAM dla klasy TreeSet, kt\u00f3ra jest wykorzystywana w klasach JPA.<\/p>\n\n\n\n<h3><strong>Rozwi\u0105zanie<\/strong><\/h3>\n\n\n\n<p>Rozwi\u0105zanie jest doj\u015b\u0107 proste, wystarczy wykorzysta\u0107 konfiguracj\u0119 <br><a href=\"https:\/\/github.com\/AxonFramework\/AxonFramework\/blob\/master\/spring-boot-autoconfigure\/src\/main\/java\/org\/axonframework\/springboot\/autoconfig\/JdbcAutoConfiguration.java\">JdbcAutoConfiguration<\/a>\u00a0do zapisywania struktur Axonowych w Postgresie. Po zastosowaniu konfiguracji zu\u017cycie pami\u0119ci spada poni\u017cej dwustu pi\u0119\u0107dziesi\u0119ciu sze\u015bciu mega bajt\u00f3w pami\u0119ci RAM.<\/p>\n\n\n\n<p>Wersja Axona: 3.0<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Problemy z JPA i Axonem nie zaczynaj\u0105 si\u0119 od razu. Pocz\u0105tki s\u0105 wolne, chcesz aby wykona\u0142 si\u0119 jeden rozkaz, p\u00f3\u017aniej sto rozkaz\u00f3w, wszystko przechodzi swobodnie i szybko, nie wida\u0107 \u017cadnego problemu. Gdy zaczyna si\u0119 robi\u0107 powa\u017cnie i musisz&#8230; <a class=\"read-more\" href=\"https:\/\/discreteempire.pl\/index.php\/2018\/10\/16\/nie-korzystaj-z-axon-i-jpa\/\">Read More<\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"spay_email":"","jetpack_publicize_message":"","jetpack_is_tweetstorm":false,"jetpack_publicize_feature_enabled":true},"categories":[21],"tags":[26,27,28],"jetpack_featured_media_url":"","jetpack_publicize_connections":[],"jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p9lLj4-4l","jetpack_likes_enabled":true,"jetpack-related-posts":[{"id":297,"url":"https:\/\/discreteempire.pl\/index.php\/2019\/01\/16\/nie-korzystaj-z-axona-i-list\/","url_meta":{"origin":269,"position":0},"title":"Nie korzystaj z Axona i list","date":"2019-01-16","format":false,"excerpt":"To nie jest tak, \u017ce w Axonie w agregatach i sagach nie mo\u017cna korzysta\u0107 z list. Je\u017celi kolekcja zawiera niewielk\u0105 ilo\u015b\u0107 element\u00f3w, oko\u0142o 1000, to nie ma problemu. Je\u017celi jednak wymagana jest obszerniejsza lista to napotykamy problemy pami\u0119ciowe i wydajno\u015bciowe. Co nale\u017cy zrobi\u0107 aby nie mie\u0107 takich problem\u00f3w? Problem pami\u0119ci\u2026","rel":"","context":"In &quot;Nie korzystaj z Axona&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":334,"url":"https:\/\/discreteempire.pl\/index.php\/2019\/01\/16\/nie-korzystaj-z-axona-i-tracking-processor\/","url_meta":{"origin":269,"position":1},"title":"Nie korzystaj z Axona i Tracking Processor","date":"2019-01-16","format":false,"excerpt":"Lubi\u0119 placki i Axona. Przez wi\u0119kszo\u015b\u0107 czasu dzia\u0142a szybko, stabilnie i niezawodnie, a problemy, kt\u00f3re sprawia jako\u015b da si\u0119 rozwi\u0105za\u0107. Jednak tym razem b\u0119d\u0119 namawia\u0142 na ca\u0142kowite porzucenie Tracking Processor. Jest to najlepsza funkcjonalno\u015b\u0107 Axona dodana w wersji 3, a zarazem bardzo niedopracowana. Je\u017celi zale\u017cy Ci na pr\u0119dko\u015bci przetwarzania i\u2026","rel":"","context":"In &quot;Nie korzystaj z Axona&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":280,"url":"https:\/\/discreteempire.pl\/index.php\/2018\/10\/14\/wprowadzenie\/","url_meta":{"origin":269,"position":2},"title":"Wprowadzenie","date":"2018-10-14","format":false,"excerpt":"Od czterech lat jestem profesjonalnym klepaczem kodu. Od dw\u00f3ch lat klepi\u0119 ten kod w do\u015b\u0107 nowych technologiach takich jak: Spring BootSpring Boot DataSpring CloudAxon FrameworkPostgresRabbitMQ Przek\u0142ada si\u0119 to na problemy, na kt\u00f3re nawet szesnasta zak\u0142adka z Stack Overflow nie pomaga. \u0179r\u00f3d\u0142em tych problem\u00f3w nie by\u0142 Spring, spokojnie mo\u017cesz korzysta\u0107 dalej,\u2026","rel":"","context":"In &quot;Nie korzystaj z Axona&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":91,"url":"https:\/\/discreteempire.pl\/index.php\/2017\/11\/05\/lubie-ddd\/","url_meta":{"origin":269,"position":3},"title":"Lubi\u0119 DDD","date":"2017-11-05","format":false,"excerpt":"Na studiach nauczono mnie programowa\u0107 obiektowo, lecz w pracy ta umiej\u0119tno\u015b\u0107 nie bardzo mi si\u0119 przyda\u0142a. Pierwszy du\u017cy projekt, z kt\u00f3rym si\u0119 w niej spotka\u0142em, by\u0142 napisany w architekturze tr\u00f3jwarstwowej. Musia\u0142em zapomnie\u0107 o tym czego si\u0119 wcze\u015bniej nauczy\u0142em i zacz\u0105\u0107 pisa\u0107 strukturalny kod jak w C tylko, \u017ce w Javie.\u2026","rel":"","context":"In &quot;Dynamics&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":75,"url":"https:\/\/discreteempire.pl\/index.php\/2017\/10\/13\/pierwszy-kontakt\/","url_meta":{"origin":269,"position":4},"title":"Pierwszy kontakt","date":"2017-10-13","format":false,"excerpt":"W pracy g\u0142upot robi\u0107 nie mog\u0119 (klient si\u0119 na to nie zgadza),\u00a0 wi\u0119c w domu musz\u0119 si\u0119 wyszale\u0107. Dlatego postanowi\u0142em napisa\u0107 w\u0142asny framework do Unity3D. Od kilku lat stara\u0142em si\u0119 napisa\u0107 jakie\u015b gry ale zawsz\u0119 ko\u0144czy\u0142o si\u0119 to fiaskiem. G\u0142ownie ze wzgl\u0119du na brak test\u00f3w i ci\u0119\u017cki do utrzymania kod.\u2026","rel":"","context":"In &quot;Dynamics&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":153,"url":"https:\/\/discreteempire.pl\/index.php\/2017\/12\/06\/usprawnienia\/","url_meta":{"origin":269,"position":5},"title":"Usprawnienia","date":"2017-12-06","format":false,"excerpt":"Po cz\u0119\u015bciowej implementacji przyszed\u0142 czas na usprawnienie. Pierwsze na czym si\u0119 skupi\u0142em to agregaty. Nic nowego nie wymy\u015bli\u0142em, po prostu wykona\u0142em metod\u0119 Kopiego Pejsta z Axona. Najwi\u0119ksz\u0105 zalet\u0105 przepisywania tego by\u0142o zrozumienie jak dzia\u0142a metoda apply z\u00a0AggregateLifecycle\u00a0i jest to jedna z ciekawszych implementacji jak\u0105 widzia\u0142em w swoim \u017cyciu. Drugim usprawnieniem\u2026","rel":"","context":"In &quot;Dynamics&quot;","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]}],"_links":{"self":[{"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/posts\/269"}],"collection":[{"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/comments?post=269"}],"version-history":[{"count":8,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/posts\/269\/revisions"}],"predecessor-version":[{"id":320,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/posts\/269\/revisions\/320"}],"wp:attachment":[{"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/media?parent=269"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/categories?post=269"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/discreteempire.pl\/index.php\/wp-json\/wp\/v2\/tags?post=269"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}