Break The Golang Context Chain

And enabling a context to be used after cancellation

Go 1.21 Update: Apparently alongside me writing this article, the Go project was tracking this very same issue. Comments in the thread bring up some very valid concerns with this pattern beyond the caveats I cover below, but ultimately the feature is now part of the Go 1.21 changeset as context.WithoutCancel. Recently, I recalled a useful pattern that’s cropped up a few times at work. API …

The X-Files: Avoiding Concurrency Boilerplate With golang.org/­​x/​sync

Or abstracting common synchronization patterns in Go

Go makes concurrent programming dead simple with the go keyword. And, with its “share memory by communicating” mantra, channels perform as a thread-safe mechanism for IO between threads. These primitives more than meet the demands of most parallel tasks. But sometimes workloads need extra coordination, particularly around error propagation or synchronization. For example, goroutines …

The X-Files: Controlling Throughput with rate.Limiter

Or how to fail fast and avoid catastrophe

In this first X-Files post, I’ll cover the simple yet powerful golang.org/x/time/rate. This package provides a Limiter that controls throughput to an arbitrary resource. There’s a ton of utility in rate, and to show its virtues, I will use it to enforce an SLA on an HTTP service.1 SLAs and Rate Limiting When creating a new service, it is prudent to specify a service level agreement, or SLA. …

The X-Files: Exploring the Golang Standard Library Sub-Repositories

Or understanding the Go packages under golang.org/x/*

This post will be the start of The X-Files, a blog series exploring the Go sub-repositories located at golang.org/x/*. Chances are, you may not have heard them called that before or know where they came from. Introductions are in order… A brief origin story Go promises, with reasonable exceptions, that its compiler and standard library will remain forward-compatible for all minor releases …

Asynchronously Split an io.Reader in Go (golang)

Or the many ways to skin a cat — er — stream

I have fallen in love with the flexibility of io.Reader and io.Writer when dealing with any stream of data in Go. And while I am more or less smitten at this point, the reader interface challenged me with something you might think simple: splitting it in two. I’m not even certain “split” is the right word. I would like to receive an io.Reader and read over it multiple times, …