Asynchronní zpracování úloh v projektu PCS
but.committee | doc. Ing. Vladimír Janoušek, Ph.D. (předseda) doc. Ing. Lukáš Burget, Ph.D. (místopředseda) prof. Ing. Jan M. Honzík, CSc. (člen) Ing. Vojtěch Mrázek, Ph.D. (člen) Ing. Jaroslav Rozman, Ph.D. (člen) | cs |
but.defence | Student nejprve prezentoval výsledky, kterých dosáhl v rámci své práce. Komise se poté seznámila s hodnocením vedoucího a posudkem oponenta práce. Student následně odpověděl na otázky oponenta a na další otázky přítomných. Komise se na základě posudku oponenta, hodnocení vedoucího, přednesené prezentace a odpovědí studenta na položené otázky rozhodla práci hodnotit stupněm B. Otázky u obhajoby: Mohl byste přiblížit, jak - a zda vůbec - jste se podílel na návrhu nebo implementaci nové architektury PCS popisované v sekci 2.4? Na jak velkém clusteru (z hlediska počtu výpočetních uzlů) byl výsledek testován? Vidíte nějaké potenciální problémy (ať už konceptuální nebo technické) se škálovatelností Vašeho řešení na větší clustery? Řešil jste nějakým způsobem i fronty úloh? Proč jste práci napsal v angličtině? | cs |
but.jazyk | angličtina (English) | |
but.program | Informační technologie | cs |
but.result | práce byla úspěšně obhájena | cs |
dc.contributor.advisor | Rogalewicz, Adam | en |
dc.contributor.author | Pospíšil, Michal | en |
dc.contributor.referee | Pavela, Jiří | en |
dc.date.created | 2022 | cs |
dc.description.abstract | Projekt PCS je distribuovaná aplikácia. Z toho vyplýva, že potrebuje spôsob ako spúšťať akcie vo vzdialených inštanciách PCS. Cieľom tejto práce je vyvinúť minimálne životaschopné riešenie pre spúšťanie akcií cez REST API, ktoré je implementované metódami asynchrónneho programovania. Tieto akcie však nie sú implementované asynchrónne, takže nemôžu byť spustené priamo z asynchrónneho kódu. REST API je preto napojené na asynchrónny plánovač, ktorý obchádza toto obmedzenie spúšťaním akcií v sade procesov (process pool). Plánovač skrýva akcie za abstrakčnú vrstvu úloh, ktoré uchovávajú informácie o stave a výsledkoch akcií. Všetky akcie potrebujú posielať aktualizácie svojho stavu klientom v reálnom čase. Toto je dosiahnuté jednosmerným komunikačným kanálom medzi akciami a plánovačom, ktorý správy od akcií ukladá do úloh. REST API umožňuje vytváranie, kontrolu stavu a rušenie spracovania úloh. Klient teda môže opakovane žiadať o stav úlohy a takto zobrazovať aktualizácie stavu z akcií. Klient tiež môže zrušiť spracovanie úloh, ktoré bežia príliš dlho. | en |
dc.description.abstract | The PCS project is a distributed application; therefore, many actions need a way to launch actions in remote application instances. The goal of this thesis is to implement a minimum viable solution for executing actions through a REST API that uses the asynchronous programming model. However, actions themselves are not implemented asynchronously and cannot be invoked directly from asynchronous code. The REST API is connected to an asynchronous scheduler that circumvents this limitation by launching actions in a process pool. The scheduler hides actions behind an abstraction layer of tasks that store information about their status and results. All the actions need to send real-time updates to the clients. This is made possible via a one-way communication channel from the actions to the scheduler that updates the tasks. The REST API provides methods for creating, getting results, and killing tasks. Clients can periodically check the task status and show these updates to the user. Clients can also choose to kill tasks that take too long to finish. | cs |
dc.description.mark | B | cs |
dc.identifier.citation | POSPÍŠIL, M. Asynchronní zpracování úloh v projektu PCS [online]. Brno: Vysoké učení technické v Brně. Fakulta informačních technologií. 2022. | cs |
dc.identifier.other | 145331 | cs |
dc.identifier.uri | http://hdl.handle.net/11012/207500 | |
dc.language.iso | en | cs |
dc.publisher | Vysoké učení technické v Brně. Fakulta informačních technologií | cs |
dc.rights | Standardní licenční smlouva - přístup k plnému textu bez omezení | cs |
dc.subject | klaster | en |
dc.subject | klaster s vysokou dostupnosťou | en |
dc.subject | PCS | en |
dc.subject | Pacemaker/Corosync Configuration System | en |
dc.subject | asynchrónne programovanie | en |
dc.subject | AsyncIO | en |
dc.subject | REST | en |
dc.subject | REST API | en |
dc.subject | Tornado | en |
dc.subject | cluster | cs |
dc.subject | high-availability cluster | cs |
dc.subject | PCS | cs |
dc.subject | Pacemaker/Corosync Configuration System | cs |
dc.subject | asynchronous programming | cs |
dc.subject | AsyncIO | cs |
dc.subject | REST | cs |
dc.subject | REST API | cs |
dc.subject | Tornado | cs |
dc.title | Asynchronní zpracování úloh v projektu PCS | en |
dc.title.alternative | Asynchronous Task Processing in PCS Project | cs |
dc.type | Text | cs |
dc.type.driver | bachelorThesis | en |
dc.type.evskp | bakalářská práce | cs |
dcterms.dateAccepted | 2022-06-13 | cs |
dcterms.modified | 2022-09-05-14:16:52 | cs |
eprints.affiliatedInstitution.faculty | Fakulta informačních technologií | cs |
sync.item.dbid | 145331 | en |
sync.item.dbtype | ZP | en |
sync.item.insts | 2025.03.18 19:44:27 | en |
sync.item.modts | 2025.01.15 22:13:16 | en |
thesis.discipline | Informační technologie | cs |
thesis.grantor | Vysoké učení technické v Brně. Fakulta informačních technologií. Ústav inteligentních systémů | cs |
thesis.level | Bakalářský | cs |
thesis.name | Bc. | cs |
Files
Original bundle
1 - 4 of 4
Loading...
- Name:
- final-thesis.pdf
- Size:
- 1.08 MB
- Format:
- Adobe Portable Document Format
- Description:
- final-thesis.pdf
Loading...
- Name:
- Posudek-Vedouci prace-25192_v.pdf
- Size:
- 124.43 KB
- Format:
- Adobe Portable Document Format
- Description:
- Posudek-Vedouci prace-25192_v.pdf
Loading...
- Name:
- Posudek-Oponent prace-25192_o.pdf
- Size:
- 132.62 KB
- Format:
- Adobe Portable Document Format
- Description:
- Posudek-Oponent prace-25192_o.pdf
Loading...
- Name:
- review_145331.html
- Size:
- 1.44 KB
- Format:
- Hypertext Markup Language
- Description:
- file review_145331.html