SlideShare a Scribd company logo
1 of 33
Agile Architecture
Software Architecture for Agile
Speaker: Raffaele Garofalo (raffaeu)
     http://blog.raffaeu.com
Agenda



Introduction              Software Architect         Agile Architecture
• Software architecture   • The role                 • Workflow
• Agile development       • Collocation with Agile   • Team structure
• Agile + Architecture                               • Sample
Introduction



  What is
                What is Agile   How they can
 Software
                Development     live together?
Architecture
Introduction



  What is
 Software
Architecture
Software Architecture


Software Architecture is a
terminology introduced some
years ago in the software
development community, which
identifies a specific science or art
of designing and delivery value.
“The art or science of designing and delivering valuable technology
                             strategies”

                                      Select
                    Engineering
                                   frameworks
                      design
                                   and products

                                               Bridges the
         Business                             gap between
         Models                               business and
                              What
                                               technology
                             does it
                             deliver?
Introduction



 What is Agile
 Development
Agile Development


 Agile software development is a group
 of software development methods
 based on iterative and incremental
 development, where requirements and
 solutions evolve through collaboration
 between self-organizing, cross-
 functional teams.
Agile is not only TDD.


     Agile     …
               Agile
     Kanban
              Modeling

     SCRUM      C.I.


      XP        TDD
SCRUM


                           2/4
                          weeks




PRODUCT    SPRINT    SPRINT       FEATURE(s)
BACKLOG   BACKLOG   BACKLOG
Introduction



               How they can
               live together?
Agile Architecture




               Software         Agile
Agile         Architecture   Architecture
                 (MDD)         (AMDD)
The Software Architect role




                The Software
The Software
               Architect in Agile   Golden Rules
  Architect
                 environment
The Software Architect role




The Software
  Architect
Software Architect


       Create architectural designs from
       a vision
       It looks at current and future
       design requirements
       Takes technical decisions such
       Platform and Frameworks based
       on his experience
The Software Architect role




          The Software
         Architect in Agile
           environment
Software Architect and Agile


        Provide information about frameworks
        and platforms
        Provide architectural knowledge during
        the modeling phase
        Interact with the business to
        communicate the changes and the
        features with the team
        Contribute to development and delivering
The Software Architect role




                    Golden
                     Rules
Golden rules of Agile
           Architect

 A Software Architect doesn’t have anything special, it is part of
 the team
 In Agile, every member of the team is an active part and so should
 be the Architect, an active part of a team
 Avoid Avory tower built during the design time without involving
 the developers in the design process. When everything is pre-
 designed and pre-decided, the frustration grows …
 A strict Software Architect will fit better in a big team/project
 because there will be more space for his ego than in a small team
 where every member should be able to do everything
Agile Architecture




           The Team    Sample Agile
Workflow
           structure   architecture
Agile Architecture




Workflow
Process Workflow


                                   Application
                                    overview


Identify Architecture
    OBJECTIVES          Key scenarios       Key Hot Spots



                                    Candidate
                                     Solution
Process Workflow


Iter: 0          Iter: n
Envision         Modeling
                Brainstorm
Estimates          TDD
Agile Architecture




     The Team
     structure
Team structure
Agile Architecture




               Sample Agile
               architecture
Sample process



     Let’s have a look at Visual
     Studio 2011 and a sample
     project created using SCRUM
     and Agile Architectures with
     the help of Typemock
Authentication Use case
Authentication components
Authentication User Interface
Q/A?




       Contacts
       • Blog: http://blog.raffaeu.com
       • Twitter: @raffaeu
Appendix A
Appendix B



   Security           Scalability   Availability




Interoperability      Testability    Usability

More Related Content

What's hot

Enterprise Architecture Management (EAM) I Best Practices I NuggetHub
Enterprise Architecture Management (EAM) I Best Practices I NuggetHubEnterprise Architecture Management (EAM) I Best Practices I NuggetHub
Enterprise Architecture Management (EAM) I Best Practices I NuggetHubRichardNowack
 
A Summary of TOGAF's Architecture Capability Framework
A Summary of TOGAF's Architecture Capability FrameworkA Summary of TOGAF's Architecture Capability Framework
A Summary of TOGAF's Architecture Capability FrameworkPaul Sullivan
 
