What is Scrum Software Development? How It Works, Best Practices & More
Mục lục bài viết
What is Scrum? How Does Rugby Help Software Developers Create Quality Products?
Wondering how Rugby relates to Scrum? In this post, we’ll examine the Scrum development framework, its benefits and disadvantages, and some best practices for Scrum software development. When you’re ready to manage your development process with Scrum methodology, check out this post for our analysis of 15 Scrum boards you can use to manage your workflow.
Definition of Scrum
Scrum is a software product development strategy that organizes software developers as a team to reach a common goal — creating a ready-for-market product. It is a widely used subset of agile software development.
The word scrum also is used in rugby to define a play where players struggle against each to gain possession of the ball. The goal of a scrum in software development is to perform at a high-performing level like a rugby team does in a scrum.
How Scrum Works
In a rugby scrum, all the players literally put their heads together. When it comes to software development, a scrum can be characterized by developers putting their heads together to address complex problems.
- Scrum software development starts with a wish list of features — a.k.a. a product backlog. The team meets to discuss:
- The backlog.
- What still needs to be completed.
- How long it will take.
- Scrum relies on an agile software development concept called sprints:
- Sprints are periods of time when software development is actually done.
- A sprint usually lasts from one week to one month to complete an item from the backlog.
- The goal of each sprint is to create a saleable product.
- Each sprint ends with a sprint review.
- Then the team chooses another piece of backlog to develop — which starts a new sprint.
- Sprints continue until the project deadline or the project budget is spent.
- In daily scrums, teams meet to discuss their progress since the previous meeting and make plans for that day.
- The meetings should be brief — no longer than 15 minutes.
- Each team member needs to be present and prepared.
- The ScrumMaster keeps the team focused on the goal.
Image via Wikimedia Commons
Who is in the Scrum?
In rugby, the forwards are involved in the scrum. In software development, three roles are defined in the scrum framework:
- The scrum team does the work. It is the individuals who are working together in the sprints to produce the products.
- The scrum master is part of the scrum team makes sure the team works in compliance with the scrum rules. This is not a manager.
- The product owner represents the customer. This role prioritizes the backlog and coordinates the scrum teamwork. The product owner is a role similar to project manager in more traditional project management frameworks.
Benefits of Scrum
Rugby players try to gain control of the ball in the scrum and move it downfield. Software developers use scrum to move their projects quickly. And the benefits trickle down to software developers:
- Developers who want the freedom to make decisions thrive in scrum teams. Team morale tends to be high.
- Each sprint produces a product that is ready for market even though the project is ongoing. The highest priority requirements are addressed first so a high-quality, low-risk product can be on the market.
- The incremental process shortens the time to market by about 30 percent to 40 percent. Because the product owner is part of the scrum team, requirements can be delivered as they are needed.
- Scrum projects often realize a higher return on investment (ROI). This is attributed to:
- Decreased time to market.
- Early and regular feedback that prompts course corrections early when they are less costly.
- Defects that are fewer and less costly.
- Projects failing early and quickly when it’s less costly.
- Reviewing each sprint before the team moves on to the next sprint spreads testing throughout development.
- Project focus and goals can change with evolving business goals.
Disadvantages of Scrum
While a rugby scrum may get rough and bloody, software developers shouldn’t have to worry about that. Nonetheless, scrum is not for all developer teams or software development projects. There are disadvantages to implementing scrum projects:
- There is a danger of scope creep if stakeholders keep adding functionality to the backlog. This could be encouraged by the fixed deadline.
- Scrum works best with small teams of experienced software developers. They need to be able to work quickly.
- Scrum teams do not work well when the scrum master micromanages their work.
- Losing any team members can hurt the progress of the project.
Scrum Best Practices
Teamwork wins rugby games and helps software developers create quality products. To get the best quality out of scrum:
- Define requirements just in time to keep product features as relevant as possible.
- Test and incorporate product owner feedback daily.
- Sprint reviews with stakeholders need to be regular.
- The scrum team needs to use the sprint retrospectives to improve how they work.
- Conduct face-to-face conversations to reduce miscommunications.
- Trust the teams to do the best job possible.
- Allow the teams to self-organize around people’s skills, work styles and personalities.
- Don’t burn out the team members. Respect the balance between their personal and professional lives to ease stress.
Additional Scrum Tutorials and Resources
Instead of joining a local rugby league, check out the following agile framework resources and resources dedicated to the Scrum framework: