In programming, serialization is the process of transforming data so it can be transferred, stored, or compared. You might have a variable in your pr...
One thing to look out for in Node.js: functions that may throw an error either synchronously or asynchronously (which, technically, is any function t...
In A Practical Tracing Journey, I described how I added tracing to a real-world app to get insights on how I could improve performance. One of the co...
Almost a year ago, I began writing a book about observability. I had a vision—a small book designed to explain the basic ideas of observability to ...
How do you know that an algorithm is O(n) (or O(log n) or O(1), etc)? The first (and correct) answer is by analysis: if your algorithm loops over a s...
I've talked a good deal about observability, tracing and instrumentation in the past. Recently, I decided to try out some new things in those areas, ...
Some time ago, I was investigating an error report from Sentry on Tentacle. I noticed something baffling: the URL wasn't mine. The error was definite...
Hi! Still working on the upgrade tool from last time. As we saw, the current implementation works, but there are a few issues. There are three main o...
Recently, I released Scribe version 3. It introduced a few changes to the config file, and it came with a little utility: run php artisan scribe:upgr...
I maintain Scribe, a library for automatically generating your HTTP API documentation from your codebase. When you run the generate command, Scribe f...
Okay, back again. Thus far, we've seen the limitations of a single-threaded architecture in achieving concurrency (Part 1). Then we saw how coroutine...
New to this series? Check out Parts 1 and 2 first. Last time, I wrote about how coroutines help enable concurrency, and how they work in JavaScript....