Architecture solution architecture method
Architecture solution architecture methodArchitecture solution architecture method
Architecture solution architecture methodChris Eaton
 
BIM Execution Plan - Bim Process Model Rview and Procedure
BIM Execution Plan - Bim Process Model Rview and ProcedureBIM Execution Plan - Bim Process Model Rview and Procedure
BIM Execution Plan - Bim Process Model Rview and Procedureanhc5l77 actp84nya
 
BIM Presentation
BIM PresentationBIM Presentation
BIM PresentationOmer Syed
 
Technical Architecture
Technical ArchitectureTechnical Architecture
Technical Architecturescmiyer
 
NEXT generation enterprise applications
NEXT generation enterprise applicationsNEXT generation enterprise applications
NEXT generation enterprise applicationsDr. Jimmy Schwarzkopf
 
Solution Architecture Framework
Solution Architecture FrameworkSolution Architecture Framework
Solution Architecture FrameworkFirmansyahIrma1
 
Knowledge Management in Agile Projects
Knowledge Management in Agile ProjectsKnowledge Management in Agile Projects
Knowledge Management in Agile ProjectsCognizant
 
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...Alan McSweeney
 
What does BIM mean for Civil Engineers?
What does BIM mean for Civil Engineers?What does BIM mean for Civil Engineers?
What does BIM mean for Civil Engineers?Chun Keung Ng
 
What is the Value of Mature Enterprise Architecture TOGAF
What is the Value of Mature Enterprise Architecture TOGAFWhat is the Value of Mature Enterprise Architecture TOGAF
What is the Value of Mature Enterprise Architecture TOGAFxavblai
 
Solution Architecture Concept Workshop
Solution Architecture Concept WorkshopSolution Architecture Concept Workshop
Solution Architecture Concept WorkshopAlan McSweeney
 
What is Enterprise Architecture?
What is Enterprise Architecture?What is Enterprise Architecture?
What is Enterprise Architecture?BOC Group
 
Integrated Project and Solution Delivery And Business Engagement Model
Integrated Project and Solution Delivery And Business Engagement ModelIntegrated Project and Solution Delivery And Business Engagement Model
Integrated Project and Solution Delivery And Business Engagement ModelAlan McSweeney
 
IT Enterprise architecture ppt
IT Enterprise architecture pptIT Enterprise architecture ppt
IT Enterprise architecture pptMonsif sakienah
 
Revit and Building Information Modeling (BIM) Presentation
Revit and Building Information Modeling (BIM) PresentationRevit and Building Information Modeling (BIM) Presentation
Revit and Building Information Modeling (BIM) Presentationryanabarton
 
BIM for Lifecycle Asset Management
BIM for Lifecycle Asset ManagementBIM for Lifecycle Asset Management
BIM for Lifecycle Asset ManagementEdwin Bartlett
 

What's hot (20)

Enterprise Architecture Management (EAM) I Best Practices I NuggetHub
Enterprise Architecture Management (EAM) I Best Practices I NuggetHubEnterprise Architecture Management (EAM) I Best Practices I NuggetHub
Enterprise Architecture Management (EAM) I Best Practices I NuggetHub
 
A Summary of TOGAF's Architecture Capability Framework
A Summary of TOGAF's Architecture Capability FrameworkA Summary of TOGAF's Architecture Capability Framework
A Summary of TOGAF's Architecture Capability Framework
 
Chapter 3
Chapter 3Chapter 3
Chapter 3
 
Architecture solution architecture method
Architecture solution architecture methodArchitecture solution architecture method
Architecture solution architecture method
 
Dissertation BIM
Dissertation BIMDissertation BIM
Dissertation BIM
 
BIM Execution Plan - Bim Process Model Rview and Procedure
BIM Execution Plan - Bim Process Model Rview and ProcedureBIM Execution Plan - Bim Process Model Rview and Procedure
BIM Execution Plan - Bim Process Model Rview and Procedure
 
BIM Presentation
BIM PresentationBIM Presentation
BIM Presentation
 
