Varun Srinivasan pfp
Varun Srinivasan
@v
We're starting to think about a new sync model for Farcaster. The current system works but is unlikely to scale up another 10x. Here's our articulation of the problem we want to go after.
14 replies
22 recasts
131 reactions

Alberto Ornaghi pfp
Alberto Ornaghi
@alor
re Pruning: does pruning generate diff syncs between hubs? if so, why? do we need pruning to be in sync? if we only prune very old data, can we let it up the single hub instance the choice to delete them when they want? I don't see the need to sync pruning between all hubs
1 reply
0 recast
1 reaction

Varun Srinivasan pfp
Varun Srinivasan
@v
Pruning changes the state of the “bag” of deltas So if I’m comparing my deltas with you and you have pruned differently we won’t be in sync
1 reply
0 recast
1 reaction

Alberto Ornaghi pfp
Alberto Ornaghi
@alor
what I'm proposing is that pruning does not change the bag of deltas. what's the issue if one hub has performed pruning already and another one still have to perform it? those are old data and different hubs my decide to keep old data for longer periods. up to them to pay for the extra storage. imho not a big deal if the state is not in sync on old data. it's crucial on new one, but old data can be left there even not in sync. since hubs don't deny casting if you are over the quota (just delete the old data to make room for the new one), I don't see the reason to be in sync with that part.
1 reply
0 recast
1 reaction

Varun Srinivasan pfp
Varun Srinivasan
@v
it's important that all hubs have the same state and don't make different decisions on what data is held. it would be very annoying if you logged onto warpcast and it had a different history than when you logged on to supercast.
1 reply
0 recast
0 reaction

Alberto Ornaghi pfp
Alberto Ornaghi
@alor
For very old data (that is basically never seen by users using the app) it’s a requirement too strict imho. Who’s gonna see the difference in a thread one year or two year old? There could be different client that will keep the history forever (some use asked for it a while ago) so I don’t see it as a problem. I agree with you for new data. But old history can be treated differently without big consequences.
1 reply
0 recast
1 reaction

Varun Srinivasan pfp
Varun Srinivasan
@v
this makes sync harder, not easier. example - if i issue a delete command for an old message, how does my hub know who to propagate it to? some hubs have that message and will accept it, other hubs will consider the delete invalid and wont propagate it. this will lead to more inconsistencies, not less.
1 reply
0 recast
0 reaction

Alberto Ornaghi pfp
Alberto Ornaghi
@alor
It’s the same as if you issue a delete on a new message now already synchronized with all hubs. Delete wins over add. And you forward the message. No need to have the message to consider it valid. Btw if all the hubs have the same pruning threshold the state will eventually be consistent. No need to propagate diffs If all hubs expire the same data. There isn’t a single one that should alert the other to expire data.
1 reply
0 recast
0 reaction

Alberto Ornaghi pfp
Alberto Ornaghi
@alor
*not already synchronized
1 reply
0 recast
0 reaction

Varun Srinivasan pfp
Varun Srinivasan
@v
let me zoom back out a bit. the core of the problem is that state changes happen in millions of individual bits thanks to how consistency works. it's really hard to keep up with individual changes because there are so many and so frequent.
2 replies
0 recast
0 reaction