Skip to content

Zajęcia projektowe i laboratoria w ramach 1DI2338: Programowanie usług w chmurze - przedmiotu prowadzonego na Wydziale Elektrycznym Politechniki Warszawskiej

Notifications You must be signed in to change notification settings

ekote/Programowanie-uslug-w-chmurze

Repository files navigation

Cloud computing

1DI2338: Programowanie usług w chmurze / Cloud computing couse at Warsaw University of Technology

1 - LAB-01 - 19.03

  1. Teoria: M01: Cloud concepts && M02: Core Azure services
  2. LAB - 5p:
  3. Image

2- LAB-02 - 26.03

  1. Teoria - M03: Security, privacy, compliance, and trust
  2. Omowienie labów
  3. Wybór labów - deklaracja per osoba - do 29.03.2020 23:59.
  4. LAB - 10p
  5. Dodatkowe ogłoszenie
Pandemia koronawirusa sprawia, że dużo sektorów zostało zmuszonych do cyfrowej transformacji [1].

Przez to datacenters Microsoftu są mocno obłożone mówiąc delikatnie. Szczególnie w dwóch regionach: Europa i USA, w których brakuje zasobów obliczeniowych.

Z tego powodu Microsoft wyłącza możliwość stawiania niektórych zasobów (tych najbardziej kosztowych pod względem potrzebnej infrastruktury) w pierwszej kolejności dla kont, które nie są podpięte jako płatnicy (Pay as you go). To powoduje, że mogą być blokady w provisioningu np. Azure SQL Db. [2 , 3]. Co będzie dalej - niestety nie wiadomo. Nie mam dostępu do listy zasobów już zablokowanych. 

Jak to wpływa na laboratorium / projekt:
- proszę się upewnić, że włączyliście możliwość provisioningu danego typu zasobu w ramach subskrypcji [4]
- jeśli nie możecie postawić SQL DB to albo możecie zastąpić tę bazę np. poprzez Azure PostgreSQL albo w przypadku labu nr 2 - zrobić lab "Intelligent analytics". 


[1] https://www.reddit.com/r/sysadmin/comments/fry2b7/who_accelerated_digital_transformation_in_your/
[2] https://social.technet.microsoft.com/Forums/azure/en-US/461b4364-1d76-4537-9f8e-3eb60d2ca137/create-sql-database-server-location-africa-south-africa-north?forum=ssdsgetstarted
[3] https://social.technet.microsoft.com/Forums/en-US/ac0376cb-2a0e-4dc2-a52c-d986989e6801/unable-to-create-sql-database-server?forum=ssdsgetstarted
[4] https://docs.microsoft.com/en-us/azure/azure-resource-manager/management/resource-providers-and-types

3- 02.04

  1. Teoria - M04.
  2. Pomoc przy labach

4- LAB-03 - 9.04

  1. Omowienie dostepnych scenariuszy do realizacji.
  2. LAB - 10p
  • Serverless architecture (Before labs)
  • Cognitive services and deep learning
  • Media AI
  • Internet of Things
    • Sprawozdanie (w formie video) ma zawierać:
      • Nazwa: "Lab 03 - "nazwa laboratorium" - Programowanie usług w chmurze"
      • Cel danego laboratorium
      • Pokazanie logowania studenta do Azure Portal
      • Wszystkie kroki, które są efektem wykonania labu plus:
        • Opis architektury z uwzględnieniem odpowiedzialności każdego elementu z diagramu dla danego laboratorium.
        • Jeśli student będzie miał problem w czasie realizacji Exercise/Task i nie uda mu się dokończyć laboratorium z powodu tego problemu wymagany jest opis: czego nie udało się zrealizować, root cause problemu, potencjalny workaround i powód, dla którego ten workaround nie może zostać wykonany.
      • Wnioski z laboratorium w tym przykładowe zastosowanie zbudowanego systemu/platformy/aplikacji.
    • Proszę pamiętać o usunięciu Resource Groups z zasobami, po zrealizowanym labie (Optymalizacja zużycia dostępnych kredytów)
  1. Zapisy na AZ-900 - proszę o wpisanie się na listę
  2. Przegląd narzędzi - deep dive into Azure Databricks.
  3. CosmosDB issue - solution
    • "A Stream Analytics Job provides a simple mechanism for pulling the chat messages from the second Event Hub and writing them to Cosmos DB for archiving" -> zamieniamy CosmosDB na Storage Account Blob. Jak? link
    • Odpuszczamy klocek z "Search", który jest podpięty do cosmosdb na diagramie architektury (czyli Task 8: Provision Azure Search)

