Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

API & dashboard showing RSR for HTTP retrievals (HTTP-RSR) #192

Closed
5 tasks done
Tracked by #181 ...
bajtos opened this issue Nov 18, 2024 · 0 comments
Closed
5 tasks done
Tracked by #181 ...

API & dashboard showing RSR for HTTP retrievals (HTTP-RSR) #192

bajtos opened this issue Nov 18, 2024 · 0 comments
Assignees
Labels

Comments

@bajtos
Copy link
Contributor

bajtos commented Nov 18, 2024

At the moment, Spark RSR is defined as how many retrievals succeeded using HTTP or Graphsync protocol for CAR transfer.

Let's add another RSR (HTTP-RSR) defined as follows: how many retrievals succeeded using HTTP protocol for CAR transfer. (A retrieval that had to use Graphsync because the SP does not advertise HTTP is considered as a failure.)

We should provide all usual flavours for this RSR:

  • Network-wide RSR from all measurements
  • Network-wide RSR using only measurements targeting miners with non-zero HTTP-RSR rate
  • Per-miner RSR

What are the benefits:

  • Spark v2 will support only HTTP, not Graphsync. The new HTTP-RSR score will show us the gap - how bad the breaking change between Spark v1 and v2 will be. (Note that this does not paint the full picture as there will be more breaking changes between Spark v1 and v2.)
  • Spark RSR consumers like the FIL+ Allocator Compliance process can start issuing a warning to SPs that don't offer HTTP retrievals. They can even decide to switch from the current RSR to HTTP-RSR in the future.

Why I want to keep the current RSR around:

  • Don't break our chart showing how Spark drove improvements in the RSR over time.
  • Avoid breaking changes to consumers. Let them decide the right time to switch and how to make the switch least disrupting to their users.

/cc @willscott, you were interested in having this data

Tasks

Note: We already collect "successful" and "total" retrieval checks. RSR is calculated as successful/total. HTTP-RSR calculation can use the same "total" field; we need to add a new field called e.g. "successful_http". HTTP-RSR is then calculated as sucessful_http/total.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants