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

Document suggested IPNS Entry TTL default #371

Merged
merged 2 commits into from
Oct 3, 2023
Merged

Conversation

hacdias
Copy link
Member

@hacdias hacdias commented Jan 25, 2023

Initial context: ipfs/interface-go-ipfs-core#94 (comment).

Currently, the default IPNS Entry TTL is hard coded to 1 minute. 1 minute is a very short duration for TTL. For DNS, 12 and 24 hours are very common TTL values. If we have a low value from the start, there is barely any performance improvement by setting a TTL manually, since no one is going to manually set it for a larger value.

With this PR, we would like to add a suggested default of 12 hours. If the user (publisher of the website), requires more frequent updates, they can always use the --ttl flag in ipns name publish to override the default.

@hacdias
Copy link
Member Author

hacdias commented Feb 14, 2023

Ping @lidel. It's been 3 weeks since I opened this and there hasn't been any comments, so I think it would be fine to merge.

@hacdias hacdias force-pushed the new-ipns-ttl-default branch from f7f0e82 to 8b1c259 Compare March 16, 2023 10:20
@hacdias
Copy link
Member Author

hacdias commented Mar 27, 2023

ping @lidel

ipns/IPNS.md Outdated
- Implementations MUST include this value in both `IpnsEntry.ttl` and inside the DAG-CBOR document at `IpnsEntry.data[ttl]`.
- Suggested default: 12 hours (43 200 000 000 000 nanoseconds).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@hacdias do you remember why we picked 12h? Was it chosen because it was the Reprovider.Interval in Kubo?
Is 12h implemented anywhere atm?

Since then, we've increased Reprovider.Interval to 22h and expiration of DHT records to 48h (ipfs/kubo#9389, ipfs/kubo#9326). The more special numbers we invent, the harder it will be to debug.

I wonder if we should park this until we have time to evaluate, maybe when we work on #376?

I suspect default closer to 15m or 1h will be safer.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@lidel the context was DNS, since IPNS Entry and DNS have similar purposes:

For context, when you add DNS record at many registrars, the default TTL for DNS records is either 12 hours or 1 hour, and is lowered manually by the user to 1 minute only for websites which need fast updates.

Copy link
Member

@lidel lidel Mar 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Right. I think I know why 12h made me unease. The concern is around end user UX:

  • User is publishing record with TTL 12h
  • Loads /ipns/{id} on gateway, record gets cached with TTL 12h
  • User complains IPNS update propagation is slow, realizes they can set custom TTL, they do it, but need to wait 12h for update to be in effect, and are stuck with old response.

I think the same UX papercut applies to DNS. I did some spelunking around default TTL in DNS, and higher TTL is used only for things like NS records and roots of TLDs like com or org. Regular websites have TTL of 1h or less.

Some interesting links:

In IPNS all websites are final names, so maybe something closer to 5m-15m-60m may be safer default? Allows for caching, but does not cause stale websites for entire day.

(will ping some folks from ecosystem for feedback)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Then perhaps I would suggest 1 hour. If we set it too low, a user will never need to change it, so there is no big benefit of even having a TTL. And if we set it too high, we have the problem you just mentioned.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My revised understanding is that TTL in IPNS and DNS serve the same purpose: it is a hint about how long a resolution result can be cached on the client, or any intermediate software, before checking for updates.

The difference is that for end user "publishing update" has different impact.
IPNS record update serves the same purpose as (DNS || HTTP) update.

In other words, the TTL for DNS can be higher, but it does not impact end user UX most of the time, because for the most of the time, publishing content update happens on HTTP server. TTL on DNS A record can be 24h, but HTTP server may return Cache-Control which acts as secondary TTL, and HTTP cache could expire faster (e.g. minutes), and Last-Modified header which asks browser to do heuristic caching.

In IPNS, publishing record is the same as publishing content update, which means slower propagation (stale result cached on gateway) will be more noticeable.