5- 16.04

  1. Informacje o obowiązkowym teście wiedzy (za 10p) przygotowującym do egzaminu AZ-900
  2. Przegląd narzędzi - deep dive into containers on Azure.
  3. Demo GCP i pokazanie dostępnych labów - https://www.qwiklabs.com
  4. Konsultacje
  5. Uwaga!! Oddanie LAB-03 przedłużone do 7:15 30.04
  6. niebezpiecznik o aplikacji kwarantanna: https://www.youtube.com/watch?v=vB36FrcWnrY&feature=youtu.be
  7. Kurs Programowanie aplikacji mobilnych i webowych
    1. Level od postaw - https://bitbucket.org/zespoll/notes_from_classes/src/master/
    2. Tryb konsultacyjny - https://github.com/ekote/pw-programowanie-aplikacji-mobilnych-i-webowych
  8. https://azureservices.io/#
  9. Przegląd narzędzi - deep dive into Cognitive Services

23.04 - nie ma zajęć

6- LAB-04 - 30.04

  1. 8:15 - Omowienie labu

  2. 8:30/8:45 - Test wiedzy przygotowujący do egzaminu AZ-900; Obowiązkowy za 10p; w jez. angielskim

07.05 - nie ma zajęć

  • Dodatkowy tydzien na zrobienie LAB-04 dla Was.

7- 14.05

  1. Oddanie projektow
    • Lab04 - do 7:15 14.05
  2. Koniec laboratorium - po tym terminie nie ma mozliwosci uzyskania punktow za zrealizowanie laboratorium
    • wystawienie punktów nastapi w ciagu tygodnia po ostatnich zajeciach

Azure - problemy z subskrypcja

Studenci, którzy nie mają konta studenckiego w Azure lub ich subskrypcja nie pozwala na realizowanie labu proszone są o kontakt z prowadzącą.

Dostępne rozwiązania:

  1. Prowadząca udostępni studentowi przestrzeń w jej subskrypcji.
  2. Prowadząca udostępni studentowi jedną z jej subskrypcji (subskrypcja typu - Subskrypcja programu Visual Studio Enterprise).
  3. Utworzenie nowego konta trial i podpięcie karty kredytowej z numerem np. z revolut. Gdy student nie ma konta revolut to proszę zgłosić się do prowadzącej.
  4. Realizacja zamiennego labu na GCP.

GCP

Inne ogłoszenia

  • Sprawdznie obecności odbywa się na początku zajęć (teoria, wytłumaczenie labów, wybór labów - część obowiązkowa)
  • Sprawozdanie jest wykonywanie w formie video publikowane na YT (publiczne/prywatne)
  • Link do video przesyłany jest za pomocą specjalnego formularza udostępnionego dla każdego laba
  • Publikują Państwo wszystkie video z Państwa konta na YT, od poczatku do konca jedno konto
  • długość 3-10 minut (to wymaganie może ulec zmianie w zależności od labu)
  • Sprawdzana będzie data i godzina, kiedy film został opublikowany
  • Deadline na publikacje, to 1h przed kolejnymi zajęciami, na których nowe laby są prezentowane
  • Za sprawozdanie udostępnione/zuploadowane po terminie (maksymalnie do 7d) można uzyskać połowę punktów
  • Za sprawozdanie udostępnione/zuploadowane po terminie (powyżej 7d) nie są przyznawane punkty
  • Podejrzenie (samo podejrzenie) o niesamodzielności wykonania zadania (labu) jest podstawą do wyzerowania wszystkich labów i wystawienia "Nzal"
  • Szczerość, Zaufanie
  • Picie kawy i innych napoi w czasie zajęć - na własną odpowiedzialność ;)
  • Najlepsze prace (kilka) z każego labu może zostać podlinkowane do tego repozytorium

Oddawanie Labu

Ocena z laboratorium

  • Max 35p z hands-on labs
  • Max 10p test wiedzy
  • Suma Max 45p
  • Oceny (procentowo)
<51; 60) % 3 - min 22.95p
<61; 70) % 3.5 - min 27.45p 
<71; 80) % 4 - min 31.95p
<81; 90) % 4.5 - min 36.45p
>= 91% 5 - min 40.95p

+ extra 10p za zdanie egzaminu AZ-900

