Architectural Patterns

Similar documents
Architectural Patterns. Architectural Patterns. Layers: Pattern. Architectural Pattern Examples. Layer 3. Component 3.1. Layer 2

Architectural Patterns

Design Patterns. Architectural Patterns. Contents of a Design Pattern. Dr. James A. Bednar. Dr. David Robertson

Software Architecture, Process and Management Architectural Patterns

Patterns in Software Engineering

Architectural Patterns: From Mud to Structure

Architectural Patterns. Pascal Molli (a System of patterns Buschman et al)

CAS 703 Software Design

Presentation-Abstraction-Control (PAC) Pattern. PAC Introduction

5/9/2014. Recall the design process. Lecture 1. Establishing the overall structureof a software system. Topics covered

Creational. Structural

Architectural Design

WHO WANTS TO BE A DESILLIONAIRE GAME RULES INTERNATIONAL TEAM OF EXPERTS MAIN IDEA INTERACTIVE SYSTEMS SOFTWARE ARCHITECTURAL STYLES

An Introduction to Software Architecture

Chapter 13: Architecture Patterns

An Introduction to Software Architecture

Patterns Architectural Styles Archetypes

Objectives. Architectural Design. Software architecture. Topics covered. Architectural design. Advantages of explicit architecture

An Introduction to Software Architecture. David Garlan & Mary Shaw 94

Software Architecture Patterns

Software Architecture

Architectural Design

Architectural Styles I

Architectural Styles II

Chapter 6 Architectural Design. Lecture 1. Chapter 6 Architectural design

Architectural Styles I

DISTRIBUTED COMPUTER SYSTEMS ARCHITECTURES

02 - Distributed Systems

02 - Distributed Systems

Lectures 24 and 25 Introduction to Architectural Styles and Design Patterns

In this Lecture you will Learn: System Design. System Architecture. System Architecture

CAS 703 Software Design

ADVANCED SOFTWARE DESIGN LECTURE 4 SOFTWARE ARCHITECTURE

Lecture 1. Chapter 6 Architectural design

Software Architecture in Practice

Universal Communication Component on Symbian Series60 Platform

Engr. M. Fahad Khan Lecturer Software Engineering Department University Of Engineering & Technology Taxila

Chapter 6 Architectural Design. Chapter 6 Architectural design

Establishing the overall structure of a software system

Architectural Design. Topics covered. Architectural Design. Software architecture. Recall the design process

Architectural Styles. Reid Holmes

Lecture 19: Introduction to Design Patterns

Survey of Architectural Styles

Architectural Design. Architectural Design. Software Architecture. Architectural Models

AOSA - Betriebssystemkomponenten und der Aspektmoderatoransatz

Architectural Styles. Software Architecture Lecture 5. Copyright Richard N. Taylor, Nenad Medvidovic, and Eric M. Dashofy. All rights reserved.

On the Structure of a Software Product-Line for Mobile Software

Broker Pattern. Teemu Koponen

Architectural Design

Enterprise Integration Patterns: Designing, Building, and Deploying Messaging Solutions

Software Architecture

DS 2009: middleware. David Evans

An Introduction to Software Architecture By David Garlan & Mary Shaw 94

Two Phase Commit Protocol. Distributed Systems. Remote Procedure Calls (RPC) Network & Distributed Operating Systems. Network OS.

Software Engineering

Distributed Objects and Remote Invocation. Programming Models for Distributed Applications

Software Architecture

Mining Relationships Between the Participants of Architectural Patterns

Announcements. me your survey: See the Announcements page. Today. Reading. Take a break around 10:15am. Ack: Some figures are from Coulouris

Patterns for Decoupling

1.264 Lecture 16. Legacy Middleware

Blackboard MVC Reflection. Lecture 8

Introduction to Software Engineering 10. Software Architecture

Software Architecture

Lecture 1: January 22

Client Server & Distributed System. A Basic Introduction

Chapter 4 Communication

Addressed Issue. P2P What are we looking at? What is Peer-to-Peer? What can databases do for P2P? What can databases do for P2P?

ICS 52: Introduction to Software Engineering

Communication Paradigms

Architectural Styles: Definitions

Initial contents proposal. List of topics. Common Architectural Styles. Architectural Styles. A sample from Elements of Software Architecture

EI 338: Computer Systems Engineering (Operating Systems & Computer Architecture)

Gustavo Alonso, ETH Zürich. Web services: Concepts, Architectures and Applications - Chapter 1 2

CSCI 3130 Software Architectures 1/3. February 5, 2013

Lecture 06: Distributed Object

Software Architecture

Software Architectures. Lecture 3

Concepts of Distributed Systems 2006/2007

