Jump to content

Draft:The Nexus framework in a Distributed Setup

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Viktoriya Kutsarova (talk | contribs) at 10:14, 5 June 2019. The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Nexus is based on the Scrum Framework and, similar to Scrum, it leverages the main points from the Agile Manifesto. Ken Schwaber, co-creator of Scrum, created The Nexus Framework. It was released by Scrum.org in 2015 along with a body of knowledge, the Nexus Guide. The framework was last updated in 2018.[1]

Nexus is a framework for developing and sustaining scaled product and software delivery initiatives.[2] The framework consists of roles, event, artifacts and the guidelines that connect them all. Approximately three to nine Scrum Teams work on a Single Backlog to build an Integrated Increment that meets a certain goal.[3]

Most products are too complex to be delivered by a single Scrum Team.[3] Products that combine hardware and software or ones that have extremely sensitive time-to-market often require efforts from coordinated teams. Companies that face such challenges need more than one Scrum Team working on a single product.[4] In those cases, integrating the work of multiple teams for every Scrum Sprint adds much more complexity because of the dependencies at scale.

The Nexus Framework helps to solve this by enabling organizations to plan, launch, scale, and manage larger product development initiatives (especially those that involve substantial software development) using Scrum.[2] Nexus helps by simplifying and managing the connection, communication and dependencies between the different Scrum Teams and thus, provides a transparent overview of how the teams interact and work together. Most important qualities for scaling in a uniform way, are transparency and communication. They are both enforced by Nexus. Using the framework, “scaling Scrum to larger, more complex products is still Scrum”.[3]

Nexus Agile software development framework overview displaying roles, events and artifacts


Purpose in a distributed setup

There are plenty of known challenges connected with Globally Distributed Software Engineering (GDSE). Most notable ones are communication, group awareness, knowledge management, coordination, collaboration[5] and many more. Various organizations have already adapted Scrum in a distributed setting.[6]

Scrum, though, has a limitation on the number of teams.[7] Having more than two Scrum teams, especially in a distributed environment, extremely increases the challenges of GDSE.

When multiple teams are involved, communicating the work that affects the other team is crucial.[8] Also, integrating and testing the deliverables in order to achieve an integrated product is extremely important. The Nexus framework can be used successfully in a distributed context in order to reach those goals. The fact that the framework stimulates transparency and communication between each of the team members is crucial when they are allocated in separate physical places and probably within multiple different time zones.[9] Nexus pays more attention to dependencies and communication between the different Scrum teams.[3] This is a key characteristic when having multiple teams in a distributed context.

Nexus Roles

In addition to the normal roles defined in Scrum, Nexus defines the Nexus Integration Team (NIT) which is responsible for ensuring that an Integrated Increment is produced every sprint. The individual Scrum teams perform the work and the NIT makes sure that the work done by different scrum teams can be integrated. The role of the NIT is therefore not to work directly on the product but rather facilitate cooperation between Scrum Teams as needed. The NIT itself consists of the following members.

Product Owner

Just like in normal Scrum the product owner is responsible for managing the backlog and is ultimately responsible for the product being created. In Nexus the product owner takes a step back from the individual Scrum teams and focus on ensuring that integration between teams can be achieved.

Scrum Master

The NIT Scrum Master is responsible for ensuring that Scrum and Nexus are properly implemented and should act as an enabler for other members. The NIT Scrum Master can be a Scrum Master for one or more of the other Scrum Teams. The Nexus Scrum Master should be in frequent contact with the other Scrum Masters in the Nexus and facilitate in solving any issues regarding cooperation between the teams.[3]

Other NIT members

Other NIT members bring in needed expertise in specific fields, such as Software Architecture or Continuous Integration. They can be members of Scrum teams, from other parts of the same organization or even contractors hired for a certain period. The makeup of the NIT should evolve with the needs of the Nexus and is not set in stone. In a distributed setting it is important that every location is represented in the NIT, this allows those representatives to efficiently relay issues or problems present at their location.[3]

Nexus Events

Most of the Nexus Events follow the structure defined by the Scrum Guide [10] : Sprint, Sprint Planning, Daily Scrum, Sprint Review and Sprint Retrospective. Nexus is aiming to make these events suitable for large scale project with teams that are both locally and globally distributed. According to the Nexus Guide [2], the events are the following: Refinement, Nexus Sprint Planning, Nexus Sprint Goal, Nexus Daily Scrum, Nexus Sprint Review and Nexus Sprint Retrospective. Each of these events is analyzed in the following paragraphs.


Refinement

Refinement of the Product Backlog (PB) has two main purposes: decide which task from PB each team will be going to tackle and point out dependencies between teams that need to be solved for the current Sprint.[2] One of the Refinement goals is to make sure the tasks of each Nexus team are sufficiently independent in order to avoid the misunderstanding created by the needs of coordination in both locally and globally distributed environments.

Sprint Planning

The Nexus Sprint Planning event starts with common meetings of representatives from each Scrum team. The Product Owner (PO) presents the Nexus Sprint Goal and is in charge of the task prioritization from the PB. Adjustments are made to the planning according to both the Nexus Sprint Goal and the other discovered team dependencies. The Sprint Planning continues on each Scrum team individually and when further dependencies are revealed, inter-team communication should be used to share them. In this way, this event tackles a very important part of locally and globally distributed software, minimizing communication issues.

Daily Scrum

Nexus Daily Scrum similar to Scrum Daily Meeting [10] servers the purpose of getting the current state inside each of the Scrum teams by focusing on the impact on the Integrated Increment. In this event, the work of the previous day is presented and if that was successfully integrated, followed by possible new dependencies and how to share them across the affected Scrum teams. The Nexus Sprint Backlog is updated after each daily meeting, serving the purpose of having daily coordination between teams, one of the most important aspects in large scale team both locally and globally distributed.

Sprint Review

Nexus Sprint Review is a meeting that takes place at the end of the Sprint, having the purpose of providing feedback from stakeholder on the integrated software resulted after fulfilling the Sprint Goal.[2] The result, a revised PB, helps to avoid long periods of misunderstanding.

Sprint Retrospective

The final presented event is the Nexus Sprint Retrospective which is split into three parts: inter-teams meeting to tackle and share issues resulted from the current Nexus Sprint Review, intra-team meeting to concretely address the issues tackled in the inter-team meeting and another inter-team meeting to synchronize the proposed actions from each team.[2] When looking from the large-scale distributed software perspective, the main points that should rise from this event are the amount of unfinished work according to the Sprint Planning, the technical debt generated by the current Sprint, the integration ratio of the newly added code and the deployment status of the newly incremented software.

Nexus Artifacts

The Nexus Guide defines the following artifacts: Product Backlog, Nexus Sprint Backlog, Nexus Goal, and Integrated Increment.[1]

Product Backlog

A single Product Backlog, which is managed by the Product Owner, is shared by all Scrum Teams. In order to improve the autonomy of the teams, dependencies between Product Backlog Items (PBIs) should be minimized, this allows the teams to pull PBIs without worrying about creating dependencies across Scrum Teams.[2]

Sprint Backlog

The PBIs that have potential integration issues or dependencies between Scrum Teams are contained in the Nexus Sprint Backlog. This is done to highlight possible issues and where there is a need for cross-team cooperation. This list should be monitored closely and updated daily.

An example of a Nexus Sprint Backlog

Nexus Goal

During the Nexus Sprint Planning event the Product Owner sets a goal for each sprint known as a Nexus Goal. Consequently each individual Scrum Teams sets their own Sprint goal based on the Nexus Goal.

Integrated Increment

Just like in normal Scrum an Increment to the product is created every sprint, to emphasize the fact that, in Nexus, the Increment is the integrated work of all the Scrum Teams the name Integrated Increment is used. It is the responsibility of the NIT to ensure that the individual Scrum Teams are able to increment their work during the sprint.


Transparency and Trust

It is important to maintain transparency throughout the teams in order to avoid miscommunication between team members and to keep the amount of technical debt known at all times [11]. Establishing rules to achieve transparency is especially important in a distributed setting where members of different teams do not have the opportunity to have random conversations at the coffee machine, for example [3].

Nexus is based on Scrum, which aims to increase transparency within a single team.[3] Nexus, however, takes this one step further and helps to improve transparency across all Scrum teams. While Nexus artifacts are meant for spreading knowledge across teams and resolve the problems, it is important to remember, that the Nexus Framework is as effective as the level of artifact transparency.[2] Insufficient information will result in flawed decisions, which will make teams difficult to lead.[3]

