Design and implementation of highty scaleable trading system for automated stock exchange based on reactive microservices architecture and artificial intelligence algorithms

master
dc.abstract.enMicroservices architecture become the most dynamically evolving branch of software engineering last years. IT companies started to migrate their applications to it. Despite its popularity, it is difficult to find comprehensive source of knowledge, that would provide information how to design system based on this architecture starting from design phase. The purpose of this thesis is to provide up to date guidance how to design system based on this architecture as well as show proof of concept for the system designed based on it.First chapters explain the idea behind this type of architecture as well as helps to understand when it should be used. Pros and cons of microservices are presented as well as alternative architectures that are worth to be considered during system design phase. Next chapters provide detailed overview of technology stack and best practices that are currently used in microservices architecture. As results of research, there are listed different aspect such as:-Threading models-Circuit breakers-System monitoring and observability tools-Microservice communication approachesEach of them is considered in terms of horizontal scalability as well as high availability of system. In order to show example implementation of the system based on presented technology stack, there is proof of concept proposed for the distributed system based on AI algorithms, which provides stock price predictions based on real time stock market data. Last chapters contain overview of the system. System design is evaluated from different perspectives. Final summary shows how microservice architecture goals were achieved in proposed system based on selected technology stack.pl
dc.abstract.plArchitektura mikroserwisowa jest aktualnie najbardziej dynamicznie rozwijaną gałęzią inżynierii oprogramowania. Wiele firm IT migruje swoje aplikacje do wspomnianej architektury. Pomimo tak dużej popularności, trudno jest znaleźć źródło wiedzy, które pomoże w stworzeniu systemu opartego o tą architekturę zaczynając od fazy projektowania a kończąc na wdrożeniu systemu na produkcję. Celem tej pracy jest dostarczenie źródła wiedzy będącego na bieżąco z obecnymi trendami, które pozwoli osiągnąć ten cel. Co więcej, praca ta dostarcza implementację rozproszonego systemu stanowiącego przykład zastosowania zgromadzonych dobrych praktyk oraz narzędzi. Pierwsze rozdziały wyjaśniają terminologię oraz pomagają zrozumieć idee architektury mikroserwisowej. Dostarczają również informacji o tym, jak aplikacja powinna być dzielona na mikroserwisy. Przedstawione są również wady i zalety tej architektury. Kolejne rozdziały poświęcone są analizie najnowszych narzędzi i dobrych praktyk które są stosowane w tej architekturze. Przedstawiają wady i zalety jak również alternatywy dla każdej z nich. Przykładowe aspekty poddane analizie: - Modele wielowątkowości - Narzędzia do monitoringu aplikacji - Modele komunikacji między procesami Ostatnie rozdziały poświęcone są zastosowaniu wyników wykonanej analizy w praktyce, poprzez implementację systemu do przewidywania cen akcji w oparciu o sztuczne sieci neuronowe. Głównym celem jest zaprezentowanie projektu oraz uproszczonej implementacji takiego systemu. System ten poddany jest późniejszej ocenie w kontekście horyzontalnej skalowalności oraz odporności na uszkodzenia.pl
dc.affiliationWydział Matematyki i Informatykipl
dc.areaobszar nauk ścisłychpl
dc.contributor.advisorMartyna, Jerzy - 130359 pl
dc.contributor.authorSzewczyk, Michałpl
dc.contributor.departmentbycodeUJK/WMI2pl
dc.contributor.reviewerMartyna, Jerzy - 130359 pl
dc.contributor.reviewerKalita, Piotr - 128604 pl
dc.date.accessioned2020-07-27T23:13:05Z
dc.date.available2020-07-27T23:13:05Z
dc.date.submitted2019-10-03pl
dc.fieldofstudyinformatyka stosowanapl
dc.identifier.apddiploma-131809-192652pl
dc.identifier.projectAPD / Opl
dc.identifier.urihttps://ruj.uj.edu.pl/xmlui/handle/item/234402
dc.languageengpl
dc.subject.enMicroservices architecture, AI, Neural networks, LMSpl
dc.subject.plArchitektura mikroserwisowa, Algorytmy sztucznej inteligencji, LMSpl
dc.titleDesign and implementation of highty scaleable trading system for automated stock exchange based on reactive microservices architecture and artificial intelligence algorithmspl
dc.title.alternativeProjekt oraz implementacja wysoce skalowalnego systemu do automatycznego obrotu akcjami w oparciu o architekturę reaktywnych mikroserwisów i algorytmy sztucznej inteligencjipl
dc.typemasterpl
dspace.entity.typePublication
dc.abstract.enpl
Microservices architecture become the most dynamically evolving branch of software engineering last years. IT companies started to migrate their applications to it. Despite its popularity, it is difficult to find comprehensive source of knowledge, that would provide information how to design system based on this architecture starting from design phase. The purpose of this thesis is to provide up to date guidance how to design system based on this architecture as well as show proof of concept for the system designed based on it.First chapters explain the idea behind this type of architecture as well as helps to understand when it should be used. Pros and cons of microservices are presented as well as alternative architectures that are worth to be considered during system design phase. Next chapters provide detailed overview of technology stack and best practices that are currently used in microservices architecture. As results of research, there are listed different aspect such as:-Threading models-Circuit breakers-System monitoring and observability tools-Microservice communication approachesEach of them is considered in terms of horizontal scalability as well as high availability of system. In order to show example implementation of the system based on presented technology stack, there is proof of concept proposed for the distributed system based on AI algorithms, which provides stock price predictions based on real time stock market data. Last chapters contain overview of the system. System design is evaluated from different perspectives. Final summary shows how microservice architecture goals were achieved in proposed system based on selected technology stack.
dc.abstract.plpl
Architektura mikroserwisowa jest aktualnie najbardziej dynamicznie rozwijaną gałęzią inżynierii oprogramowania. Wiele firm IT migruje swoje aplikacje do wspomnianej architektury. Pomimo tak dużej popularności, trudno jest znaleźć źródło wiedzy, które pomoże w stworzeniu systemu opartego o tą architekturę zaczynając od fazy projektowania a kończąc na wdrożeniu systemu na produkcję. Celem tej pracy jest dostarczenie źródła wiedzy będącego na bieżąco z obecnymi trendami, które pozwoli osiągnąć ten cel. Co więcej, praca ta dostarcza implementację rozproszonego systemu stanowiącego przykład zastosowania zgromadzonych dobrych praktyk oraz narzędzi. Pierwsze rozdziały wyjaśniają terminologię oraz pomagają zrozumieć idee architektury mikroserwisowej. Dostarczają również informacji o tym, jak aplikacja powinna być dzielona na mikroserwisy. Przedstawione są również wady i zalety tej architektury. Kolejne rozdziały poświęcone są analizie najnowszych narzędzi i dobrych praktyk które są stosowane w tej architekturze. Przedstawiają wady i zalety jak również alternatywy dla każdej z nich. Przykładowe aspekty poddane analizie: - Modele wielowątkowości - Narzędzia do monitoringu aplikacji - Modele komunikacji między procesami Ostatnie rozdziały poświęcone są zastosowaniu wyników wykonanej analizy w praktyce, poprzez implementację systemu do przewidywania cen akcji w oparciu o sztuczne sieci neuronowe. Głównym celem jest zaprezentowanie projektu oraz uproszczonej implementacji takiego systemu. System ten poddany jest późniejszej ocenie w kontekście horyzontalnej skalowalności oraz odporności na uszkodzenia.
dc.affiliationpl
Wydział Matematyki i Informatyki
dc.areapl
obszar nauk ścisłych
dc.contributor.advisorpl
Martyna, Jerzy - 130359
dc.contributor.authorpl
Szewczyk, Michał
dc.contributor.departmentbycodepl
UJK/WMI2
dc.contributor.reviewerpl
Martyna, Jerzy - 130359
dc.contributor.reviewerpl
Kalita, Piotr - 128604
dc.date.accessioned
2020-07-27T23:13:05Z
dc.date.available
2020-07-27T23:13:05Z
dc.date.submittedpl
2019-10-03
dc.fieldofstudypl
informatyka stosowana
dc.identifier.apdpl
diploma-131809-192652
dc.identifier.projectpl
APD / O
dc.identifier.uri
https://ruj.uj.edu.pl/xmlui/handle/item/234402
dc.languagepl
eng
dc.subject.enpl
Microservices architecture, AI, Neural networks, LMS
dc.subject.plpl
Architektura mikroserwisowa, Algorytmy sztucznej inteligencji, LMS
dc.titlepl
Design and implementation of highty scaleable trading system for automated stock exchange based on reactive microservices architecture and artificial intelligence algorithms
dc.title.alternativepl
Projekt oraz implementacja wysoce skalowalnego systemu do automatycznego obrotu akcjami w oparciu o architekturę reaktywnych mikroserwisów i algorytmy sztucznej inteligencji
dc.typepl
master
dspace.entity.type
Publication
Affiliations

* The migration of download and view statistics prior to the date of April 8, 2024 is in progress.

Views
44
Views per month
Views per city
Krakow
7
Leonding
5
Tehran
3
Warsaw
3
Ho Chi Minh City
2
Kelowna
2
Wroclaw
2
Athens
1
Birmingham
1
Bydgoszcz
1

No access

No Thumbnail Available