The Impact of SOA Policy-Based Computing on C2 Interoperation and Computing. R. Paul, W. T. Tsai, Jay Bayne

Simple Object Access Protocol (SOAP) Reference: 1. Web Services, Gustavo Alonso et. al., Springer

Architectural Patterns

THE IMPACT OF E-COMMERCE ON DEVELOPING A COURSE IN OPERATING SYSTEMS: AN INTERPRETIVE STUDY

What is the fundamental purpose of a communication system? Discuss the communication model s elements.

CS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring Lecture 22: Remote Procedure Call (RPC)

Improving the Data Warehouse Architecture Using Design Patterns

Basic Properties of Styles

Lecture 1: January 23

Application Servers in E-Commerce Applications

Chapter 1: Distributed Information Systems

OS structure. Process management. Major OS components. CSE 451: Operating Systems Spring Module 3 Operating System Components and Structure

An Introduction to Software Architecture By David Garlan & Mary Shaw 94

Context-Awareness and Adaptation in Distributed Event-Based Systems

Transformation-free Data Pipelines by combining the Power of Apache Kafka and the Flexibility of the ESB's

Today: Distributed Middleware. Middleware

Middleware. Adapted from Alonso, Casati, Kuno, Machiraju Web Services Springer 2004

Architectural Styles and Non- Functional Requirements

EPL 603 TOPICS IN SOFTWARE ENGINEERING. Lab 6: Design Patterns

Software Architecture. Lecture 4

Today CSCI Remote Method Invocation (RMI) Distributed Objects

Transcription:

Architectural Patterns Dr. James A. Bednar jbednar@inf.ed.ac.uk http://homepages.inf.ed.ac.uk/jbednar Dr. David Robertson dr@inf.ed.ac.uk http://www.inf.ed.ac.uk/ssp/members/dave.htm SAPM Spring 2012: Architecture 1

Architectural Patterns The fundamental problem to be solved with a large system is how to break it into chunks manageable for human programmers to understand, implement, and maintain. Large-scale patterns for this purpose are called architectural patterns. Architectural patterns are related to design patterns, but higher level and larger scale. For more details, see Buschmann et al. (1996), chapter 2 or http://en.wikipedia.org/wiki/ Architectural_pattern_(computer_ science) SAPM Spring 2012: Architecture 2

Architectural Pattern Examples High level decompositions: Layers Pipes and filters Blackboard Distributed systems: Multi-tier (e.g. 3-tier; covered in other courses) Broker Interactive systems: Model-view-controller Presentation-abstraction-control Adaptable/reusable systems: Microkernel SOA, Mashups, Cloud computing Scripted components SAPM Spring 2012: Architecture 3

Layers: Pattern Layer 3 Component 3.1 Layer 2 Component 2.1 Component 2.2 Layer 1 Component 1.1 Component 1.2 SAPM Spring 2012: Architecture 4

Layers: Problem System has different levels of abstraction Typical: Requests go down, notification goes back up It is possible to define stable interfaces between layers Want to be able to change or add layers over time SAPM Spring 2012: Architecture 5

Layers: Solution Start with the lowest level Build higher layers on top Same level of abstraction within a layer No component spreads over two layers Try to keep lower layers leaner Specify interfaces for each layer Try to handle errors at lowest layer possible SAPM Spring 2012: Architecture 6

Layers: Example (TCP/IP) FTP FTP TCP TCP IP IP Ethernet Ethernet physical connection SAPM Spring 2012: Architecture 7

Layers: Advantages Reuse of layers Standardization of tasks and interfaces Only local dependencies between layers Programmers and users can ignore other layers Different programming teams can handle each layer SAPM Spring 2012: Architecture 8

Layers: Liabilities Cascades of changing behavior Lower efficiency of data transfer Difficult to choose granularity of layers Difficult to understand entire system SAPM Spring 2012: Architecture 9

Pipes and Filters: Pattern When processing a stream of data, each processing step is done by a filter and the filters are connected by pipes carrying data. Connecting filters in different combinations gives different ways of processing the data streams. SAPM Spring 2012: Architecture 10

Pipes and Filters: Problem Data stream processing which naturally subdivides into stages May want to recombine stages Non-adjacent stages don t share information May desire different stages to be on different processors Helpful: Standardized data structure between stages SAPM Spring 2012: Architecture 11

Pipes and Filters: Solution Filter may consume/deliver data incrementally Filters may be parameterisable (e.g. UNIX filters) Input from data source (e.g. a file) Output to a data sink Sequence of filters from source to sink gives a processing pipeline SAPM Spring 2012: Architecture 12

Pipes and Filters: Example Lexical analysis Symbol table Syntax analysis Semantics analysis Intermediate code generation SAPM Spring 2012: Architecture 13

