Sumo Logic ahead of the pack
Read articleComplete visibility for DevSecOps
Reduce downtime and move from reactive to proactive monitoring.
The Agile methodology is a set of techniques, values, and principles designed to guide and improve how software development teams work together to deliver new applications and updates. It values:
The traditional software delivery method is sometimes called the Waterfall method. The Waterfall method is so named because it represents a linear, step-wise approach to software delivery. Just like the water flowing through a Waterfall travels in one direction, the workflow of a Waterfall software development project flows from one step to the next, and each step must be completed before the next one can begin. The process flow for the traditional software delivery method can be described in eight steps:
In the Waterfall method, customers are involved only in the initial stage of development. Project leaders work with customers to capture their needs, then go off and build the entire product before returning to the customers at a later stage for user acceptance testing.
In contrast to the traditional Waterfall method, the Agile methodology takes an iterative and customer-focused approach to software development. Its goal is to deliver completed functional units of code as frequently as possible.
Development teams using the Agile methodology usually do not build apps with traditional monolithic architecture. Instead, projects are divided into function units of code known as features or microservices and the project schedule is divided into sprints where the goal of a sprint is to complete the entire delivery process for a single feature. In each sprint, developers will gather needs for that specific feature, design and code the feature, test it, get feedback from customers and test for errors before finalizing the code.
As a result, Agile development teams collect feedback from customers at many stages in the software development process and can better customize their design and coding decisions based on the needs of the customer. Customer feedback can be used to improve features that are in progress, iterate on features that have already been delivered and help determine which feature developers should build next.
To summarize, the difference between the Waterfall and Agile methodology is that Waterfall projects are plan-driven while Agile projects are customer-driven. Waterfall development can be effective for developers who prefer to work on a fixed-price agreement where requirements are established up-front and it makes sense to fully establish the scope of work before commencing the project.
Developing an Agile methodology can help reduce the risk of project failure. Collecting frequent feedback from customers helps ensure that new features are consistently meeting customer expectations for quality and value.
The original authors of the Agile Manifesto identified four values central to Agile Methodology. It is worth considering how each of these values is reflected in the Agile methodology today:
Individuals and interactions over processes and tools
This first value reflects an important belief that was shared by the founders of Agile: software problems are solved by teams of individuals interacting with each other, not by processes and tools. The Agile methodology encourages software developers to work in teams, program in pairs, meet daily and interact with each other on a regular basis as needs arise to solve problems.
Working software over comprehensive documentation
Founders of the Agile methodology were frustrated that the Waterfall method would require them to write hundreds of pages of technical documentation for applications that nobody would ever read. The Agile methodology does not discourage the documentation of code wholesale, but it does encourage development teams to minimize their wasted effort by only producing documentation that drives value, especially by writing tests for the system that document its behavior.
Customer collaboration over contract negotiation
The Waterfall method encouraged a contract negotiation model where software development firms would enter into fixed-price contracts with the entire scope of work negotiated upfront. Changes to the scope of work were discouraged, as they would require modifications to the original contract. Agile software delivery favors a "time and materials" or other non-fixed funding structure that helps align customer and developer incentives and promote quality.
Responding to change by following a plan
In the Waterfall delivery method, software developers delivered projects based on requirements and scope of work that was effectively set in stone at the outset of the project. There was little or no opportunity to collect feedback from customers throughout the design and code development process, so it was imperative to build applications according to the customer's exact requirements. In the Agile methodology, frequent customer feedback ultimately drives user satisfaction by ensuring that development teams are delivering work that meets user needs, even as they change.
More and more software development teams are relying on cloud-based environments to support product testing and deliver their applications to customers. Sumo Logic's cloud-native analytics platform can help software developers monitor the operational performance of applications deployed in the cloud while protecting development platforms, infrastructure, and sensitive data against malicious cyber attacks.
Reduce downtime and move from reactive to proactive monitoring.