Technical Architecture
Technical ArchitectureTechnical Architecture
Technical Architecture
 
NEXT generation enterprise applications
NEXT generation enterprise applicationsNEXT generation enterprise applications
NEXT generation enterprise applications
 
Solution Architecture Framework
Solution Architecture FrameworkSolution Architecture Framework
Solution Architecture Framework
 
Knowledge Management in Agile Projects
Knowledge Management in Agile ProjectsKnowledge Management in Agile Projects
Knowledge Management in Agile Projects
 
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...
Integrating It Frameworks, Methodologies And Best Practices Into It Delivery ...
 
What does BIM mean for Civil Engineers?
What does BIM mean for Civil Engineers?What does BIM mean for Civil Engineers?
What does BIM mean for Civil Engineers?
 
What is the Value of Mature Enterprise Architecture TOGAF
What is the Value of Mature Enterprise Architecture TOGAFWhat is the Value of Mature Enterprise Architecture TOGAF
What is the Value of Mature Enterprise Architecture TOGAF
 
Solution Architecture Concept Workshop
Solution Architecture Concept WorkshopSolution Architecture Concept Workshop
Solution Architecture Concept Workshop
 
What is Enterprise Architecture?
What is Enterprise Architecture?What is Enterprise Architecture?
What is Enterprise Architecture?
 
Integrated Project and Solution Delivery And Business Engagement Model
Integrated Project and Solution Delivery And Business Engagement ModelIntegrated Project and Solution Delivery And Business Engagement Model
Integrated Project and Solution Delivery And Business Engagement Model
 
IT Enterprise architecture ppt
IT Enterprise architecture pptIT Enterprise architecture ppt
IT Enterprise architecture ppt
 
Revit and Building Information Modeling (BIM) Presentation
Revit and Building Information Modeling (BIM) PresentationRevit and Building Information Modeling (BIM) Presentation
Revit and Building Information Modeling (BIM) Presentation
 
BIM for Lifecycle Asset Management
BIM for Lifecycle Asset ManagementBIM for Lifecycle Asset Management
BIM for Lifecycle Asset Management
 

Viewers also liked

Cita iasa certifications
Cita iasa certificationsCita iasa certifications
Cita iasa certificationsAdams Firdaus
 
The process of software architecting
The process of software architectingThe process of software architecting
The process of software architectingRoger Snook
 
Solution architecture
Solution architectureSolution architecture
Solution architectureiasaglobal
 
Are You an Accidental or Intention Software Architect
Are You an Accidental or Intention Software ArchitectAre You an Accidental or Intention Software Architect
Are You an Accidental or Intention Software ArchitectRandy Ynchausti
 
User story estimation with agile architectures
User story estimation with agile architecturesUser story estimation with agile architectures
User story estimation with agile architecturesRaffaele Garofalo
 
IASA 2014 Conference - Cape Town, South Africa #iasa2014
IASA 2014 Conference - Cape Town, South Africa #iasa2014IASA 2014 Conference - Cape Town, South Africa #iasa2014
IASA 2014 Conference - Cape Town, South Africa #iasa2014Karen Du Toit
 
Architecting multi sided business
Architecting multi sided businessArchitecting multi sided business
Architecting multi sided businessRichard Veryard
 
The Role of the Software Architect
The Role of the Software ArchitectThe Role of the Software Architect
The Role of the Software ArchitectHayim Makabee
 
Iasa, Iasa Ireland, ICS Jan 2011
Iasa, Iasa Ireland, ICS Jan 2011Iasa, Iasa Ireland, ICS Jan 2011
Iasa, Iasa Ireland, ICS Jan 2011iasaireland
 
Iasa Architect responsibilities in the cloud
Iasa Architect responsibilities in the cloudIasa Architect responsibilities in the cloud
Iasa Architect responsibilities in the cloudiasaglobal
 
Why IT needs more IT Architects (IASA style)
Why IT needs more IT Architects (IASA style)Why IT needs more IT Architects (IASA style)
Why IT needs more IT Architects (IASA style)Paddy Baxter
 
Delivering Data - Social Networking Personal
Delivering Data - Social Networking PersonalDelivering Data - Social Networking Personal
Delivering Data - Social Networking Personaliasaireland
 