Pipes and Filters: Advantages Pipes remove need for intermediate files Can replace filters easily Can achieve different effects by recombination (increases long-term usefulness) If data stream has a standard format, filters can be developed independently Incremental filters allow parallelization SAPM Spring 2012: Architecture 14

Pipes and Filters: Liabilities Difficult to share global data Parallelization is less useful than may seem Expensive if there are many small filters and a high data transfer cost Difficult to know what to do with errors (especially if filters are incremental) SAPM Spring 2012: Architecture 15

Blackboard: Pattern A central, blackboard data store is used to describe a partial solution to a problem. A variety of knowledge sources are available to work on parts of the problem and these may communicate only with the blackboard, reading the current partial solution or suggesting modifications to it via a control component. SAPM Spring 2012: Architecture 16

Blackboard: Problem Immature or poorly specified domain No deterministic or optimal solution known for problem Solutions to different parts of problem may require different representational paradigms May be no fixed strategy for combining contributions of different problem solvers May need to work with uncertain knowledge SAPM Spring 2012: Architecture 17

Blackboard: Solution Problem solvers work independently (and opportunistically) on parts of the problem Share a common data structure (the blackboard) A central controller manages access to the blackboard The blackboard may be structured (e.g. into levels of abstraction) so problem solvers may work at different levels Blackboard contains original input and/or partial solutions SAPM Spring 2012: Architecture 18

Blackboard: Example Phrase creation Word creation Segmentation Controller Phrase1...Phrase2... Blackboard Word1...Word2...Word3...Word4... S1...S2...S3...S4...S5...S6...S7...S8...S9... SAPM Spring 2012: Architecture 19

Blackboard: Advantages Allows problem solvers to be developed independently Easy (within limits) to experiment with different problem solvers and control heuristics System may (within limits) be tolerant to broken problem solvers, which result in incorrect partial solutions SAPM Spring 2012: Architecture 20

Blackboard: Liabilities Difficult to test Difficult to guarantee an optimum solution Control strategy often heuristic May be computationally expensive Parallelism possible but in practice we need much synchronization SAPM Spring 2012: Architecture 21

Broker: Pattern Decoupled components interact through remote service invocations. Communication is coordinated by a broker component which does things like forwarding requests and relaying results. SAPM Spring 2012: Architecture 22

Broker: Problem Large scale system where scaling to many components is an issue Components must be decoupled and distributed Services required for adding, removing, activating, locating components at run time Designers of individual components should not need to know about the others SAPM Spring 2012: Architecture 23

Broker: Solution Use brokers to mediate between clients and servers Clients send requests to a broker Brokers locate appropriate servers; forward requests; and relay results back to clients May have client-side and/or server-side proxies SAPM Spring 2012: Architecture 24

Broker: Example CORBA: Common Object Request Broker Architecture (e.g. JADE) OLE/DCOM/Active X Multi-agent systems are often coordinated through brokers such as JADE that provide a standard mechanism for relaying messages, based on a high-level communication protocol. Individual agents may be implemented in any language as long as they can input/output according to the protocol. SAPM Spring 2012: Architecture 25

Broker: Advantages Components can be developed independently Location transparency Components easily adapted Broker easily adapted SAPM Spring 2012: Architecture 26

Broker: Liabilities Low fault tolerance Limited efficiency (high communications cost) Difficult to test SAPM Spring 2012: Architecture 27

Model-View-Controller: Pattern Interactive system arranged around a model of the core functionality and data. View components present views of the model to the user. Controller components accept user input events and translate these to appropriate requests to views and/or model. A change propagation mechanism takes care of propagation of changes to the model. SAPM Spring 2012: Architecture 28

M-V-C: Problem Users care a lot about interfaces and demand changes often Different users ask for different changes The underlying GUI technologies also change rapidly You may want to support different look and feel standards You typically have important core code that can be separated from the interfaces SAPM Spring 2012: Architecture 29

M-V-C: Solution Develop a core model which is independent of style of input/output Define different views needed for parts/whole model Each view component retrieves data from the model and displays it Each view component has an associated controller component to handle events from users The model component notifies all appropriate view components whenever its data changes SAPM Spring 2012: Architecture 30

M-V-C: Example Spreadsheet Controller Labour: 60% Tory: 30% Lib.Dem: 10% Model Pie chart Bar chart Views SAPM Spring 2012: Architecture 31

M-V-C: Advantages Multiple views of the same model View synchronization View components can be plugged in Changes to interfaces without touching the model SAPM Spring 2012: Architecture 32

M-V-C: Liabilities Too complex for simple interface problems Frequent events may strain simple change propagation mechanisms Views and controllers aren t modular in practice Changing the model is expensive if there are many views SAPM Spring 2012: Architecture 33