One of the measures for doing this in Nexus is switching members of the team according to the situation.[3] However, distributing a single team can be challenging.[12] In addition, switching team members will lessen the feeling of safety provided by the team. Therefore it is important to acknowledge the social aspects of teams.

Nexus uses Scrum values - Courage, Focus, Commitment, Respect, and Openness to combat these issues.[10] However, the values do not enforce themselves and it is a responsibility of the Scrum Master to introduce and remind them. This can be done by having a poster with the values on the wall or have each member name some actions which represented the aforementioned Scrum values.[3]

Challenges

Managing Technical Debt

Product Owner is the responsible person for choosing which is the most valuable work. Sometimes it can happen, that Product Owner might choose to push in new features, not realizing that ignoring technical debt is not beneficial in the long run.

To tackle this, guard rails [3] can be introduced which determine the percentage of the time, which should be spent on specific issues. For example, it can be defined, that 70% of the time must be spent on new features and 30% of the time on fixing old issues.[3] Therefore the product Backlog must contain all the issues and provide a transparent overview of existing bugs to be fixed and future features to be implemented.

Scaling Product Owner

When scaling Scrum, it is possible, that Product Owner will not be able to answer all the questions coming from different members of all the Scrum teams, regardless of the team location.[6] This results in long waiting times and is especially noticeable in distributed teams.

To alleviate the issue, each of the Scrum teams can choose a delegate who lessens the workload of the Product Owner.[3] The delegate would still retain the developer tasks, but delegating the Product Owner should take priority. However, there still needs to be only one Product Owner who takes critical decisions about the product. Hence, there should be no such things as “Subordinate Product Owner” and “Master Product Owner”.

Skill Development

Nexus provides great techniques to spread information about business logic, building the product and the status of the production. However, more information must be shared regarding practices and experiences.[3] If there is no opportunity for informal discussions during breaks, this information will not get shared across teams. This is especially true for distributed teams.

In order to share this information, different measures can be taken such as organizing hangouts, periodic presentation or discussion groups sharing successes and challenges between the teams. Often, these methods require leaders in specific skills (such as Python or Designing), roles (such as Scrum master) or business domains (such as customer service).

Comparison to Other Frameworks

In addition to Nexus, there exist other Distributed Scrum Frameworks, most notably Scaled agile framework (SAFe), Disciplined agile delivery, Large-Scale Scrum (LeSS) and Scrum of Scrums. Compared to other frameworks, Nexus is the newest [13], hence it is not as widely adopted as SAFe, for example.[14] A major difference is that Nexus acknowledges the difficulties of integration of work by different teams and is the only framework with a separate integration team. In addition, Nexus is not as business oriented as SAFe and Disciplined Agile Delivery. Compared to other frameworks, the number of teams supported also differs. While Nexus and Scrum of Scrums support up to 9 and 10 teams respectively, then other frameworks can support up to hundreds of people.

Framework Date of

Release

Product Owner

Control

Scale Sprint Length

for Teams

Used Team Level

Frameworks

Key Positives [14] Key Risks [14]
Nexus [15] 2015 Single Product Owners

with Delegates

Small

(3-9 teams)

Varies Scrum Puts a lot of attention

to integration and has a

separate integration team

Still growing and being adopted,

limited scalability

SAFe [12] 2011 Central & top-down on ideas,

but distributed in ownership

Large

(Enterprise)

Common Scrum / Kanban  / XP Offers a complete general

overview which is good for

large enterprises to start

with

Most enterprise aware, most

descriptive and most adopted

Disciplined Agile Delivery [16] 2012 Mixed, but usually central

(Chief Product Owner)

Med - Large Varies Scrum / Lean A lot of content, strong

in architecture, dev ops

and design

Oldest and more enterprise

aware, hybrid of various agile

principles (XP, Kanban, Scrum,

Lean)

LeSS (Huge) [17] 2013 Centralized priorities with

distributed coordination

Med - Large Common Scrum Good Product Owner

scaling, is not prescriptive

and offers only

"suggestions"

Very agile oriented, and has

