Kanban (development)


Kanban is a lean method to manage and improve work across human systems. This approach aims to manage work by balancing demands with available capacity, and by improving the handling of system-level bottlenecks.
Work items are visualized to give participants a view of progress and process, from start to finish—usually via a Kanban board. Work is pulled as capacity permits, rather than work being pushed into the process when requested.
In knowledge work and in software development, the aim is to provide a visual process management system which aids decision-making about what, when, and how much to produce. The underlying Kanban method originated in lean manufacturing, which was inspired by the Toyota Production System. Kanban is commonly used in software development in combination with other methods and frameworks such as Scrum.

Evolution and documentation of method

David Anderson's 2010 book, Kanban, describes an evolution of the approach from a 2004 project at Microsoft using a theory-of-constraints approach and incorporating a drum-buffer-rope, to a 2006–2007 project at Corbis in which the kanban method was identified. In 2009 Don Reinertsen published a book on second-generation lean product-development which describes the adoption of the kanban system and the use of data collection and an economic model for management decision-making. Another early contribution came from Corey Ladas, whose 2008 book Scrumban suggested that kanban could improve Scrum for software development. Ladas saw Scrumban as the transition from Scrum to Kanban. Jim Benson and Tonianne DeMaria Barry published Personal Kanban, applying Kanban to individuals and small teams, in 2011. In Kanban from the Inside, Mike Burrows explained kanban's principles, practices and underlying values and related them to earlier theories and models. In Agile Project Management with Kanban, Eric Brechner provides an overview of Kanban in practice at Microsoft and Xbox. Kanban Change Leadership, by Klaus Leopold and Siegfried Kaltenecker,
explained the method from the perspective of change management and provided guidance to change-initiatives. In 2016 Lean Kanban University Press published a condensed guide to the method, incorporating improvements and extensions from the early kanban projects.

Kanban boards

The diagram here shows a software development workflow on a Kanban board. Kanban boards, designed for the context in which they are used, vary considerably and may show work item types, columns delineating workflow activities, explicit policies, and swimlanes. The aim is to make the general workflow and the progress of individual items clear to participants and stakeholders.
As described in books on Kanban for software development, the two primary practices of Kanban are:
  1. Visualize your work
  2. Limit work in progress

    Four additional general practices of Kanban listed in Essential Kanban Condensed, are:

  3. Make policies explicit
  4. Manage flow
  5. Implement feedback loops
  6. Improve collaboratively, evolve experimentally
The Kanban board in the diagram above highlights the first three general practices of Kanban.
Kanban manages workflow directly on the Kanban board. The WIP limits for development steps provide development teams immediate feedback on common workflow issues.
For example on the Kanban board shown above, the "Deployment" step has a WIP limit of five and there are currently five epics shown in that step. No more work items can move into deployment until one or more epics complete that step. This prevents the "Deployment" step from being overwhelmed. Team members working on "Feature Acceptance" might get stuck because they can't deploy new epics. They can see why immediately on the board and help with the current epic deployments.
Once the five epics in the "Deployment" step are delivered, the two epics from the "Ready" sub-column of "Feature Acceptance" can be moved to the "Deployment" column. When those two epics are delivered, no other epics can be deployed. Now, team members working on deployment are stuck. They can see why immediately and help with feature acceptance.
This workflow control works similarly for every step. Problems are visual and evident immediately, and re-planning can be done continuously. The work management is made possible by limiting work in progress in a way team members can see and track at all times.