Presentation-Abstraction-Control: Pattern A system implemented as a hierarchy of cooperating agents. Each agent is responsible for a specific aspect of functionality, and consists of: A presentation component responsible for its visible behaviour An abstraction component which maintains the data model for the agent A control component which determines the dynamics of agent operation and communication SAPM Spring 2012: Architecture 34

P-A-C: Problem Interactive system viewed as a set of cooperating agents, often developed independently Some agents specialize in HCI; others maintain data; others deal with error handling, etc. Some notion of levels of responsibility in the system Changes to individual agents should not affect the whole system SAPM Spring 2012: Architecture 35

P-A-C: Solution Define top-level agent with core functionality and data model, to coordinate the other agents and (possibly) also coordinate user interaction Define bottom-level agents for specific, primitive semantic concepts and/or services in the application domain Connect top and bottom levels via intermediate agents which supply data to groups of lower level agents For each agent separate core functionality from HCI SAPM Spring 2012: Architecture 36

P-A-C: Example Information system for political elections, with: Spreadsheet for entering data Various tables and charts for presenting current standings Users interact through graphical interface but different versions exist for different user needs Top-level agent holds data repository Different bottom-level agents for different types of charting, analysis and error handling Intermediate agent to coordinate views of system SAPM Spring 2012: Architecture 37

P-A-C: Advantages Separation of different concepts as individual agents that can be maintained separately Changes to presentation or abstraction in an agent doesn t affect other agents Easy to integrate/replace agents Suits multi-tasking Suits multi-user applications SAPM Spring 2012: Architecture 38

P-A-C: Liabilities Can have too many, too simple bottom-level agents Can be difficult to get control right while maintaining independence of agents Long chains of communication may be inefficient SAPM Spring 2012: Architecture 39

Microkernel: Pattern For systems which must be easily adaptable to changing requirements, separate minimal functional core from extended functionality and customer-specific parts. Provide sockets in the microkernel for plugging in these extensions and coordinating them. SAPM Spring 2012: Architecture 40

Microkernel: Problem Software systems with long life spans must evolve as their environment evolves Such systems must be adaptable to changes in existing platforms and must be portable to new platforms There may be a large number of different but similar platforms To conform with standards on different platforms it may be necessary to build emulators on top of the core functionality Thus the core should be small SAPM Spring 2012: Architecture 41

Microkernel: Solution Build a microkernel component which encapsulates all the fundamental services of your application The microkernel: Maintains system-wide resources (e.g. files) Enables other components to communicate Allows other components to access its functionality External servers implement their own view of the microkernel, using the mechanisms available from the microkernel Clients communicate with external servers using the communication facilities of the microkernel SAPM Spring 2012: Architecture 42

Microkernel: Example Operating system for desktop computers: Must be portable to relevant hardware platforms and adapt as these evolve. Must be able to run applications developed for other established operating systems e.g., users could choose which OS from a menu. Each of these OSs is built as an external server on top of the microkernel. SAPM Spring 2012: Architecture 43

Microkernel: Advantages Porting to a new environment normally doesn t need changes to external servers or clients Thus external servers or clients can be maintained independently of kernel Can extend by adding new external servers Can distribute the microkernel to several machines, increasing availability and fault tolerance SAPM Spring 2012: Architecture 44

Microkernel: Liabilities Performance overhead in having multiple views of system May be difficult to predict which basic mechanisms should be in the microkernel SAPM Spring 2012: Architecture 45

SOA, Mashups, Cloud computing Trends: further decentralization, web-based distributed systems, extending Broker, Multi-Tier patterns: Service-oriented architecture: Build application from disparate, loosely coupled set of independently provided services, typically with web interfaces Mashups: Rough, lightweight SOA, focusing on ability of end-users to reconfigure services on-the-fly to solve a specific problem or appeal to a particular audience Cloud computing: Use externally provided, geographically scattered, highly decoupled services for storage and computation (esp. via virtual machines), rather than purchasing and relying on specific physical infrastructure SAPM Spring 2012: Architecture 46

Summary Architectural patterns allow systems to be broken into chunks that can be developed (to some degree) and maintained independently These patterns support large-scale, long-term development and maintenance Not a recipe, just an approach New large-scale patterns continue to appear; Google SOA, Mashups, Cloud computing for more info Next lecture: Scripted components architectural pattern SAPM Spring 2012: Architecture 47

References Buschmann, F., Meunier, R., Rohnert, H., Sommerlad, P., & Stal, M. (1996). Pattern-Oriented Software Architecture: A System of Patterns. Hoboken, NJ: Wiley. SAPM Spring 2012: Architecture 47