In a large, high-throughput system there’s no one database to rule them all, distributed transactions are a no-no and failure is a first-class citizen.
Designing for scale means designing for large numbers of distributed systems and dealing with a few hundred clients poses different problems to scaling out to cover an entire country, continent or planet.
You’re likely to want Damian Maclennan for this talk, too, if you can get him, as the first time we delivered this talk was together at DDD Brisbane 2013.
Here’s a version of the talk that Damian and I delivered together at the Brisbane Azure User Group.
I'm Head of IT & Engineering at Etax, one of Australia's largest tax agents. Other interesting places I've been before Etax include Octopus Deploy, ThoughtWorks, Readify, Zap BI, Realex Payments and TRL.
I'm a fan of high-quality code, domain-driven design, event-driven architecture, continuous delivery and, most importantly, shipping software that works and that solves people's problems.
I have a number of small open-source creations, including Nimbus, ConfigInjector and NotDeadYet, and am an occasional contributor to several more.
I'm a regular speaker and presenter at conferences and training events. My mother wrote COBOL on punch cards and I've been coding in one form or another since I was five years old.
Cyclist. Runner. Hiker. Budding skydiver. Photographer. Ballroom dancer. Motorcyclist. Occasional sailor. Lapsed fencer. Legatee.