From Design It! From Programmer to Software Architect by Michael Keeling.
- Partition system and assign responsibilities.
- Decide trade-offs among quality attributes:
- Performance (response time)
- Scalability (annual growth)
- Availability
- Security
- Testability
- Maintainability (team knowledge)
- Supportability
- Simplicity
- Time-to-market
- Manage technical debt.
- Grow the team's architecture skills.
- Define essential structures:
- Modules
- Components & connectors
- Allocations
- Find architecturally significant requirements (ASRs):
- Constraints
- Quality attributes
- Influential functional requirements
- Other influencers
- Turn a big problem into smaller, more manageable problems.
- Show people how to work together.
- Provide a vocabulary for talking about complex ideas.
- Look beyond features and functionality.
- Help avoid costly mistakes.
- Enables agility.
- Human rule. All design is social in nature.
- Ambiguity rule. Preserve ambiguity.
- Redesign rule. All design is redesign.
- Tangibility rule. Make ideas tangible to facilitate communication.
- Understand the problem.
- Explore ideas.
- Evaluate fit.
- Make it real.
- Think. Create a plan to learn.
- Do. Execute the plan.
- Check. Critically examine what we accomplished.
A satisficing design is both satisfactory and sufficient — good enough — for our needs.
- Treat solutions as experiments.
- Focus on reducing risks.
- Work to simplify problems.
- Iterate quickly to learn quickly.
- Think about the problem and solution at the same time.
The bigger the software system, the greater the benefits from up-front architecture design.
- Stakeholder map
- Business goals
- Architecture decision records
- Architecturally significant requirements
- Visual model:
- Element-responsiblity view
- Refinement view
- Event storming
- Context diagram
- Prototype
- Inception deck
- Big ball of mud
- Shared-data
- Multi-tier (e.g. 3-tier)
- Publish-subscribe
- Service-oriented architecture (microservices)
- Layers
- Ports and adapters
- Pipe-and-filter
- Centre of competence
- Open source contribution