SDLC - model zwinny

Zwinny model SDLC to połączenie iteracyjnych i przyrostowych modeli procesów z naciskiem na zdolność adaptacji procesu i satysfakcję klienta dzięki szybkiej dostawie działającego oprogramowania. Metody Agile dzielą produkt na małe przyrostowe kompilacje. Te kompilacje są dostarczane w iteracjach. Każda iteracja trwa zwykle od około jednego do trzech tygodni. Każda iteracja obejmuje międzyfunkcyjne zespoły pracujące jednocześnie w różnych obszarach, takich jak -

  • Planning
  • Analiza wymagań
  • Design
  • Coding
  • Testowanie jednostkowe i
  • Testy akceptacyjne.

Pod koniec iteracji działający produkt jest wyświetlany klientowi i ważnym interesariuszom.

Co to jest Agile?

Model Agile zakłada, że ​​każdy projekt musi być traktowany inaczej, a istniejące metody muszą być dostosowane tak, aby jak najlepiej odpowiadały wymaganiom projektu. W Agile zadania są podzielone na przedziały czasowe (małe ramy czasowe), aby zapewnić określone funkcje dla wydania.

Przyjmowane jest podejście iteracyjne, a kompilacja oprogramowania roboczego jest dostarczana po każdej iteracji. Każda kompilacja jest przyrostowa pod względem funkcji; ostateczna wersja zawiera wszystkie funkcje wymagane przez klienta.

Oto graficzna ilustracja modelu Agile -

Proces myślowy Agile rozpoczął się na wczesnym etapie rozwoju oprogramowania i z czasem stał się popularny ze względu na jego elastyczność i możliwość adaptacji.

Najpopularniejsze metody Agile to Rational Unified Process (1994), Scrum (1995), Crystal Clear, Extreme Programming (1996), Adaptive Software Development, Feature Driven Development i Dynamic Systems Development Method (DSDM) (1995). Są one teraz łącznie określane jakoAgile Methodologies, po opublikowaniu Manifestu Agile w 2001 roku.

Oto zasady Manifestu Agile -

  • Individuals and interactions - W rozwoju Agile ważna jest samoorganizacja i motywacja, podobnie jak interakcje, takie jak kolokacja i programowanie w parach.

  • Working software - Działające oprogramowanie demonstracyjne jest uważane za najlepszy sposób komunikacji z klientami w celu zrozumienia ich wymagań, a nie tylko polegania na dokumentacji.

  • Customer collaboration - Ponieważ wymagań nie można zebrać w całości na początku projektu z powodu różnych czynników, ciągła interakcja z klientem jest bardzo ważna, aby uzyskać odpowiednie wymagania dotyczące produktu.

  • Responding to change - Agile Development jest nastawiony na szybkie reagowanie na zmiany i ciągły rozwój.

Zwinne i tradycyjne modele SDLC

Agile jest oparty na adaptive software development methodspodczas gdy tradycyjne modele SDLC, takie jak model kaskadowy, są oparte na podejściu predykcyjnym. Zespoły predykcyjne w tradycyjnych modelach SDLC zwykle pracują nad szczegółowym planowaniem i mają pełną prognozę dokładnych zadań i funkcji, które mają być dostarczone w ciągu najbliższych kilku miesięcy lub w trakcie cyklu życia produktu.

Metody predykcyjne całkowicie zależą od requirement analysis and planningzrobione na początku cyklu. Wszelkie zmiany, które mają zostać wprowadzone, przechodzą przez ścisłą kontrolę zmian i ustalanie priorytetów.

Agile używa adaptive approachgdzie nie ma szczegółowego planowania i istnieje jasność co do przyszłych zadań tylko w odniesieniu do tego, jakie funkcje należy opracować. Istnieje rozwój oparty na funkcjach, a zespół dynamicznie dostosowuje się do zmieniających się wymagań produktu. Produkt jest bardzo często testowany w kolejnych wersjach, co minimalizuje ryzyko poważnych awarii w przyszłości.

Customer Interactionjest podstawą tej metodologii Agile, a otwarta komunikacja z minimalną dokumentacją to typowe cechy środowiska programistycznego Agile. Zespoły zwinne ściśle ze sobą współpracują i najczęściej znajdują się w tym samym położeniu geograficznym.

Model Agile - wady i zalety

Metody zwinne są ostatnio szeroko akceptowane w świecie oprogramowania. Jednak ta metoda może nie zawsze być odpowiednia dla wszystkich produktów. Oto kilka zalet i wad modelu Agile.

Zalety modelu Agile są następujące -

  • To bardzo realistyczne podejście do tworzenia oprogramowania.

  • Promuje pracę zespołową i trening krzyżowy.

  • Funkcjonalność można szybko rozwinąć i zademonstrować.

  • Wymagania dotyczące zasobów są minimalne.

  • Nadaje się do stałych lub zmiennych wymagań

  • Dostarcza wczesne rozwiązania do częściowej pracy.

  • Dobry model dla środowisk, które stale się zmieniają.

  • Minimalne zasady, łatwa dokumentacja.

  • Umożliwia jednoczesny rozwój i dostarczanie w ramach ogólnego zaplanowanego kontekstu.

  • Planowanie jest niewielkie lub nie jest wymagane.

  • Łatwe w zarządzaniu.

  • Daje elastyczność programistom.

Wady modelu Agile są następujące -

  • Nie nadaje się do obsługi złożonych zależności.

  • Większe ryzyko trwałości, łatwości konserwacji i rozszerzalności.

  • Ogólny plan, zwinny lider i zwinna praktyka PM to konieczność, bez której to nie zadziała.

  • Ścisłe zarządzanie dostawami określa zakres, funkcjonalność, która ma być dostarczona, i dostosowania w celu dotrzymania terminów.

  • W dużym stopniu zależy od interakcji z klientem, więc jeśli klient nie jest jasny, zespół może pójść w złym kierunku.

  • Istnieje bardzo duża zależność indywidualna, ponieważ generowana jest minimalna dokumentacja.

  • Transfer technologii do nowych członków zespołu może być sporym wyzwaniem ze względu na brak dokumentacji.