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 at Octopus Deploy, helping to ship software that helps people ship software. Other interesting places I've been before Octopus include ThoughtWorks, Readify, Zap BI, Realex Payments and TRL.
I'm also a co-founder at Stack Mechanics, one of the organisers of the DDD Brisbane conference and, in my spare time (ha!), I also run my own photography business, Ivory Digital.
I'm a fan of high-quality code, domain-driven design, event-driven architecture, continuous delivery and, most importantly, shipping code 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. Photographer. Ballroom dancer. Motorcyclist. Occasional sailor. Lapsed fencer.