Przypomnienie regulaminu kursu

  • Nieobecność: Warunkiem udziału w kursie jest znajomość języka angielskiego umożliwiająca lekturę dokumentacji technicznej. W uzasadnionych i udokumentowanych wypadkach prowadzący zajęcia może usprawiedliwić nieobecność studenta na podstawie jego prośby o usprawiedliwienie nieobecności. Dopuszcza się jedną usprawiedliwioną nieobecność studenta w czasie semestru pod warunkiem uzupełnienia materiału zajęć z inną grupą lub na wyznaczonych przez Kierownika zajęciach dodatkowych. Większa liczba nieobecności skutkuje niezaliczeniem zajęć. Prowadzący zajęcia ma prawo odmówić usprawiedliwienia nieobecności na zajęciach, jeśli uzna, że przyczyna nieobecności nie jest zasadna lub wystarczająco udokumentowana.
  • Cel przedmiotu Celem przedmiotu jest nauczenie zasad tworzenia aplikacji we współczesnych środowiskach chmurowych. Przedmiot przedstawia zasady korzystania i budowania usług w środowiskach rozproszonych oraz tworzenia aplikacji korzystających z usług. Student po ukończeniu zajęć powinien znać różne rodzaje technologii chmurowych, zasady projektowania architektur usługowych oraz potrafić stworzyć oraz wdrożyć system oprogramowania w środowisku chmurowym.
  • Zaliczenie Warunkiem zaliczenia ćwiczeń jest uzyskanie co najmniej 51% pkt.

PROJEKT

  • 19.03 - Intro; zlaszanie tematow w ciagu tygodnia; podzial na grupy 5-6 osobowe; Podzial odpowiedzialnosci w grupie; Na koniec studenci oceniają się nawzajem

  • 26.03 - I obowiązkowe review w grupach; 15min na grupę

  • 2.04 - konsultacje online dla chętnych

  • 9.04 - II obowiązkowe review (5p)

    • Studenci w swoich zespołach zobowiązani są przygotować na spotkanie:
      • Digaram z architekturą - użyte komponenty Azure. Proponowane narzędzia do wykonania diagramu: Visio, Draw.io.
      • Diagram przypadków użycia (funcje aplikacji/systemu/platformy)
      • Techniczne szczegóły (np. z jakiej sieci neuronowej będą korzystać i dlaczego; jaki język programowania i biblioteka)
      • Rozpisane zadania w dowolnym narzędziu (np. Trello, Jira, Azure DevOps, Asana, GitHub, Notatnik, Excel ... dowolne )
      • Założone repozytorium na GitHub
  • 16.04 - konsultacje online dla chętnych

  • 23.04 - konsultacje online dla chętnych

  • 30.04 - konsultacje online dla chętnych

  • 7.05 - III obowiązkowe review (5p)

    • Studenci w swoich zespołach zobowiązani są przygotować na spotkanie:
      • utrzymane wszystkie punty z wcześniejszego review
      • zalążek architektury postawiony na Azure
      • progres w realizacji zadań per członek zespołu
  • 14.05 - konsultacje online dla chętnych

  • 21.05 - konsultacje online dla chętnych

  • 28.05 - konsultacje online dla chętnych

  • 4.06 - Oddanie projektu (40p)

    • Działająca aplikacja/system/platforma
    • Video na YT z prezentacją rozwiązania (link do video musi być dosłany do prowadzącej do 03.06 do godz. 19:00 )
    • Repozytorium na Github zawierające:
      • sprawozdanie
      • pełną dokumentację
  • 11.06 - Wystawienie ocen

Inspiracje projektowe

  1. Wszystkie architektury realizowane w czasie labów
  2. Centrum architektury platformy Azure
  3. Azure Blockchain
  4. Azure security and management
  5. Intelligent vending machines
  6. Lift and shift/Azure Resource Manager
  7. Linux lift and shift
  8. Microservices architecture
  9. Mobile app innovation
  10. Optimized architecture
  11. OSS DevOps
  12. Securing PaaS
  13. Cloud native apps

Polecam wyszukiwanie architektur i warsztatów na GitHub.

Oddanie projektu

  • Video na YT z prezentacją rozwiązania
  • Github z opisanym sprawozdaniem i pełna dokumentacja

Cel projektu

W ramach projektu studenci wykonują kompletny prosty system składający się z gotowych usług, usług napisanych przez studentów oraz aplikacji, która wykorzystuje usługi w chmurze. System jest uruchomiony na platformie chmurowej (PaaS) wybranej przez studentów.

Ocena z projektu

  • 10p review
  • 40p projekt
  • Oceny (procentowo)
<51; 60) % 3
<61; 70) % 3.5
<71; 80) % 4
<81; 90) % 4.5
>= 91% 5

Komunikacja z prowadzącą

Komunikacja prowadząca-studenci odbywa się poprzez email: kote@ee.pw.edu.pl.

Osoby, które nie wiedzą lub mają trudności w pisaniu formalnych wiadomości do prowadzących, proszone są o zapoznanie się z artykułami:

Konsultacje

Konsultacje online odbywają się we wtorki w godz. 16-21 po wcześniejszym zapisaniu się przez portal ISOD.

Dodatkowe linki

Courses

About

Zajęcia projektowe i laboratoria w ramach 1DI2338: Programowanie usług w chmurze - przedmiotu prowadzonego na Wydziale Elektrycznym Politechniki Warszawskiej

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published