Book Image

Mastering Non-Functional Requirements

By : Sameer Paradkar
Book Image

Mastering Non-Functional Requirements

By: Sameer Paradkar

Overview of this book

Non-functional Requirements are key to any software/IT program and cannot be overlooked or ignored. This book provides a comprehensive approach to the analysis, architecture, and measurement of NFRs. It includes considerations for bespoke Java, .NET, and COTS applications that are applicable to IT applications/systems in different domains. The book outlines the methodology for capturing the NFRs and also describes a framework that can be leveraged by analysts and architects for tackling NFRs for various engagements. This book starts off by explaining the various KPIs, taxonomies, and methods for identifying NFRs. Learn the design guidelines for architecting applications and systems relating to NFRs and design principles to achieve the desired outcome. We will then move on to various key tiers/layers and patterns pertaining to the business, database, and integrating tiers. After this, we will dive deep into the topics pertaining to techniques related to monitoring and measurement of NFRs, such as sizing, analytical modeling, and quality assurance. Lastly, we end the book by describing some pivotal NFRs and checklists for the software quality attributes related to the business, application, data, and infrastructure domains.
Table of Contents (14 chapters)

Chapter 5. Architectural Patterns and its Impact on NFRs

As a software architect or designer, you should be able to read, understand, and apply these models in the context of engagement requirements. One would able to determine if a particular pattern applies to the context in which you are architecting and whether the stated problem exists in your proposed system. You can then follow the pattern and apply it in your particular context.

This is not about a particular technology specification, such as Microsoft's .NET, Oracle's JEE, or a particular product set, such as the Oracle Application Server. This is a conceptual view of systems that we're interested in and how architectural components of the system are arranged. Where appropriate, we have described how a particular technology, platform, or product supports the general concepts. This includes the idea of the relative cost of different solutions since, as a software architect, you will almost certainly become involved in brainstorming...