Software Architecture

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 7
At a glance
Powered by AI
The key takeaways from the passage are that software architecture involves identifying major system components and their communications. Explicit architecture has advantages like stakeholder communication, system analysis, and large-scale reuse. Architectural design models can include things like shared data repositories, shared services, layered styles, object models, and pipeline/data-flow models.

The three organizational styles discussed for structuring a system are: 1) A shared data repository style, 2) A shared services and servers style, and 3) An abstract machine or layered style.

The two modular decomposition models covered are: 1) An object model where the system is decomposed into interacting object, and 2) A pipeline or data-flow model where the system is decomposed into functional modules which transform inputs to outputs.

SOFTWARE ARCHITECTURE The design process for identifying the sub-systems making up a system and the framework for

sub-system control and communication is architectural design. The output of this design process is a description of the software architecture. Architectural design Represents the link between specification and design processes. Often carried out in parallel with some specification activities. It involves identifying major system components and their communications. Advantages of explicit architecture Stakeholder communication. Architecture may be used as a focus of discussion by system stakeholders. System analysis. Means that analysis of whether the system can meet its non-functional requirements is possible. Large-scale reuse. The architecture may be reusable across a range of systems. System structuring Concerned with decomposing the system into interacting sub-systems. The architectural design is normally expressed as a block diagram presenting an overview of the system structure. More specific models showing how sub-systems share data are distributed and interface with each other may also be developed.

Packing robot control system Architectural design decisions Architectural design is a creative process so the process differs depending on the type of system being developed. However, a number of common decisions span all design processes. Is there a generic application architecture that can be used? How will the system be distributed? What architectural styles are appropriate? What approach will be used to structure the system? How will the system be decomposed into modules?

What control strategy should be used? How will the architectural design be evaluated? How should the architecture be documented? Systems in the same domain often have similar architectures that reflect domain concepts. Application product lines are built around core architecture with variants that satisfy particular customer requirements. Architectural models System organizational model - Reflects the basic strategy that is used to structure a system. Three organizational styles are widely used: 1. A shared data repository style - Sub-systems must exchange data. This may be done in two ways: a. Shared data is held in a central database or repository and may be accessed by all sub-systems; b. Each sub-system maintains its own database and passes data explicitly to other sub-systems. When large amounts of data are to be shared, the repository model of sharing is most commonly used.

2. A shared services and servers style - Distributed system model which shows how data and processing is distributed across a range of components. - Set of stand-alone servers which provide specific services such as printing, data management, etc. - Set of clients which call on these services. - Network which allows clients to access servers.

3. An abstract machine or layered style - Used to model the interfacing of sub-systems. - Organizes the system into a set of layers (or abstract machines) each of which provides a set of services.

Supports the incremental development of sub-systems in different layers. When a layer interface changes, only the adjacent layer is affected. However, often artificial to structure systems in this way.

Modular decomposition styles - Styles of decomposing sub-systems into modules. A sub-system is a system in its own right whose operation is independent of the services provided by other sub-systems. A module is a system component that provides services to other components but would not normally be considered as a separate system. Two modular decomposition models covered: An object model where the system is decomposed into interacting object;

A pipeline or data-flow model where the system is decomposed into functional modules which transform inputs to outputs.

Control styles - Are concerned with the control flow between sub-systems. Distinct from the system decomposition model. Centralized control - One sub-system has overall responsibility for control and starts and stops other sub-systems. Call-return model - Top-down subroutine model where control starts at the top of a subroutine hierarchy and moves downwards. Applicable to sequential systems.

Manager model - Applicable to concurrent systems. One system component controls the stopping, starting and coordination of other system processes. Can be implemented in sequential systems as a case statement.

Event-based control - Each sub-system can respond to externally generated events from other subsystems or the systems environment. Two principal event-driven models: Broadcast models. An event is broadcast to all sub-systems. Any sub-system which can handle the event may do so.

Interrupt-driven models. Used in real-time systems where interrupts are detected by an interrupt handler and passed to some other component for processing.

Domain-specific model - Architectural models that are specific to some application domain. Two types of domain-specific model Generic models which are abstractions from a number of real systems and which encapsulate the principal characteristics of these systems. Data processing applications - Data driven applications that process data in batches without explicit user intervention during the processing. Ex: Billing systems, Payroll systems.
Sys t em

Inp ut

Proces s

Ou tp ut Pri nt er

Database

Input-process-output model

Salary payment DFD Transaction processing applications - Data-centered applications that process user requests and update information in a system database. Ex: E-commerce systems, Reservation systems.
I/O pro cess in g Applica tion logic T ran saction manager Database

Transaction processing

ATM system organization

Web bro wser

Webse r ve r

Ap plication s erver

Database s erver

E-commerce system architecture Event processing systems - Applications where system actions depend on interpreting events from the systems environment. Ex: Word processors, Real-time systems.

Language processing systems - Applications where the users intentions are specified in a formal language that is processed and interpreted by the system. Ex: Compilers, Command interpreters.

Reference models which are more abstract, idealized model. Provide a means of information about that class of system and of comparing different architectures. Reference models are derived from a study of the application domain rather than from existing systems. It can be used as a basis for system implementation or to compare different systems. It acts as standard against which systems can be evaluated.

OSI model for communication layer

Reference model

You might also like