dispatchrun/dispatch-py

README: introduce technical terms before using them

Opened this issue · 0 comments

Throughout our README, we make use of advanced technical terms without defining them, which makes it difficult to appeal to a wide audience.

Here is a quote from some a piece of feedback we received that explains the problem:

I opened the GitHub, saw:

"Dispatch is a platform for developing reliable distributed systems"

and I liked it, got hooked on that.

Then I read that it provides "durable coroutines" and got a bit confused, not sure what that means, but I was thinking maybe it was explained later.

"scheduling of function calls across a fleet of service instances" sounds good, I imagine a bunch of remote machines executing what I need, not sure what Dispatch does, but the idea sounds appealing.

"fair scheduling" sounds cool, but I'm not really sure what it means.

"transparent retry of failed operations", sounds cool, although I'm not sure what "transparent" means here, but interesting.

"durability" I'm not sure what it means, because I think it's about execution and not storing data (as far as I understand), and then I'm not sure what's gonna be durable...

Then there's another term "Stateful Functions", and I'm not sure what that means. Not sure if it's the same as "durable execution semantics" and if that means that "if the function fails with a temporary error, it is automatically retried, even if the program is restarted, or if multiple instances are deployed", but I'm not sure if those concepts are independent or they refer to the same idea in that last phrase.

To address this issue, we should make sure that we always introduce technical terms before using them. Let's also be warry of definitions that rely on other technical terms; the aim is to explain complex concept in simple words so the product value can be communicated to a broad audience.