Business Process Management: Implementing Continuous Improvement in Your Orga...
Business Process Management: Implementing Continuous Improvement in Your Orga...Business Process Management: Implementing Continuous Improvement in Your Orga...
Business Process Management: Implementing Continuous Improvement in Your Orga...Henry Chandra
 
Platforms or Two-sided markets
Platforms or Two-sided marketsPlatforms or Two-sided markets
Platforms or Two-sided marketsMartin Westhead
 

Viewers also liked (15)

Cita iasa certifications
Cita iasa certificationsCita iasa certifications
Cita iasa certifications
 
The process of software architecting
The process of software architectingThe process of software architecting
The process of software architecting
 
Solution architecture
Solution architectureSolution architecture
Solution architecture
 
Are You an Accidental or Intention Software Architect
Are You an Accidental or Intention Software ArchitectAre You an Accidental or Intention Software Architect
Are You an Accidental or Intention Software Architect
 
User story estimation with agile architectures
User story estimation with agile architecturesUser story estimation with agile architectures
User story estimation with agile architectures
 
IASA 2014 Conference - Cape Town, South Africa #iasa2014
IASA 2014 Conference - Cape Town, South Africa #iasa2014IASA 2014 Conference - Cape Town, South Africa #iasa2014
IASA 2014 Conference - Cape Town, South Africa #iasa2014
 
Architecting multi sided business
Architecting multi sided businessArchitecting multi sided business
Architecting multi sided business
 
The Role of the Software Architect
The Role of the Software ArchitectThe Role of the Software Architect
The Role of the Software Architect
 
Iasa, Iasa Ireland, ICS Jan 2011
Iasa, Iasa Ireland, ICS Jan 2011Iasa, Iasa Ireland, ICS Jan 2011
Iasa, Iasa Ireland, ICS Jan 2011
 
Iasa Architect responsibilities in the cloud
Iasa Architect responsibilities in the cloudIasa Architect responsibilities in the cloud
Iasa Architect responsibilities in the cloud
 
Why certify
Why certifyWhy certify
Why certify
 
Why IT needs more IT Architects (IASA style)
Why IT needs more IT Architects (IASA style)Why IT needs more IT Architects (IASA style)
Why IT needs more IT Architects (IASA style)
 
Delivering Data - Social Networking Personal
Delivering Data - Social Networking PersonalDelivering Data - Social Networking Personal
Delivering Data - Social Networking Personal
 
Business Process Management: Implementing Continuous Improvement in Your Orga...
Business Process Management: Implementing Continuous Improvement in Your Orga...Business Process Management: Implementing Continuous Improvement in Your Orga...
Business Process Management: Implementing Continuous Improvement in Your Orga...
 
Platforms or Two-sided markets
Platforms or Two-sided marketsPlatforms or Two-sided markets
Platforms or Two-sided markets
 

Similar to Software architecture in an agile environment

Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)
Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)
Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)Spiffy
 
Importance of Software architecture
Importance of Software architectureImportance of Software architecture
Importance of Software architectureSteve Essich
 
02 architectures in_context
02 architectures in_context02 architectures in_context
02 architectures in_contextMajong DevJfu
 
The role of the architect in agile
The role of the architect in agileThe role of the architect in agile
The role of the architect in agileDror Helper
 
Saf08 Growing Architects Kevin Francis
Saf08 Growing Architects   Kevin FrancisSaf08 Growing Architects   Kevin Francis
Saf08 Growing Architects Kevin FrancisKevin Francis
 
Agile Architecture Belfast Software Architecture User Group
Agile Architecture   Belfast Software Architecture User GroupAgile Architecture   Belfast Software Architecture User Group
Agile Architecture Belfast Software Architecture User GroupPaul Wallace
 
