WeSearch

That one time I used Go panics for flow control

·3 min read · 0 reactions · 0 comments · 10 views
#technology#programming#go#software engineering
⚡ TL;DR · AI summary

The article discusses a situation where a key service in a support infrastructure became overloaded due to high query demand. The author explains how they implemented a workaround using Go's panic mechanism for flow control to handle cancellation of long-running sort operations. This approach, while not typical, allowed them to avoid unnecessary processing when queries were abandoned.

Key facts
Original article
Noncrab
Read full at Noncrab →
Opening excerpt (first ~120 words) tap to expand

How our protagonist discovered that a key service that powers our support was absurdly vulnerable to overload, and what we did to fix it. Part of our support infrastructure at work is an in-memory datastore, that allows us to query our outstanding support work over various dimensions, such as work type, whether it's been put on hold for some reason, etc. It's functionally equivalent to a single table in an SQL database, where you have a single dataset, boolean filters and configurable sorting. At work, we have an in-memory datastore that powers part of our support infrastructure. Its kind of analgous to having bitmap filters with post-hoc filtering, so any use of sort/limit will sort the entire result set.

Excerpt limited to ~120 words for fair-use compliance. The full article is at Noncrab.

Anonymous · no account needed
Share 𝕏 Facebook Reddit LinkedIn Threads WhatsApp Bluesky Mastodon Email

Discussion

0 comments

More from Noncrab