To są przecież podstawowe rzeczy

#0

Kim jest

ten facet

na scenie?

Piotr Stapp

  • Mam dość unikalne nazwisko - łatwo zapamiętać ;)
  • CEO @ Dotnetomaniak
  • VP @ devWarsztaty
  • Software Architect @ Demant
  • Autor poznajkubernetes.pl
  • M.Sc (distction) Oxford Brooks University in Web Tech
  • M.Sc. Warsaw University of Technology in Computer Science
  • Oraz ......

#1

Rzemieślnik

i

inżynier

Kto to budował?

Rzemieślnik

  • Umie powtarzać wzorce
  • Bardzo dobry rzemieślnik potrafi dopasowywać wzorce
  • Wybitny rzemieślnik potrafi tworzyć wzorce

Architekt

  • Rozumie używane wzorce
  • Przeciętny inżynier rozumie prawa użyte we wzorcach
  • Dobry inżynier umie łączyć wzorce i je weryfikować

#2

Jak tworzyć

dobre aplikacje (rozproszone)?

Pomysł #1

Pomysł #1 - rezultat

Pomysł #2 - historia + exp!

Pomysł #2 - wynik

Junior DEV:

Pomysł #3 - copy BIG ONES

Pomysł #3 - wynik

Pomysł #4

Pomysł #4 - wynik

A na poważnie?

12 factor app

  • Metodologia dwunastu aspektów
  • Może być stosowana do aplikacji napisanych w każdym języku programowania
  • Może być stosowana do aplikacji wykorzystujących dowolną kombinację usług wspierających (bazy danych, kolejki, cache pamięci etc).

Ale czy można im ufać?

  • Stworzyli ją deweloperzy, którzy bezpośrednio byli zaangażowani w tworzenie i wdrażanie setek aplikacji na platformie Heroku
  • Dodatkowo pośrednio byli świadkami produkcji, działania i skalowania setek tysięcy aplikacji
  • Metodologia jest podsumowaniem ich doświadczeń i obserwacji aplikacji typu SaaS

I. Codebase

Jedno źródło kodu śledzone systemem kontroli wersji, wiele wdrożeń

II. Zależności

Jawnie zadeklaruj i wydziel zależności

III. Konfiguracja

Przechowuj konfigurację w środowisku

IV. Usługi wspierające

Traktuj usługi wspierające jako przydzielone zasoby

V. Buduj, publikuj, uruchamiaj

Oddzielaj etap budowania od uruchamiania

VI. Procesy

Uruchamiaj aplikację jako jeden lub więcej bezstanowych procesów

VII. Przydzielanie portów

Udostępniaj usługi przez przydzielanie portów

VIII. Współbieżność

Skaluj przez odpowiednio dobrane procesy

IX. Zbywalność

Zwiększ elastyczność pozwalając na szybkie uruchamianie i zatrzymywanie aplikacji

X. Jednolitość środowisk

Utrzymuj konfigurację środowisk jak najbardziej zbliżoną do siebie

XI. Logi

Traktuj logi jako strumień zdarzeń

XII. Zarządzanie aplikacją

Uruchamiaj zadania administracyjne jako jednorazowe procesy

Podsumowanie

Uruchamiaj zadania administracyjne jako jednorazowe procesy

Podsumowanie

  • 12factor to standard umożliwiający stworzenie dobrych jakościowo aplikacji.

  • Aplikacje 12factor są łatwo przenaszalne - można je hostować wszędzie niezależnie od technologii.

Podsumowanie c.d.

  • 12Factor + np: Kubernetes = <3
  • 12Factor + np: Kubernetes = wdrażanie wszędzie
  • 12Factor + "the new big thing" = easy :)

#3

Ile serwerów

minimalnie potrzebuje nasza aplikacja?

Pomysł #1

Pomysł #1

Pomysł #2

Pomysł #3

3.... 2.... 1
 

M/M/c queue

czyli

Erlang–C model

Matematyka :)

  • Pw - czas oczekiwana
  • A - intensywność ruchu
  • N - Ilość agentów

Opublikowane w 1917 roku przez A.K. Erlang

DEMO!

Podsumowanie czyli a jak się nie da?

  • Dobry orkiestrator na ratunek (np: Kubernetes - sorry)
  • Albo dobra infrastruktura PaaS
  • A w nim:
    • auto skalowanie
    • auto tworzenie nowych "serwerów"
    • auto monitorowanie zużycia, czasu, kolejki itp.
  • A mają te dane => wzorek czeka :)

#4

Czy aplikacja żyje i ma się dobrze czy może już umarła i jest w piekle?

Aplikacje kiedyś (i czasem dziś)

Aplikacje 2014 - *

A na serio

Pomysł #1

Pomysł #2

Health check

Jakie rodzaje

  • Czy aplikacja żyje?

 

  • Czy usługi zależne żyją?

 

  • Czy "domenowo" aplikacja pracuje dobrze?

 

Podsumowując: czy to wystarcza?

  • NIE!!!!
  • Znów potrzeba czegoś co to obsłuży
  • Możemy wybrać:
    • Wybrać/użyć coś PaaS
    • Zbudować coś sami
    • Użyć orkiestratora np: Kubernetes
    • Zrobić miks :)

#5

Jak dokonać migracji bazy danych o godzinie 13:15 jedząc lunch w bezpieczny sposób?

Pomysł #1

Pomysł #2

Pomysł #2

A gdyby tak?

  • Dodaję zmianę w schemacie DB
  • Robię wdrożenie zmiany DB
  • Jak:
    • już wszystko przeszło;
    • czyli jest na UAT/produkcji;
    • czyli stary kod działa z nową wersją schematu;
    • czyli jestem pewien zmiany

         to dopiero używam nowej wersji schematu

Podsumowując

  • Włączamy myślenie :)
  • Pamiętamy że NoSQL to nie rozwiązania problemów z SQL
  • Stosujemy regułę trzech wersji (acz pewnie nazywa się inaczej)
  • W NoSQL są inne sposoby :)

#6

Jak odszukać logi które dotyczą request z 15:31:00:001?

Pomysł #1

Pomysł #1

Pomysł #2

Problem

Rozwiązanie

Podsumowanie czyli "ale jak???"

  • Używać GUID od początku ścieżki
  • Jak się da to już w SPA :) 
  • Przekazywać go zarówno po HTTP jak i kolejkach
  • Uważać na zagnieżdżenia (albo dodać informację o nich)
  • Najprościej w HTTP Header

Koniec?

Jeszcze nie ;)

To są przecież podstawowe rzeczy

By Piotr Stapp

To są przecież podstawowe rzeczy

  • 295