[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology
[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology
[WSO2Con USA 2018] Deep-dive into Agile Architecture and MethodologyWSO2
 
Agile Architecture
Agile Architecture Agile Architecture
Agile Architecture VMware Tanzu
 
Agile Software Development Overview
Agile Software Development OverviewAgile Software Development Overview
Agile Software Development Overviewsunilkumar_
 
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...AgileNetwork
 
Teams and workflow inside design systems
Teams and workflow inside design systemsTeams and workflow inside design systems
Teams and workflow inside design systemsAlfonso Morcuende
 
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015Mozaic Works
 
Solution Architecture tips & tricks by Roman Shramkov
Solution Architecture tips & tricks by Roman ShramkovSolution Architecture tips & tricks by Roman Shramkov
Solution Architecture tips & tricks by Roman ShramkovJavaDayUA
 
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...ANI | Agile Chennai | Architecture in agile environment challenges enablers |...
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...AgileNetwork
 
Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)stanbridge
 
Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)stanbridge
 
02_Architectures_In_Context.ppt
02_Architectures_In_Context.ppt02_Architectures_In_Context.ppt
02_Architectures_In_Context.pptRohanBorgalli
 
CMAD Group Workbook 3.1 Op Model Enable
CMAD Group Workbook 3.1 Op Model Enable CMAD Group Workbook 3.1 Op Model Enable
CMAD Group Workbook 3.1 Op Model Enable Alexander Doré
 

Similar to Software architecture in an agile environment (20)

Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)
Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)
Agile in Action - Act 1 (Set Up, Planning, Requirements and Architecture)
 
Importance of Software architecture
Importance of Software architectureImportance of Software architecture
Importance of Software architecture
 
02 architectures in_context
02 architectures in_context02 architectures in_context
02 architectures in_context
 
The role of the architect in agile
The role of the architect in agileThe role of the architect in agile
The role of the architect in agile
 
Agile Engineering Practices
Agile Engineering PracticesAgile Engineering Practices
Agile Engineering Practices
 
Saf08 Growing Architects Kevin Francis
Saf08 Growing Architects   Kevin FrancisSaf08 Growing Architects   Kevin Francis
Saf08 Growing Architects Kevin Francis
 
Agile Architecture Belfast Software Architecture User Group
Agile Architecture   Belfast Software Architecture User GroupAgile Architecture   Belfast Software Architecture User Group
Agile Architecture Belfast Software Architecture User Group
 
[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology
[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology
[WSO2Con USA 2018] Deep-dive into Agile Architecture and Methodology
 
Agile Architecture
Agile Architecture Agile Architecture
Agile Architecture
 
Agile Software Development Overview
Agile Software Development OverviewAgile Software Development Overview
Agile Software Development Overview
 
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...
Agile Chennai 2021 | Achieving High DevOps Maturity through Platform Engineer...
 
Teams and workflow inside design systems
Teams and workflow inside design systemsTeams and workflow inside design systems
Teams and workflow inside design systems
 
Training Offerings - CodeOps Technologies
Training Offerings - CodeOps TechnologiesTraining Offerings - CodeOps Technologies
Training Offerings - CodeOps Technologies
 
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015
Simon Brown: Software Architecture as Code at I T.A.K.E. Unconference 2015
 
Solution Architecture tips & tricks by Roman Shramkov
Solution Architecture tips & tricks by Roman ShramkovSolution Architecture tips & tricks by Roman Shramkov
Solution Architecture tips & tricks by Roman Shramkov
 
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...ANI | Agile Chennai | Architecture in agile environment challenges enablers |...
ANI | Agile Chennai | Architecture in agile environment challenges enablers |...
 
Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)
 
Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)Cs 1023 lec 3 architecture (week 1)
Cs 1023 lec 3 architecture (week 1)
 
02_Architectures_In_Context.ppt
02_Architectures_In_Context.ppt02_Architectures_In_Context.ppt
02_Architectures_In_Context.ppt
 
CMAD Group Workbook 3.1 Op Model Enable
CMAD Group Workbook 3.1 Op Model Enable CMAD Group Workbook 3.1 Op Model Enable
CMAD Group Workbook 3.1 Op Model Enable
 

Recently uploaded

2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...Martijn de Jong
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoffsammart93
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobeapidays
 
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...apidays
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxRustici Software
 
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelNavi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelDeepika Singh
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businesspanagenda
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Jeffrey Haguewood
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024The Digital Insurer
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native ApplicationsWSO2
 
AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024The Digital Insurer
 
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWERMadyBayot
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...DianaGray10
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodJuan lago vázquez
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Zilliz
 
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbu
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu SubbuApidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbu
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbuapidays
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...apidays
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdflior mazor
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 

Recently uploaded (20)

2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...
Apidays Singapore 2024 - Scalable LLM APIs for AI and Generative AI Applicati...
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelNavi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024
 
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
 
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbu
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu SubbuApidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbu
Apidays Singapore 2024 - Modernizing Securities Finance by Madhu Subbu
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdf
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 

Software architecture in an agile environment

  • 1. Agile Architecture Software Architecture for Agile Speaker: Raffaele Garofalo (raffaeu) http://blog.raffaeu.com
  • 2. Agenda Introduction Software Architect Agile Architecture • Software architecture • The role • Workflow • Agile development • Collocation with Agile • Team structure • Agile + Architecture • Sample
  • 3. Introduction What is What is Agile How they can Software Development live together? Architecture
  • 4. Introduction What is Software Architecture
  • 5. Software Architecture Software Architecture is a terminology introduced some years ago in the software development community, which identifies a specific science or art of designing and delivery value.
  • 6. “The art or science of designing and delivering valuable technology strategies” Select Engineering frameworks design and products Bridges the Business gap between Models business and What technology does it deliver?
  • 7. Introduction What is Agile Development
  • 8. Agile Development Agile software development is a group of software development methods based on iterative and incremental development, where requirements and solutions evolve through collaboration between self-organizing, cross- functional teams.
  • 9. Agile is not only TDD. Agile … Agile Kanban Modeling SCRUM C.I. XP TDD
  • 10. SCRUM 2/4 weeks PRODUCT SPRINT SPRINT FEATURE(s) BACKLOG BACKLOG BACKLOG
  • 11. Introduction How they can live together?
  • 12. Agile Architecture Software Agile Agile Architecture Architecture (MDD) (AMDD)
  • 13. The Software Architect role The Software The Software Architect in Agile Golden Rules Architect environment
  • 14. The Software Architect role The Software Architect
  • 15. Software Architect Create architectural designs from a vision It looks at current and future design requirements Takes technical decisions such Platform and Frameworks based on his experience
  • 16. The Software Architect role The Software Architect in Agile environment
  • 17. Software Architect and Agile Provide information about frameworks and platforms Provide architectural knowledge during the modeling phase Interact with the business to communicate the changes and the features with the team Contribute to development and delivering
  • 18. The Software Architect role Golden Rules
  • 19. Golden rules of Agile Architect A Software Architect doesn’t have anything special, it is part of the team In Agile, every member of the team is an active part and so should be the Architect, an active part of a team Avoid Avory tower built during the design time without involving the developers in the design process. When everything is pre- designed and pre-decided, the frustration grows … A strict Software Architect will fit better in a big team/project because there will be more space for his ego than in a small team where every member should be able to do everything
  • 20. Agile Architecture The Team Sample Agile Workflow structure architecture
  • 22. Process Workflow Application overview Identify Architecture OBJECTIVES Key scenarios Key Hot Spots Candidate Solution
  • 23. Process Workflow Iter: 0 Iter: n Envision Modeling Brainstorm Estimates TDD
  • 24. Agile Architecture The Team structure
  • 26. Agile Architecture Sample Agile architecture
  • 27. Sample process Let’s have a look at Visual Studio 2011 and a sample project created using SCRUM and Agile Architectures with the help of Typemock
  • 31. Q/A? Contacts • Blog: http://blog.raffaeu.com • Twitter: @raffaeu
  • 33. Appendix B Security Scalability Availability Interoperability Testability Usability