many specialization layers, which

might be hard to sell in traditional

organizations

Scrum-of-Scrums [18] 2001 Distributed with light

coordination

Small

(5-10 teams)

Common Scrum Simple and relies

on standard Scrum

Limited and scaling and likely

not suitable for large scale

References

  1. ^ a b "Nexus Guide Change History". Scrum.org. Retrieved 2019-06-05.
  2. ^ a b c d e f g h "Online Nexus Guide-The Definitive Guide to Nexus: The Rules of the Game". Scrum.org. Retrieved 2019-05-21.
  3. ^ a b c d e f g h i j k l m n o Kurt Bittner; Patricia Kong; Eric Naiburg; Dave West (4 December 2017). The Nexus Framework for Scaling Scrum: Continuously Delivering an Integrated Product with Multiple Scrum Teams. Pearson Education. ISBN 978-0-13-468271-6.
  4. ^ "Nexus at a European Bank". valueglide.com. Retrieved 2019-06-05.
  5. ^ Jiménez, Miguel; Piattini, Mario; Vizcaíno, Aurora (2009). "Challenges and Improvements in Distributed Software Development: A Systematic Review". Advances in Software Engineering. 2009. Hindawi Limited: 1–14. doi:10.1155/2009/710971. ISSN 1687-8655.{{cite journal}}: CS1 maint: unflagged free DOI (link)
  6. ^ a b Paasivaara, Maria; Durasiewicz, Sandra; Lassenius, Casper (2009). Using Scrum in Distributed Agile Development: A Multiple Case Study. IEEE. doi:10.1109/icgse.2009.27. ISBN 978-0-7695-3710-8.
  7. ^ Ken Schwaber; Mike Beedle (2002). Agile Software Development with Scrum. Pearson Education International. ISBN 978-0-13-207489-6.
  8. ^ Gutwin, Carl; Penner, Reagan; Schneider, Kevin (2004). "Group awareness in distributed software development". Proceedings of the 2004 ACM conference on Computer supported cooperative work - CSCW '04. Chicago, Illinois, USA: ACM Press: 72. doi:10.1145/1031607.1031621. ISBN 9781581138108.
  9. ^ Phalnikar, Rashmi; Deshpande, V.S.; Joshi, S.D. (2009). "Applying Agile Principles for Distributed Software Development". (:unav). doi:10.1109/icacc.2009.93.
  10. ^ a b c "The Scrum Guide-The Definitive Guide to Scrum:The Rules of the Game" (PDF). Scrum.org. Retrieved 2019-05-21.
  11. ^ Hinds, Pamela J.; Bailey, Diane E. (2003). "Out of Sight, Out of Sync: Understanding Conflict in Distributed Teams". Organization Science. 14 (6). Institute for Operations Research and the Management Sciences (INFORMS): 615–632. doi:10.1287/orsc.14.6.615.24872. ISSN 1047-7039.
  12. ^ a b Richard Knaster; Dean Leffingwell (20 July 2018). SAFe 4.5 Distilled: Applying the Scaled Agile Framework for Lean Software and Systems Engineering. Pearson Education. ISBN 978-0-13-517127-1.
  13. ^ "Scaling Agile for Enterprises: A Comparison of SAFe Agile, Nexus, Disciplined Agile 2.0 (DAD), and Large Scale Scrum (LeSS)". Smartsheet. 2016-11-22. Retrieved 2019-06-03.
  14. ^ a b c "ASK Matrix". Agile Scaling. Retrieved 2019-06-05.
  15. ^ McFadyen, John (2017-10-05). "Scaling Scrum: Enterprise Scrum Compared with Other Leading..." Agile Centre. Retrieved 2019-06-03.
  16. ^ Ambler, Scott W., 1966- (2012). Disciplined agile delivery : a practitioner's guide to agile software delivery in the enterprise. IBM Press. ISBN 9780132810135. OCLC 794176281.{{cite book}}: CS1 maint: multiple names: authors list (link) CS1 maint: numeric names: authors list (link)
  17. ^ "Overview - Large Scale Scrum (LeSS)". less.works. Retrieved 2019-06-03.
  18. ^ "Scrum of Scrums". Agile Alliance. 2015-12-17. Retrieved 2019-06-05.