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

bug: optimize filter registrations to avoid some issues noticed #5262

Closed
Tracked by #219
chaitanyaprem opened this issue May 30, 2024 · 6 comments
Closed
Tracked by #219

bug: optimize filter registrations to avoid some issues noticed #5262

chaitanyaprem opened this issue May 30, 2024 · 6 comments
Assignees
Labels
E:Mobile release 2.30 status-waku-integ All issues relating to the Status Waku integration.

Comments

@chaitanyaprem
Copy link
Contributor

chaitanyaprem commented May 30, 2024

Problem

While dogfooding #4665 with status-desktop, i had noticed few issues that need to be addressed.

  1. Sometimes, filters are registered before there is any peer connectivity which causes them to fail. Since error is not propagated all the way up the stack from where these are installed, there is no retry and app gets stuck in a weird state. Only workaround is to restart the app to regain connectivity.
  2. Few times i had noticed that app loading takes a lot of time. This is because if the user is a member of a community, then a lot of filters would be installed which are done in sequence. Since this involves network calls to 2 peers per filter, the loading takes almost few minutes which is a very bad user experience.

Implementation

Following approach would solve both the problems and also address the issue #4526
Solution is as below:

  1. Do filter registrations async i.e filter-manager to accept any filter install and queue them.
  2. Batch the filter subscriptions and group them(subscriptions in a pubsubTopic) into a max of 100 contentTopics to reduce number of actual filter subscriptions. This would reduce number of subscriptions. This would then have a side-affect that when a filter is uninstalled, we need to remove that specific subscription(To analyze).
  3. Note to also have a small batch timer so that subscriptions are not queued for too long.
  4. If no peers are available when a subscription is requested, keep it queue and proceed only if there are filter peers available in peerStore (Note we need to consider peers supporting a specific pubsubTopic for this)

Acceptance Criteria

Need to validate all Filter test cases along with dogfooding lightClient.

cc @richard-ramos @vitvly @cammellos : Do review the above and provide any feedback/suggestions.

@weboko @danisharora099 : This might be something that is useful in js-waku Filter-SDK as well.

@chaitanyaprem chaitanyaprem self-assigned this May 30, 2024
@chaitanyaprem chaitanyaprem added the status-waku-integ All issues relating to the Status Waku integration. label May 30, 2024
@vitvly vitvly mentioned this issue May 31, 2024
1 task
@danisharora099
Copy link

Oh, this is interesting for js-waku indeed.
Thanks @chaitanyaprem for documenting this.

I noticed something similar when working on introducing peer management for LightPush, but this is directly applicable for Filter as well:
I was thinking of introducing automated retries into the SDK where the SDK .send() would attempt at finding a peer for the request, if doesn't exist already, and then send the peer. In a case where, even upon a forced find of peers, no peers are found, we will simply return with an error code communicating that no peers were found.

I'm curious: in your approach where you queue these requests, do you block the initial library consumer's function invocation, of for example the .subscribe()? Does it wait to be resolved?

cc @weboko

@chaitanyaprem
Copy link
Contributor Author

I'm curious: in your approach where you queue these requests, do you block the initial library consumer's function invocation, of for example the .subscribe()? Does it wait to be resolved?

I did not think of reporting failure back to caller as of now. But rather i am expecting SDK to keep retrying internally.
But yeah, this is something that needs to be thought of. Maybe some sort of a callback can be invoked in case such things fail even after retry.
At this point i am not sure, because there are factors such as what if the node itself lost connectivity and hence subscribe keeps failing.

@chaitanyaprem
Copy link
Contributor Author

Filter subscription async and queuing subscriptions when no connectivity is there(Points 1 & 4 above), are implemented as part of 817e959

Others will be taken up in a separate PR.

@chaitanyaprem
Copy link
Contributor Author

Batching of subscriptions may not be required unless we start seeing an issue.
Because this only impacts the lightClient that has to maintain and manage these subscriptions. To a serviceNode, it doesn't matter how many subscriptions a peer has it still considers them as a single one.

The only possible challenge i see at this point with not batching them could be in case the serviceNode starts rate-limiting filter-subscribe requests which would then start failing.

@chaitanyaprem
Copy link
Contributor Author

This is being taken up now since it is causing delay and bloat of subscriptions.
And #5421 will take time to implement.

@chaitanyaprem
Copy link
Contributor Author

Closing as completed as part of #5440

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
E:Mobile release 2.30 status-waku-integ All issues relating to the Status Waku integration.
Projects
None yet
Development

No branches or pull requests

2 participants