Editor's Notes

  1. Today we will talk about Software Architecture and Agile. But do you have already a definition for Software Architecture and Agile? Do you exactly know what a Software Architect should do and what is Agile?The webinar is divided into three different topics. In the first part we will have a short introduction to Software architecture and Agile development. Then we will have a look at the Software Architect role and finally we will see the Agile Architecture methodology. Next slide
  2. Introduction. First of all let’s start with some terminology and explanations. What is Software Architecture? What is Agile Developments? And finally, let’s see how can we keep together Agile and Software Architectures. Next slide
  3.  Next slide
  4. Definition of Software ArchitectureSoftware Architecture is a terminology introduced some years ago in the software development community, which identifies a specific science or art of designing and delivery value. So the target of Software Architecture is to design and delivering value. Very important concept. If your architecture is not delivering value you should be concerned about it because it is a useless cost for the company.But what does it mean delivering value? Next slide
  5. Software architecture is?Software architecture is a group of methods, techniques, documents, approaches, you name it … used to deliver and document software.A software architecture, generally is in place to help us delivering the following items: Business models, Engineering design, choose the right frameworks and platforms, bridge the gap between the IT and the business.  Next slide
  6. Introduction. First of all let’s start with some terminology and explanations. What is Software Architecture? What is Agile Developments? And finally, let’s see how can we keep together Agile and Software Architectures. Next slide
  7. Agile software development is a group of software development methods based on iterative and incremental development, where requirements and solutions evolve through collaboration between self-organizing, cross-functional teams.Agile Next slide
  8. If we talk about Agile I am sure everyone of you has already heard about: continuous integration, unit testing, continuous delivering, flexibility to change, sprint and features.Agile is a set of methodologies, each one focused on a specific aspect of the development process.For example, we may adopt XP if we need to improve productivityWe may adopt SCRUM if we need some additional information about the team and the process and we want a light process to handle the development.We may have Kanban if the Team is 100% interchangeable, we may adopt TDD because we want to increase the quality of the code delivered.
  9. In this slide we have a simple representation of SCRUM, one of the available methodologies offered by agile.The main characteristic of SCRUM is to break the development into small tasks, with minimal planning without requiring long planning tasks. It is composed by iterations where the team work all together to deliver one or more feature. There is no architectural view of the project because the team is always focused only on the feature they are delivering, for this reason the role of a software architect is tricky inside a team that is adopting agile.In the same time every member of team has the same decisional impact of any other member of the team and this can grant more freedom to the ego of every single developer, which is an important factor.So, how do we solve this problem?How do we keep together software architectures and agile? Next slide
  10.  Next slide
  11. In this simple equation we have on one side the agile methodologies and MDD development.On the other side we have AMDD, the agile architecture.With MDD (Model Driven Development) the team and especially the architects are forced to design the entire or a good portion of the business model upfront. This is the classic technique. Unfortunately with this approach we can’t be iterative like we are with Agile where we have plan/development/release iterations.AMDD (Agile Model Driven Development) is an agile technique that differs a little bit from the standard MDD Model Driven Development.With AMDD we create agile models that are just barely good enough to drive the development. This is a further step of the agile adoption, where in a first phase the team is focused solely to deliver features and fix bugs and it does not have an architectural overview of the project.
  12. Let’s see how a software architect can live inside an Agile team and how it is really important to keep this role even if we are inside an Agile team, in order to provide a continuous overview and right documentation of the product we are delivering. The software architect is an ambitious role but even controversial because it has always been defined with a wide large definition that doesn’t always represents the correct role. Now we have some institutes and organizations like Microsoft and IASA that are trying to give a better definition for this role but there are still controversial decisions between the various organizations.
  13. The software architect is the member of the team able to create an architectural design from a vision of a stakeholder. It does not mean that from the vision the software architect must create the entire architecture but he is able to translate the vision into something more understandable by the IT.He should be able to look at current and future requirements in order to drive the team and the costs into the right direction from the beginning.He should be able to take technical decisions that will drive the development such as: the right framework, the right OS, the right tools. This decisions should be made from his experience and his knowledge of the team.This is the strict description adopted by the architect organizations. Now let’s see how we can modify this role to fit into Agile. Next slide
  14. Inside an Agile environment the Software Architect should be able to:Provide information about Frameworks and Platforms by sharing his knowhow with the teamProvide architectural knowledge during the modeling phase of each iterationInteracts with the business because the Software Architect represents the bridge between the business and the ITBe modest enough to contribute to development and delivering because in Agile every single member of the team should be flexible enough to cover multiple roles, from the developer role to the architect role, without regretting the database developer role either…So, based on my personal experience inside an Agile team, I draw few golden rule that every agile architect should follow Next slide
  15. Let’s see how a software architect can live inside an Agile team and how it is really important to keep this role even with Agile, in order to provide a continuous overview and right documentation of the product we are delivering. The software architect is an ambitious role but even controversial because it has always been defined with a wide large definition that doesn’t always represents the correct role. Inside an Agile team a good software architect should be flexible enough to keep his role of architect and be also a good developer and tester in order to be a good and exchangeable key of the team.
  16. In order to be a good Agile Architect you should follow these golden rules:A Software Architect doesn’t have anything special, it is part of the teamIn Agile, every member of the team is an active part and so should be the Architect, an active part of a teamAvoid Avory tower built during the design time following the MDD (Model Driven Development) methodology. It doesn’t involve the developers so the team, it doesn’t fit the collaborative approach adopted by AgileA strict Software Architect will fit better in a big team/project because there will be more space for his ego than in a small team where every member should be able to do everything. Inside a small team the software architect role should be cover by the entire team.
  17. We are now at the final section of this webinar where we will have a look at the agile architecture methodology and how it works. Next slide
  18. How does it works?
  19. This methodology has been presented the first time in 2008 by JD Maier; he recently joined the Microsoft Enterprise Strategy team.The methodology is described with the following workflow:First we identify the objectives. How? You know what will it be the outcome, right? Here you should build a prototype, share the models over the team and discuss potential paths and risksSecond, we need to identify the key scenarios. We need to identify the architecturally significant use cases, but how do we know that a use case is architecturally significant and how can we avoid the Avory Tower? They are use cases important for acceptance of the deliverableWith the application overview, we can start to provide a general overview of the application. [show slide 31]Then we need to analyze the key hotspots, we need to use the quality attributes to identify the right hotsposts. But what are quality attributes? [show slide 32]Now you can create the candidate solution, the candidate architecture and discuss it against constraint and environmentThis workflow is iterative, so you will not define these requirements all at the beginning by through an iterative process. How? Let’s have a look at the next slide.
  20. This slide represents the AMDD (Agile Model Driven Development).We have an initial iteration that we will call iteration 0 where we envision the requirements and estimate the potential risks and decide the architectural style and the frameworks, environments we will use. This step is really important because from here we will drive the team and the development through a specific path. This iteration, depending on the type of project, will take some days in order to allow the team to identify the high level requirements. You may provide some mocks of the UI and some mocks of the business model in order to have further to discuss.Then we have n iterations composed by three parts:Modeling. The model should give enough information to provide an estimation and to plan the work for the iteration. The scope of this part is solely to provide a good estimate for the current iteration, so the model shouldn’t go further than what expected by the current iteration. Remember that you can always go back and refactor the model!In this part few members of team meet together for a short period of time and discuss the model obtained so far. In XP this is called stand-up design sessionTDD first absolutely perfect into this process because after you have modeled your software you need to implement the model in the code. Using the TDD approach each part of the model required by the iteration will be implemented using the TDD approach, to improve the quality of the code constantly during the developmentAt the end you will come up with a double outcome. On one side the team has a full understanding of the architecture and knows exactly what to deliver for every iteration. Plus, you have been able to keep alive your software architecture process and the second outcome will be a well documented architecture flexible enough for an iterative development process.
  21. Now let’s briefly see how it is structured a team inside Agile Architecture
  22. Let’s take two different cases. Large and small team.In a large team you need some management and you need an architecture owner, which is usually the Software Architect.Usually when the team is large and there is more than an architecture owner, each of this owner is the team lead of the sub-development team. In this way the knowhow of the architecture is properly distributed across the entire structure.If the team is small, I found really helpful to distribute the knowledge of the architecture and the role of the software architect across the entire team following a more practical Agile approach. Next slide
  23. Now let’s have a look at an agile architecture
  24. First we determine the application typeUnderstand the deployment constraints such as the environmentIdentify the architectural style and keep it over the entire application. Domain Driven? SOA?Identify the relevant technologies that you will use in your architecture (WPF, SQL Server?)
  25. These is just a short list of the quality attributes you may use in your architectureto identify the key hot spots.