Stanowe aplikacje Webowe
@Horusiath
http://bartoszsypytkowski.com
Agenda
- Jak zmienił się świat IT?
- Bezstanowe protokoły
- Stanowe aplikacje
- Aktorzy
- Maszyny stanów
- Uwagi
Trochę historii
IT kiedyś i dziś
Dawniej | Obecnie |
---|---|
Mała droga pamięć RAM | Tani RAM |
1-rdzień CPU | Wiele rdzeni |
1 maszyna | Chmury obliczeniowe |
Opóźnienia - sekundy | Opóźnienia - milisekundy |
Modemy | Gigabitowe łącza |
Tysiące użytkowników | Miliony użytkowników |
Programowanie
Znane wzorce i koncepty
- Relacyjne bazy danych - 1970 r.
- MVC (Model-View-Controller) - lata 70-te
- Model aktorowy - 1973 r.
- TCP - 1974 r.
- ...
- HTTP - 1997 r.
Aplikacje
Gry komputerowe
Procesowanie dokumentów, wniosków, aplikacji
Zarządzanie zasobami
Reagowanie na zdarzenia
Kilka przykładów domen
Sieci społecznościowe,
komunikatory
Internet of Things
Wiele aplikacji to aplikacje stanowe
HTTP to protokół bezstanowy
Problem?
Jak to obchodzimy?
Kilka popularnych "hacków"...
ORM
Caching
There are only two hard things in Computer Science: cache invalidation and naming things.
-- Phil Karlton
Jeden problem wciąż pozostaje
Separacja logiki od stanu aplikacji
Czy można inaczej?
Aktorzy
Aktorzy cd.
Aktorzy w aplikacjach stanowych
... i jak ma się do tego Domain Driven Design
Nie odtwarzamy agregatów z bazy danych
Pozwalamy im żyć w pamięci pod postacią aktorów
Baza danych służy za backup
Maszyny stanów skończonych
Do prostych problemów...
... i tych bardziej złożonych
Upraszczamy logikę poprzez zmianę zachowania
Inne zalety...
Modułowość
Komunikacja oparta o wiadomości
- Fire-and-forget
- RPC (request-response)
- Progressive response
- Long pooling
- Publish / Subscribe
- Streaming / data flows
Świat jest większy niż RPC
Microservices
Kompromisy
bo życie to sztuka wyboru
Łyżka nie istnieje...
baza danych przestaje pełnić rolę jedynego źródła prawdy
ACID no more
życie bez kwasu może okazać się nie do zniesienia
RPC
stare przyzwyczajenia ciężko umierają
Koniec
Stateful web applications
By Bartosz Sypytkowski
Stateful web applications
- 1,309