Lawrence Jones

Building reliable infrastructure for GoCardless, a fast-growing fintech based in London. Focused on tackling infrastructure problems with a software engineering mindset.
https://blog.lawrencejones.dev/ (RSS)
visit blog
Looking back at 2024
31 Dec 2024 | original ↗

I’m determined to make a tradition of this, which is why I find myself in an empty office on New Years Eve trying to remember what’s gone by these last twelve months. I ended “Looking back at 2023” saying “brace for impact” which I had thought meant I was prepared for this year, but in retrospect I wasn’t even close. It’s a common story in...

When Game Days go wrong
8 Dec 2024 | original ↗

It was the week before pandemic lockdowns began. Like many companies, we were thinking about what a fully remote workforce might mean for us. In an attempt to get ahead of things, we scheduled a ‘Game Day’ to test our work-from-home incident response capabilities. You know, just in case we’d need to abandon the office (spoiler: we would). The...

Learn one thing at a time
26 Apr 2024 | original ↗

Of the mental models and rules I use in my life, by far the most useful is to learn only one thing at any given time. If you get it right, you: Ensure work is the right balance of challenging for it to be enjoyable. Avoid stalling due to an overload of uncertainty. Learn better, and faster. This rule works for individuals but is also useful...

Looking back at 2023
29 Dec 2023 | original ↗

Last year I wrote “Looking back at 2022” and found it valuable to reflect and celebrate a year of work, even if just as a reminder of the things that happened before going into the next. So with another year having passed, time to try again! This time for my second full year working at incident.io. To contextualise the year, some milestones (see...

Adding concurrency control to HTTP APIs
14 Oct 2023 | original ↗

Recently, I’ve needed to add concurrency protections to several HTTP APIs. One endpoint was for updating a schedule, where incident.io customers would tell us about who was on-call and what hours they worked so we could generate a pay report. It would suck if another user was modifying the same schedule – maybe just to add a single user – and...

Use your database to power state machines
16 Sept 2023 | original ↗

Most people are familiar with state machines and know their value. The average state machine library can help you model states, prevent invalid transitions, and produce diagrams that help even non-technical people understand how the code behaves. This article isn’t about making the case for state machines. It’s about how you take the concept of a...

Screw DRY – copy-paste is the goal
3 Jul 2023 | original ↗

From the moment you learn programming people tell you “don’t repeat yourself!” So what I’m about to suggest might sound odd. But I’m here to say that if you want to ship high-quality software at pace, you should be investing in abstractions that are designed to enable copy-and-paste. When you look at most software teams, they work within an...

Three months building a catalog
30 Jun 2023 | original ↗

For the last three months I’ve been working on a team building the incident.io Catalog: read the announcement post here. One of the things I enjoy about working at incident is we often build products I’ve been thinking about or actively using for years. The catalog may be the best example of this, having spent years at GoCardless building and...

Uptime, status pages, and transparency calculus
30 Jan 2023 | original ↗

When you first create a status page, it’s probably because you want to communicate outages to your customers. The faster you can share details about an outage, the sooner your customers know what’s going on, and the more effectively they can handle the outage. Communicating promptly – in clear language – builds trust. And as a young company with...

Using ULIDs at incident.io
3 Jan 2023 | original ↗

Inspired by PlanetScale’s post about Why we chose NanoIDs for PlanetScale’s API, I wanted to share my experience of using ULIDs (Universally Unique Lexicographically Sortable Identifier) at incident.io. It’s worth noting ULIDs had been chosen before I ever arrived at incident, so I can’t speak to the motivation. But I think our implementation...

Looking back at 2022
31 Dec 2022 | original ↗

I’ve never done this before (at least sharing it publicly) but 2022 was a wild ride for me and I wanted to pause to consider everything that happened. Weird to think it, but this was my first full year at incident.io, having joined the company August 2021. So much has happened these last 12 months – 4x’ing the team, our Series A, building loads...

Weird stuff and how to test it
29 Dec 2022 | original ↗

Most software is simple: you have a codebase, and existing patterns for testing at a unit and integration level. Sometimes though, you’ll face problems that aren’t just adding code to an existing project. Maybe your problem involves many codebases, uses tricky infrastructure, or perhaps you’re not trying to test ‘code’, per-say. I’ve faced my...

Building workflows: technical deep-dive and evaluation
14 Sept 2022 | original ↗

After one year in operation, I wrote a technical deep-dive into how we built the workflows feature at incident.io, split into a two-part series. Workflow series in two parts: part 1 and part 2 Part one explains core workflow concepts used across the feature, and look at how code structure makes development easy. Followed by a...

Want to found a start-up? Work at one first!
30 Aug 2022 | original ↗

Contrary to the popular stereotype of college drop-out founders, research shows start-ups with older founders are more likely to succeed, and build more valuable companies too. It’s clear that when it comes to building companies, experience really does matter. And recently, speaking with friends considering starting companies, I’ve been...

Adding latency: one step, two step, oops
20 Aug 2022 | original ↗

I’m a fan of testing in production, especially when it comes to complex systems with a wide range of user behaviour. You can only go so far with synthetic experiments before you need to try something out for real, but as with anything in production, it’s not without risk. Several years back I was at GoCardless, migrating our infrastructure from...

Growing into Platform Engineering
11 Jun 2022 | original ↗

This post is a written form of my talk at PlatformCon, with the addition of the service catalog story. Here’s a link if watching the talk is more your thing: https://platformcon.com/talk/growing-into-platform-engineering I work at incident.io, a start-up in London that offers incident response tooling to help organisations respond with ease, at...

My most impactful code
19 Mar 2022 | original ↗

At a team dinner over Mexican food and margaritas, someone asked “what was the most impactful code you ever wrote?”. I hadn’t considered this before and was surprised I had an answer ready. Though whether the impact was a net positive is something I’m not certain of. Setting the scene I rejoined GoCardless in 2016 when the company was 80 people,...

↑ These items are from RSS. Visit the blog itself at https://blog.lawrencejones.dev/ to find everything else and to appreciate author's digital home.