To mitigate negative effect on end user, we could:

  • pick a lower default TTL (1h, 15m, 5m, or even keep 1m)
  • make namesys cache behavior be "stale-while-revalidate" to avoid latency spikes on gateways when TTL expires
    • i think we can do this, because IPNS record has separate expiration field, and as long validity check passes, we can return stale record

Probably good topic to discuss during IPFS Thing in hallway track

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's then discuss it during IPFS Thing. I agree we should choose a lower default, but not too low (5m or 15m maybe).

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should strongly push for/towards making TTL mandatory as publishers typically know about the nature of their content and it does not make sense for the network stack to guess it.

Picking a (somewhat) higher default is in the network's interest and will incentivise publishers to think about TTL's (e.g. for more frequently updated content). Picking too high a value and we might get stale content (e.g. no providers online) and/or bloated caches.

Also note that records might get updated regardless of TTL as updates propagate throughout the network, especially for nodes with a higher centrality. It might even make sense for nodes to be pro-active in propagating updates (e.g. I was caching this so it's probably also relevant to peers).

Concretely, I'd suggest at least 1h and ideally 1d defaults, adding to the docs that frequently updated content should set a lower value. I think more than 1d doesn't make sense cache-wise and less than 1h makes the cache much less useful.

Perhaps we should also consider whether IPNS as it currently stands is indeed the correct mutability framework particularly for frequently updated content (e.g. write-heavy databases). That is: is IPNS future-proof? If not, what is necessary to get there and what would be a realistic roadmap there? Based on that, perhaps it makes sense to map out suitable and less-suitable use cases, which might inform (more) sensible decisions.

@lidel lidel marked this pull request as draft March 29, 2023 00:03
@hacdias hacdias force-pushed the new-ipns-ttl-default branch from 8b1c259 to ec6778f Compare April 5, 2023 08:15
@hacdias hacdias changed the title docs: add suggested default 12h for IPNS Entry TTL Add suggested IPNS Entry TTL default Apr 5, 2023
@hacdias hacdias changed the title Add suggested IPNS Entry TTL default Document suggested IPNS Entry TTL default Apr 5, 2023
@hacdias
Copy link
Member Author

hacdias commented Apr 5, 2023

I rebased the PR to make sure it's in sync and changed the status to "blocked" so we discuss it during IPFS þing.

@BigLep
Copy link
Contributor

BigLep commented Apr 6, 2023

I rebased the PR to make sure it's in sync and changed the status to "blocked" so we discuss it during IPFS þing.

@hacdias : is there an established forum at IPFS Thing where this is going to be discussed, or do we need to set something up. I'm just making sure that the conversation we want to have happen actually hapens.

@lidel
Copy link
Member

lidel commented Apr 11, 2023

If time allows, I think we will create an unconf session on Tue or Wed to discuss what the default TTL should be in boxo/ipns + optionally other IPNS-related topics.

FYI there are three "big" IPNS topics I am aware of:

From these, TTL is the only one that could be realistically answered during IPFS Thing.

@hacdias hacdias force-pushed the new-ipns-ttl-default branch from ec6778f to f7c35a7 Compare October 3, 2023 12:24
@hacdias hacdias requested review from lidel and dokterbob October 3, 2023 12:24
@hacdias hacdias marked this pull request as ready for review October 3, 2023 12:24
@hacdias
Copy link
Member Author

hacdias commented Oct 3, 2023

I rebased this and I'm re-opening this. We did not end up discussing this during IPFS Thing, but many changes have happened in the meanwhile, so maybe we can now come up with a suggestion. It is a suggestion, after all, not a must. I have also changed the suggested default to 1 hour based on the discussions above.

@hacdias hacdias force-pushed the new-ipns-ttl-default branch from f7c35a7 to 942569e Compare October 3, 2023 12:27
src/ipns/ipns-record.md Outdated Show resolved Hide resolved
src/ipns/ipns-record.md Show resolved Hide resolved
@hacdias hacdias merged commit 7a4e220 into main Oct 3, 2023
2 checks passed
@hacdias hacdias deleted the new-ipns-ttl-default branch October 3, 2023 14:32
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Ratified
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants