1 / 39

Software Architecture: a Roadmap

Software Architecture: a Roadmap. David Garlan 2000 By: A. Rasoolzadegan. Abstract. During 1990-2000 Software Architecture Has received increasing attention as an Important subfield of software engineering

kevlyn
Download Presentation

Software Architecture: a Roadmap

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Software Architecture: a Roadmap David Garlan 2000 By: A. Rasoolzadegan

  2. Abstract • During 1990-2000 • Software Architecture • Has received increasing attention as an • Important subfield of software engineering • Developing the technological and methodological base for treating architectural design as an • Engineering Discipline • Purposes of this paper: • Examines some of the important trends of software architecture in research and practice • Speculate on the important emerging trends, challenges, and aspirations Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  3. Introduction • Architecture: • A critical issue in the design and construction of any complex software system • Gross organization of a complex software as a collection of interacting components • A good architecture ensure that a system will satisfy key requirements in: • Performance • Reliability • Portability • Scalability • Interoperability • … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  4. Introduction (Con.) • Progresses occurred during 1990-2000: • Software Architecture • has received increasing attention as an important subfield of software engineering • Practitioners: • Realize that • getting an architecture right is a critical success factor for system design and development • Leveraging past architectural designs in the development of new products • Numerous books, regular conferences and workshops, commercial tools, courses, major government and industrial research projects, … • Codification of Formal architectural standards and principles • … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  5. Introduction (Cont.) • Despite this progresses, as engineering disciplines go, the field of software architecture remains relatively immature • While the outline of an engineering basis for S.A. are becoming clear, there remain numerous challenges and unknowns • We can expect to see major new development in S.A. over the next decade both in research and practice Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  6. The Roles of S.A. • Architecture of a system describes its gross structure which illuminates: • The top level design decisions including things such as: • How the system is composed of interacting parts • Where are the main pathways of interactions • What are the key properties of the parts • An architectural description includes sufficient information to allow high-level analysis and critical evaluation Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  7. The Roles of S.A. (Cont.) • S.A typically plays a key role as a bridge between requirements and implementation Requirements Software Architecture Code Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  8. The Roles of S.A. (Cont.) • Architecture exposes certain properties of a system, while hiding others, by providing an abstract description of the system which provides: • An intellectually tractable guide to the overall system • Permits designers • To reason about the ability of a system to satisfy certain requirements • Suggests a blueprint for system construction and composition Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  9. The Roles of S.A. (Cont.) • Role of S.A. at software development: • Understanding • Reuse • Construction • Evolution • Analysis • Management Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  10. The Roles of S.A. (Cont.) - Understanding • S.A. simplifies our ability to comprehend large systems by • presenting them at a level of abstraction at which a system’s high level design can be easily understood • Architectural description exposes the high level constraints on system design Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  11. The Roles of S.A. (Cont.) - Reuse • Architectural design supports both • reuse of large components and • frameworks into which components can be integrated • Related existing works in this aspect • Domain specific software architecture • Reference frameworks • Architectural design patterns Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  12. The Roles of S.A. (Cont.) - Construction • An architectural description provides a partial blueprint for development by • Indicating the major components and dependencies between them • Example: • A layered view of an architecture typically • documents abstraction boundaries between parts of a system’s implementation • clearly identifying the major internal system interfaces • constraining what parts of a system may rely on services provided by other parts Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  13. The Roles of S.A. (Cont.) - Evolution • S.A. can expose the dimensions along which a system is expected to evolve • By making explicit the “load-bearing walls” of a system • system maintainers can better understand the ramifications of changes • thereby more accurately estimate costs of modifications Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  14. The Roles of S.A. (Cont.) - Evolution • Architectural descriptions separate concerns about the functionality of a components from the ways in which that components is connected to other components • Permits one to more easily change connection mechanisms to handle evolving concerns about • Performance, • Interoperability, • Prototyping, • Reuse. Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  15. The Roles of S.A. (Cont.) - Analysis • Architectural descriptions provide new opportunities for analysis including • System consistency checking • Conformance to constraints imposed by an architectural style • Conformance to quality attributes • … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  16. The Roles of S.A. (Cont.) - Management • Experiments has shown that successful projects view achievement of a viable software architecture as a key milestones in an industrial software development process • Critical evaluation of an architecture typically leads to a much clearer • Understanding of requirements • Implementation strategies • Potential risks Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  17. Yesterday • During 1990-2000 • Architecture was largely an ad hoc affair • Descriptions relied on informal box and line diagrams • Rarely maintained once a system was constructed • Architectural choices were made in idiosyncratic fashion • Typically by adapting some previous design • There was no way to check that a given system implementation faithfully represented its architectural design Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  18. Yesterday (Cont.) • Despite their informality, architectural description were central to system design • Recognize the need for a more disciplined and unified approach • Tool vendors began thinking about explicit support for architectural design • Language designers began to consider notations for architectural representation Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  19. Yesterday (Cont.) • Within industry two trends highlighted the importance of architecture • Recognition of a shared repertoire of methods, techniques, patterns and idioms for structuring complex software systems such as “pipeline”, “blackboard oriented design” or “client-server systems” • Exploiting commonalities in specific domains to provide reusable frameworks for product families • Low cost • Instantiating shared design Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  20. Today • The technological basis for architectural design has improved dramatically • Three of the important advancements have been • Development of architecture description languages and tools • Emergence of product line engineering and architectural standards • Codification and dissemination of architectural design expertise Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  21. TodayArchitecture Description Languages and Tools • The informality of most box and line depictions of architectural designs leads to a number of problems • The meaning of the design may not be clear • Informal diagrams can not be formally analyzed for • Consistency • Completeness • Correctness • … • There are few tools to help architectural designers with their tasks Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  22. TodayArchitecture Description Languages and Tools (Cont.) • Proposing formal notations for representing and analyzing architectural designs • Architectural Description Languages (ADLs) • ADLs typically provide tools for • Parsing • Displaying • Compiling • Analyzing • Simulating Architectural Descriptions Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  23. TodayArchitecture Description Languages and Tools (Cont.) • Recently there have been a number of proposal that attempt to show how the concepts founds in ADLs can be mapped directly into an object oriented notation like UML Requirements B A C Architecture In an ADL Architecture In UML D Code E Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  24. TodayProduct lines and Standards • Exploit commonality across multiple products • Create product lines within an organization • Emergence of cross-vendor integration standards Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  25. TodayProduct Lines (Cont.) • Must consider requirements • for a family of systems • relationship between those requirements • ones associated with each particular instance • We need a reusable architecture that can be instantiated for each product • Product line engineering is not yet widespread Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  26. TodayCross-vendor Integration Standards • Like product line approaches • require architectural frameworks • that permit a system developer to configure a wide variety of specific systems • by instantiating that framework • Typically provide the system glue • Integrate parts provided by multiple vendors • Such standards may be • Formal international standards sponsored by IEEE, ISO or … • Ad hoc and de facto standards promoted by an industrial leader Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  27. TodayCodification and Dissemination • One of improvements has occurred nowadays is the use of standard architectural styles • An architectural style typically specifies • a design vocabulary, • constraints on how that vocabulary is used, • semantic assumptions about that vocabulary • such as • pipe and filter style, • blackboard architectures, • client-server architecture, • event-based architecture, • object-based architectures • Each style is appropriate for certain purposes Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  28. Tomorrow • Although S.A. is on much more solid footing than a decade ago, it is not yet established as a discipline that is taught and practiced universally across the software industry • Reasons: • It takes time for new approaches and perceptions to propagate • Technological basis for architecture design is still immature Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  29. TomorrowChanging Build Versus Buy Balance • A critical issue in the development of systems has been the decision about • what parts of the system to obtain elsewhere • Advantages and disadvantages • Saving development time • Often incompletely satisfying the needs • Being less under control of the development organization • … • what parts to build in-house Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  30. TomorrowChanging Build Versus Buy Balance (Cont.) • Economic pressures to reduce time-to-market are drastically changing the build versus buy balance • For an increasing number of products, introducing a product a month early may be the difference between success and failure • In such situations building systems using software that others have written becomes the only feasible choice • Indeed, many companies are rapidly finding themselves more in the position of system integrators than software developers • This trend is evident in the rising popularity of “component-based” software development Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  31. TomorrowChanging Build Versus Buy Balance (Cont.) • Today’scomponent technologies work at a fairly low level of architectural abstraction • Essentially at the level of procedure call between objects • To obtain more significant integration will require higher level architectural standards • This is Likely to lead us from “component-based” engineering to “architecture-based” engineering • This trend is also leading toward standardization of notations and tools across vendors Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  32. TomorrowNetwork Centric Computing • There is a clear trend from a PC centric computational model to a network centric model • Reasons of this trend • Network centric computing • Provides a much broader base of services • Permits access to a rich set of computing and information retrieval services through portable computers that can be used almost anywhere • … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  33. TomorrowNetwork Centric Computing (Cont.) • For such systems a new set of software architecture changes emerges • First is the need for architectures that scale up to the size and variability of the Internet • Second is the need to support computing with dynamically formed, task specific, coalitions of distributed autonomous resources (e.g. Internet) • The need to handle dynamically evolving collections of components obtained from a variety of sources will require new techniques for managing architectural models at run time • … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  34. TomorrowPervasive Computing • The next related trend is toward pervasive computing in which the computing universe is populated by a rich variety of heterogeneous computing devises • Such as toasters, home heating systems, entertainment systems, smart carts, … Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  35. TomorrowPervasive Computing (Cont.) • Some of consequent challenges for S.A • Architectures for these systems will have to be more flexible than they are today • Devices are likely to come and go in an unpredictable fashion • Handling reconfiguration dynamically while guaranteeing uninterrupted processing is a hard problem • Need for architectures that will better handle user mobility • Provide much more automated control over the management of computational services Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  36. Conclusion • The field of S.A. has experienced considerable growth over the past decade • It promises to continue that growth for the foreseeable future • There are a number of significant challenges that will need to be solved before architectural design matures into an engineering discipline • Many of these challenges will be solved as a natural consequence of dissemination and maturation of the architectural practices and technology • Others arise because of the shifting landscape of computing and the needs for software • That will require significant new innovations Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  37. Reference • David Garlan, “Software Architecture: a Roadmap”, in The Future of Software Engineering, A. Finkekstein (Ed), ACM Press, 2000. Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  38. Related Papers • Architecture-driven Modelling and Analysis, David Garlan and Bradley Schmerl.  In Tony Cant editor, Proceedings of the 11th Australian Workshop on Safety Related Programmable Systems (SCS'06), Vol. 69 of Conferences in Research and Practice in Information Technology, Melbourne, Australia, 2006. • Architecture-based Simulation for Security and Performance, Bradley Schmerl, Shawn Butler and David Garlan. 2006. Submitted for publication. • Analyzing Architectural Styles, Jung Soo Kim and David Garlan.  2007. Submitted for Publication • Software Architecture-based Adaptation for Grid Computing, Shang-Wen Cheng, David Garlan, Bradley Schmerl, Peter Steenkiste, and Ningning Hu, The 11th IEEE Conference on High Performance Distributed Computing (HPDC’02), Edinburgh, Scotland, July 2002. • Understanding Tradeoffs among Different Architectural Modelling Approaches, Roshanak Roshandel, Bradley Schmerl, Nenad Medvidovic, David Garlan, and Dehua Zhang, Proceedings of the 4th Working IEEE/IFIP Conference on Software Architectures, Oslo, Norway, June 11-14, 2004. • Differencing and Merging of Architectural Views, Marwan Abi-Antoun, Jonathan Aldrich, Nagi Nahas, Bradley Schmerl, and David Garlan, Carnegie Mellon University Institute for Software Research International Technical Report CMU-ISRI-05-128, 2005. • ... Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

  39. Conclusion Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory,Large Scale Software Architecture Course, Dr. Abdollahzadeh

More Related