Na produkcji zdarzają się pożary, w zwinnej metodyce wytwarzania oprogramowania zmiany są na porządku dziennym. Ma się wrażenie, że pracujemy w ogromnym chaosie. Czasem ten chaos jest zły, ale kontrolowany chaos bywa dobry. Aby lepiej kontrolować mój chaos, zapoznałem się z materiałem: Boiling Frogs 2020 – Bart Szulc – Spokojnie, to tylko kontrolowany chaos.
W ramach rozwijania się oglądam i czytam różne materiały. Następnie wiedzę z nich umieszczam w Anki oraz w notatkach i uzupełniam własnymi przemyśleniami.
Notatka z materiału: Boiling Frogs 2020 – Bartek Szulc – Spokojnie, to tylko kontrolowany chaos
Zanotowałem z tego materiału:
- Inżynieria chaosu – zestaw praktyk wykonywania kontrolowanych eksperymentów na budowanym systemie w celu nabrania pewności, że tworzony system jest w stanie wytrzymać nietypowe sytuacje na produkcji.
- Prezentacja przedstawia system rozproszony składający się z wielu małych mikroserwisów.
- Za każdy mikroserwis odpowiada niewielu programistów (1-3), którzy go stworzyli. Odpowiadają oni za nie 24h na dobę.
- Techniki zwiększające przeżywalność serwisu, to np.
- Retry
- Cache
- Ustawiony timout
- Auto-scallling
- Circuit breakers
- Execution time limits
- Implementacja rozwiązań dla problemów działa, ale gdy różne problemy występują razem często przestaje działać, np.
- Feature flagi :
- Pozwalają cofnąć nową funkcjonalność bez re-deploy’a.
- Feature flagi trzeba skądś ściągnąć, co kosztuje. Można je wrzucić w cache, ale wtedy przełączenie feature flagi nie cofnie funkcjonalności w serwisie.
- Feature flagi :
- Cykl eksperymentowania w inżynierii chaosu:
- Steady state – stan metryk w normalnym stanie.
- Hipoteza – opis sytuacji, w której coś przestaje działać, ale system nadal jest w stanie Steady state.
- Eksperyment – sprawdzenie hipotezy i próba jej obalenia.
- Weryfikacja.
- Improve – wyciągnięcie wniosków, poprawienie oprogramowania, zapisanie eksperymentu, aby więcej już tego nie sprawdzać, jeżeli wszystko było ok. Można ten eksperyment zmienić w powtarzalny test i dołączyć do regularnych testów.
- 4 fazy w inżynierii chaosu
- Kreatywność – szukanie pomysłów na eksperymenty
- Zastanawianie się nad możliwymi problemami
- Lesson learned – wymiana wiedzy na temat:
- Przeszłych problemów i ich rozwiązania.
- Zrobionych eksperymentów i podjętych działaniach naprawczych.
- Szukanie stwierdzeń: nigdy nam się nie zepsuje X. Sprawdź to.
- Hamowanie się – szukanie realnych problemów, a nie takich problemów, których nasz system nie da rady w żaden sposób obsłużyć.
- Zbieranie:
- Potwierdzonych eksperymentów.
- Ekspertów.
- Narzędzi.
- Testów i skryptów generujących eksperyment.
- Rozwiązań problemów.
- Logów i miar.
- Nauka:
- Monitorowanie.
- Reagowanie.
- Analizowanie.
- Wyciąganie wniosków.
- Kreatywność – szukanie pomysłów na eksperymenty
- Szukaj nie tylko rozwiązania problemu, ale rozwiązania dla całej klasy problemów, do których należy zaistniały problem.
- Ciekawe sposoby robienia eksperymentów przez zespoły (i całą firmę):
- Przykłady:
- Game Day.
- War Games.
- Chaos Bash.
- Fire Drill.
- Takie gry pozwalają nauczyć się opanować stres, ponieważ w kontrolowanych warunkach pojawiają się awarie.
- Przykłady:
Wszystkie posty związane z notatkami z nauki:
- Wydajność – Jarek Pałka – Notatka z nauki
- Memento Memori – Konrad Kokosa – Notatka z nauki
- Architektura Modularnego Monolitu – Notatka z nauki
- Jak przetestować prawdziwy system – Notatka z nauki
- Rekonesans – Budowa biznesu – Notatka z nauki
- Be pragmatic be SOLID – Notatka z nauki
- Co może pójść nie tak – Notatka z nauki
- Podcast: Demo 28-dniowego wyzwania równoległego
- Podcast: Jakie podjąłem 28-dniowe wyzwania?
- Podcast: Jakie można podjąć 28-dniowe wyzwania?
- Podcast: Szablony 28-dniowego wyzwania
- Sagi, strumienie, reaktywność i inne buzzwordy – Notatka z nauki
- Podcast: Co dalej z 28-dniowym wyzwaniem?
- Podcast: Zakończenie serii o 28-dniowym wyzwaniu
- Języki ezoteryczne – Notatka z nauki
- Developerze zdevelopuj się sam – Notatka z nauki
- Jak działa dobra firma – Notatka z nauki
- Praca z kodem zastanym – Notatka z nauki
- Jak wytrenować Juniora – Notatka z nauki
- Engineering architecture – Notatka z nauki
- Jak zbudować skuteczny proces sprzedaży w firmie – Notatka z nauki
- Level-up your culture – Notatka z nauki
- Problem sprytnego programisty – Notatka z nauki
- Napraw swój zespół – Notatka z nauki
- Jak odzyskać kontrolę nad aplikacją? Logger – Notatka z nauki
- Nailing down bugs in distributed systems – Notatka z nauki
- Wybór architektury – Notatka z nauki
- Pair programming – sposób na lepszy kod i mocniejszy zespół – Notatka z nauki
- Continuous Delivery w projektach Open Source – Notatka z nauki
- Learning Software Development – Notatka z nauki
- Bezpieczne programowanie – Notatka z nauki
- Zero code systems – Notatka z nauki
- Jak znaleźć czas na jakość – Notatka z nauki
- Najlepszy menedżer w historii Polski – Notatka z nauki
- Refaktoryzacja w Świecie Biznesu – Notatka z nauki
- Pytania z Kosmosu. Kim jesteśmy, skąd się wzięliśmy i dokąd zmierzamy — de Grasse Tyson Neil, Trefil James
- Deweloper na detoksie – Notatka z nauki
- Clean Code – Notatka z nauki
- Przepis na DevOps – Notatka z nauki
- Effective software delivery – Notatka z nauki
- Zero Trust Theorem – Notatka z nauki
- Errors errors everywhere! – Notatka z nauki
- Budowanie efektywnych zespołów IT – Notatka z nauki
- Jak technologie zmienią nasze życie do roku 2020? – Notatka z nauki
- Głaskologia — Miłosz Brzeziński
- Innowacja – strategiczne podejście do pomysłów – Notatka z nauki
- Continuous Integration na przykładzie oprogramowania dla iOS – Notatka z nauki
- Product/market fit and beyond – Notatka z nauki
- 7 sprawdzonych metod zwiększania konwersji – Notatka z nauki
- Mistrz czystego kodu Kodeks postępowania profesjonalnych programistów — Robert C. Martin
- Mój pierwszy raz z… inwestorem – Notatka z nauki
- Koszty złej jakości oprogramowania – Notatka z nauki
- Start-up Od pomysłu do sukcesu — Łopusiewicz Adam
- Produktywność wg CodeTwo – Notatka z nauki
- Sztuczna inteligencja – Transhumanizm czy wojny robotów? – Notatka z nauki
- Start-up po polsku Jak założyć i rozwinąć dochodowy e-biznes
- Realizuj projekty oparte na pasji – Notatka z nauki
- Czy istnieje bezpieczny kod – Notatka z nauki
- Czego nie należy robić, aby osiągnąć sukces w innowacyjnym przedsięwzięciu? – Notatka z nauki
- Czy Blockchain zdecentralizuje wszystko – Notatka z nauki
- Lead generation i automatyzacja, czyli jak sprzedawać leżąc na plaży – Notatka z nauki
- Wykorzystanie machine learning i sztucznej inteligencji w Marketing Automation – Notatka z nauki
- 9 rzeczy których nauczyłem się robiąc startupy – Notatka z nauki
- 5 Najczęstszych błędów w Entity Framework Core – Notatka z nauki
- ADAS – Autonomiczne Auta – Notatka z nauki
- Inteligentne miasta – Notatka z nauki
- Największe wyzwania w rekrutacji programistów i jak sobie z nimi radzić? – Notatka z nauki
- Dobry programista to leniwy programista – automatyzacja Continuous Integration / Delivery – Notatka z nauki
- Od pomysłu do produktu – jak przejść tę drogę bez potknięć? – Notatka z nauki
- Jak zdefiniować produkt? – Notatka z nauki
- Jak e-marketing wielokanałowy działa w praktyce – Notatka z nauki
- Czy programiści podzielą los dinozaurów a program może napisać się sam?- Notatka z nauki
- 3G Capital – FUNDUSZ którego spółka notuje ponad 50 mld $ przychodów – Notatka z nauki
- Jak przeskoczyć przepaść stworzyć produkt technologiczny i na nim zarobić – Notatka z nauki
- Jak nie umrzeć przedwcześnie – Notatka z nauki
- Tiger Global Management – fundusz inwestujący w JEDNOROŻCE jak nikt dotąd – Notatka z nauki
- Object Oriented UX – Notatka z nauki
- Modelowanie Zwinnej organizacji – Notatka z nauki
- 7 Błędów Początkujących Podczas Pisania Testów Jednostkowych – Notatka z nauki
- TDD Test Driven Development i Testy jednostkowe – Notatka z nauki
- Testy integracyjne – Notatka z nauki
- Kurs SEO – Notatka z nauki
- Testy jednostkowe – Notatka z nauki
- Przykłady aplikacji w Power Apps – Notatka z nauki
- Kariera developera. Zostałem seniorem i co dalej? – Notatka z nauki
- Największe zagrożenia dla bezpieczeństwa w internecie – Notatka z nauki
- Jak zwiększyć wartość testów jednostkowych – Notatka z nauki
- W 30 minut na produkcję – Notatka z nauki
- How to Build a Startup Without Funding – Notatka z nauki
- Jak błędy poznawcze niszczą Twoją pracę – Notatka z nauki
- Zarządzanie i motywowanie rozproszonego zespołu – Notatka z nauki
- Be eco be rich be fast – Notatka z nauki
- (Un)productive partnerships – Notatka z nauki
- From developer to a robot – Notatka z nauki
- Kariera w/dzięki Open Source – Notatka z nauki
- Od czego zacząć robotyzacje procesów biznesowych w firmie by osiągnąć zamierzone cele? – Notatka z nauki
- Modern agile retrospectives – Notatka z nauki
- Mój pierwszy milion jak zarabiać na aplikacjach – Notatka z nauki
- Rozwój osobisty w informatyce – czyli jak być efektywnym – Notatka z nauki
- Co robi Scrum Master cały dzień – Notatka z nauki
Źródła
Obraz główny
Materiał Boiling Frogs 2020 – Bart Szulc – Spokojnie, to tylko kontrolowany chaos
- Boiling Frogs 2020 – Bart Szulc – Spokojnie, to tylko kontrolowany chaos
- https://pl.qaz.wiki/wiki/Chaos_engineering
Sorry, there was a YouTube error.