Use the "a" key to toggle between slideshow and single page with notes.
"Software architects are a confused lot." [blogger Pranshu Jain]
The selection of the upper-level layers may be affected by the choice of an architectural pattern or framework. Thus, it is important to define what these terms mean.
A pattern codifies specific knowledge collected from experience. Patterns provide examples of how good modeling solves real problems, whether you come up with the pattern yourself or you reuse someone else's.
Frameworks differ from Analysis and Design patterns in their scale and scope. Frameworks describe a skeletal solution to a particular problem that may lack many of the details, and that may be filled in by applying various Analysis and Design patterns.
A framework is a micro-architecture that provides an incomplete template for applications within a specific domain. Architectural frameworks provide the context in which the components run. They provide the infrastructure (plumbing, if you will) that allows the components to co-exist and perform in predictable ways. These frameworks may provide communication mechanisms, distribution mechanisms, error processing capabilities, transaction support, and so forth.
Frameworks may range in scope from persistence frameworks that describe the workings of a fairly complex but fragmentary part of an application to domain-specific frameworks that are intended to be customized (such as Peoplesoft, SanFransisco, Infinity, and SAP). For example, SAP is a framework for manufacturing and finance.
Design patterns are being collected and cataloged in a number of publications and media. You can use design patterns to solve issues in your design without "reinventing the wheel". You can also use design patterns to validate and verify your current approaches.
Using design patterns can lead to more maintainable systems and increased productivity. They provide excellent examples of good design heuristics and design vocabulary. In order to use design patterns effectively, you should become familiar with some common design patterns and the issues that they mitigate.
A design pattern is modeled in the UML as a parameterized collaboration. Thus it has a structural aspect and a behavioral aspect. The structural part is the classes whose instances implement the pattern, and their relationships (the static view). The behavioral aspect describes how the instance collaborate -- usually by sending messages to one another -- to implement the pattern (the dynamic view). A parameterized collaboration is a template for a collaboration.The Template Parameters are used to adapt the collaboration for a specific usage.These parameters may be bound to different sets of abstractions, depending on how they are applied in the design.
Architectural Analysis is where you consider architectural patterns, as this choice affects the high-level organization of your object model.
Model-View-Controller: The MVC pattern is where an application is divided into three partitions: The Model, which is the business rules and underlying data, the View, which is how information is displayed to the user, and the Controllers, which process the user input.
Layers: The layers pattern is where an application is decomposed into different levels of abstraction. The layers range from application-specific layers at the top to implementation/technology-specific layers on the bottom.
Pipes and Filters: In the Pipes and Filters pattern, data is processed in streams that flow through pipes from filter to filter. Each filter is a processing step.
Blackboard: The Blackboard pattern is where independent specialized applications collaborate to derive a solution, working on a common data structure.
Architectural patterns can work together. (That is, more than one architectural pattern can be present in any one software architecture.)
The architectural patterns listed above imply certain system characteristics, performance characteristics, and process and distribution architectures. Each solves certain problems but also poses unique challenges.
|
Multiple views and multiple controllers may be supported.
Context: A large system that requires decomposition.
Problem: A system that must handle issues at different levels of abstraction; for example: hardware control issues, common services issues, and domain-specific issues. It would be extremely undesirable to write vertical components that handle issues at all levels. The same issue would have to be handled (possibly inconsistently) multiple times in different components.
Forces:
Layers are called tiers if they are implemented by physically separate libraries or hosts.
Layering represents an ordered grouping of functionality, with the application-specific functions located in the upper layers, functionality that spans application domains in the middle layers, and functionality specific to the deployment environment at the lower layers.
The number and composition of layers is dependent upon the complexity of both the problem domain and the solution space:
Specific functionality | Application-specific | Makes the application distinct |
Business-specific | Re-usable systems specific to the type of business | |
Middleware | Platform-independent services, distribution | |
General functionality | System Software | Infrastructure: OS, DB, HW interfaces |
This slide shows a sample architecture with four layers:
See http://msdn.microsoft.com/en-us/library/ms978706.aspx for complete MSDN description, including interaction diagrams.
|