Vorgurakendused 2 prax 1 Mikroteenused 2021 kevad

Allikas: Lambda

Sarnaselt teiste praktikumitöödega oleks alustuseks vaja implementeerida lihtne P2P protokoll üle HTTP, nii et:

  • protokoll oleks realiseeritud HTTP protokolli peale (vaja implementeerida ka HTTP server ja klient)
  • mitu sinu rakenduse klooni suudavad suhelda nii samas masinas, töötades eri portide peal, kui mitmes erinevas masinas eri IP-de peal.
  • eesmärk on kõigi rakendused omavahel suhtlema ja ühise võrguna tegutsema panna


Programmeerimiskeel on vabalt valitav. Masin(ad), kus su süsteem töötab, on vabalt valitavad: võid kasutada oma laptoppi, dijkstrat või mõnda muud serverit.

Kood peaks olema TTÜ Gitlabis repositooriumis nimega `ITI0215_2021`. Niimoodi on praktikumitööd õppejõudude poolt lihtsasti leitavad.

Praktikumitöö kirjtutamiseks on kaks suunda.

1. Olemasoleva monoliit-süsteemi dekomponeerimine mikroteenusteks ja selle töölepanemine HTTP Protokollil

2. Stsenaarium, kus on arhitektuur ette kirjutatud (see täpsustub) ja komponendid vahetavad omavahel andmeid.

Vaata ka: Uberi mikroteenuste arhitektuur - https://eng.uber.com/microservice-architecture/.

Mõlemal juhul oleks stsenaarium selline et erinevad teenused saadavad (olgu käsitsi või automaatselt) andmeid failiandmebaasile. Andmebaasiteenus peab suutma hakkama saada sellega et tuleb vastuolulist infot ja olema "single source of truth".

Implementeerida tuleb queue, mis protsese sünkroniseerib.

Edasiarendatud variandis ehitatakse eksperimentaalne süsteemi kus teenuseid pannakse käima hästi palju ja osad neist tehakse meelega katki. Selle kaudu selguvad parimad strateegiad kuidas erinevatest veaolukordadest välja tulla.

Millises järjekorras asju teha

  • Vali välja ja seadista arendusvahendid: IDE sõltuvalt keelest milles kirjutad, tekita esmane Giti repo. Võiksid ka nüüd välja mõelda, kus kavatsed rakendust jooksutada ja kuidas võimalikult mugavalt deployda.
  • Mõtle välja esmane topoloogia - komponendid millest rakendus koosneb ja kuidas need omavahel on seotud.
  • Alustada jooksvalt dokumenteerimist. Mugav on seda teha README.md failis mida Giti repos hoiad
  • Kirjutada hästi lihtne klient ja server, kõigepeallt fiksitud aadressil ja pordil - hiljem saad selle muuta dünaamiliseks.
  • Mõtle juba praegu läbi kuidas ja mida konkreetselt demoda (stsenaariumid, konsoolimessaged jne)

Soovitusi tehnoloogiate valikul

Serverikomponent

Kuna selles aines valmisehitatud veebiservereid a'la Apache või Nginx kasutada ei tohi, siis peaksid selle implementeerima ise. Siin on soovitusi ja viiteid teekide valikuks:

Python:

Java

Node


Go, PHP jne

Päringute testimine

Loe ka: Postman vs Insomnia – why not both?. https://blog.tdwright.co.uk/2018/08/14/postman-vs-insomnia-why-not-both/

Mudeldamine. Kirjeldamine. Dokumenteerimine

Juhul kui juba kasutad mõnda "päris" mudeldamistööriista nt Visual Paradign, Enterprise Architect sobib see väga hästi. Aga reeglina on selliste tööriistade kasutuselevõtmine ajamahukas ja õppimiskõver kõrge. Seepärast on siin erinevaid kergeid alternatiive mis ei vaja installeerimist ja on intuitiivselt kasutatavad.

Viiteid