Deprecating Simplicity
This video is also available in the GOTO Play video app! Download it to enjoy offline access to our conference videos while on the move.
When engineering teams take on a new project, they often optimize for performance, availability, or fault tolerance. More experienced teams can optimize for these properties simultaneously. We can add an additional property: feature velocity. Organizations often try to optimize for feature velocity through process improvements and engineering hierarchy, but some optimize for feature velocity through explicit architectural decisions. These decisions increase the complexity of the system.
Mental models of approaching availability help us understand the tension between these engineering properties. For example, understanding the distinction between accidental complexity and essential complexity can help you decide whether to invest engineering effort into simplifying your stack or expanding the surface area of functional output. Incident remediation, approaches to automation, and diversity of engineering can all be understood through the perspective of these mental models. With insight and diligence, these models can be applied to improve availability over time and drift into a safer state for the system.
-
Computer Science - A Guide for the PerplexedJoe ArmstrongWednesday Apr 25 @ 8:45 AM
-
Coal to Code: Developing DevelopersMarvin LaucherAmanda LaucherWednesday Apr 25 @ 5:00 PM
-
Get Ready to Rock with Sonic Pi - The Live Coding Music Synth for EveryoneSam AaronWednesday Apr 25 @ 5:40 PM
-
Old Is the New NewKevlin HenneyThursday Apr 26 @ 5:00 PM
-
Dynamic Non-EventsAdrian CockcroftThursday Apr 26 @ 8:45 AM
-
Deprecating SimplicityCasey RosenthalThursday Apr 26 @ 1:00 PM