04_kanban

DevOps - Kanban

ParameterKursinformationen

Veranstaltung:

262062 DevOps

Semester

SEB4

Hochschule:

Hochschule Heilbronn

Inhalte:

Kanban

Startseite

Link auf den GitHub:

Autoren

@author

Ziele und Kompetenzen

  • Grundlegende Konzepte hinter Kanban kennen lernen

  • Unterschiede (Vor- und Nachteile) gegenĂĽber anderen agilen Ansätzen verstehen

  • Verstehen wann Kanban vorzugsweise eingesetzt werden kann

Kanban Ursprung

  • Jap. kan çś‹ (sichtbar) und ban ćťż (Karte o.d Brett)

  • Konzepte entstammen dem Toyota Production System (TSP)

  • Konkret: Just-in-Time Scheduling System

    • Nur »machen« was benötigt wird

    • Nur »machen« wenn es benötigt wird

    • Nur »machen« wieviel benötigt wird

Kanban System wurde sowohl fĂĽr die Produktion als die Software Entwicklung adaptiert.

{{1}}


Toyota Kanban

The kanban, a tool that describes which and how many parts are used where and when, made just-in-time production possible. The new kanban management system was adopted at all plants in 1963. By producing parts in accordance with the instructions on the kanban, parts are delivered among the different plants only in the volumes needed, and inventories within each process can be eliminated. As kanban came into widespread use, problems such as standardization of work and transport management were resolved one after another and production lines operated smoothly.


{{2}}


Drei Prinzipien

  • Visualize

  • Limit Work in Progress

  • Manage Flow


Das Kanban Board

Visualisierung

  • Information Fridge

    • Muss immer wieder geöffnet werden, um nachzuschauen ob „etwas Neues drin ist“

    • Klassische Ticket-Systeme, digitale Boards etc.

  • Information Radiator

    • GroĂźe sichtbare Displays

    • FĂĽr das eigene Team und alle Interessierten

    • Aktualisierungen möglichst einfach halten

    • So groĂź wie möglich!!!

    • »Use it or lose it!«

{{1}}


Beispielboard

Bildquelle: Rakuten Inc., https://commons.wikimedia.org/wiki/File:Lean_Kanban.jpg, CC BY-SA 3.0 (https://creativecommons.org/licenses/by-sa/3.0)


{{2}}


Kanban Board - Tipps

  • GroĂźe Boards verwenden (s. Information Radiator)

  • Digitale und physische Boards haben beide Vor- und Nachteile

  • Bei ungeĂĽbten Teams möglichst physische Boards nutzen

  • Regelmäßige Stand-Ups (Daily Stand-Up)

  • Den Workflow anpassen, das Board reflektiert den aktuellen Workflow im Team

  • Der Workflow kommt nicht vom Management, sondern vom Team

  • Nicht zu viele Gedanken machen, Ă„nderungen willkommen heiĂźen


{{3}}


Kanban Board - Beispielaufbau


{{4}}


Enter- & Exit-Kriterien


{{5}}


Priorisierung

  • Anders als in Scrum:

    • Priorisierung kann fortwährend erfolgen

    • Täglich, u.U. auch wöchentlich oder zwei-wöchentlich

  • Reihenfolge der Tickets am Board spiegelt die Priorität wieder

    • Es wird immer das am höchsten priorisierte Ticket gezogen

    • No-Go: Ticket ziehen, das einem am meisten SpaĂź macht


Work in Progress

  • Abk.: WiP

  • Beinhaltet alle begonnen aber noch nicht abgeschlossenen Aufgaben

    • Auch alle Aufgaben, an denen gerade nicht gearbeitet wird

    • Auch alle Aufgaben, fĂĽr die gerade auf Zuarbeit geartet wird

  • WiP-Limit

    • Anzahl an gerade in Bearbeitung befindlicher Aufgaben limitieren

    • Anzahl der Tickets

    • Typischerweise pro Spalte (in Bearbeitung, Test, Abnahme etc.)

{{1}}


Little's Law

  • Ursprung: John D.C. Little

    • In den 1950ern einfach angenommen

    • Erst Ende der 1960er bewiesen

  • Bedeutung: Je mehr gleichzeitig bearbeitet wird, desto länger dauert die Fertigstellung aller »Work Items«


{{2}}


Auswirkung von Parallelität


{{3}}


WiP-Limit


{{4}}


WiP-Limit Wisdoms

  • Es gibt keine »goldene Regel«

  • Beobachten und anpassen

  • Guter Ansatz: »Stop starting, start finishing «

  • Beispiel 1: Um Pairing zu forcieren kann ein WiP-Limit von $Teamgröße -1$ gewählt werden

  • Beispiel 2: Existieren z.B. externe Abhängigkeiten (=Wartezeiten) kann ein WiP-Limit von $Teamgröße \cdot 2$ gewählt werden um Wartezeiten (engl. idle time) zu vermeiden

  • Beispiel 3: …


{{5}}


Praxis Tipps

  • Durchsatz erhöhen

  • Verschwendung (jap. muda 無駄) z.B. durch Wartezeiten oder Blocker vermeiden

  • Probleme schnell lösen

  • Kanban ermöglicht häufig Priorisierung (signifikanter Unterschied zu Scrum)

  • Geeignet fĂĽr kleine und bekannte Arbeitseinheiten (z.B. im Ops-Umfeld)

  • Schlechter fĂĽr Entwicklung, da Aufgaben geschätzt werden mĂĽssen

  • WiP-Limits einhalten


Referenzen

Last updated