graphql-batch
RocketJob
Our great sponsors
graphql-batch | RocketJob | |
---|---|---|
3 | 1 | |
1,402 | 289 | |
0.5% | 0.0% | |
5.2 | 6.0 | |
15 days ago | 5 months ago | |
Ruby | Ruby | |
MIT License | Apache License 2.0 |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
graphql-batch
-
The GraphQL N+1 Problem and SQL Window Functions
After recognizing the problem, we brainstormed options to offload some of the work onto the database server to ultimately reduce the Rails application’s memory consumption. One particularly promising avenue involved SQL window functions. After deciding to pursue SQL window functions, we started our work by considering the WindowKeyLoader example described in the graphql-batch repository.
-
N+1 problem will never be an issue with N1Loader gem
Interesting, I've just been researching Dataloader implementations for Ruby and have between trying to decide between GraphQL::Dataloader, graphql-batch and BatchLoader. I'll give this a look as well. Can you also make API calls inside the loaders?
-
"I'm the CTO of a Growing Rails Startup" Ask Me Anything
This is mainly addressed in the last thing but we cache pretty heavily on our REST APIs and for GraphQL we use the graphql-batch gem pretty heavily. Those two things can go a long way. Make sure you're using an APM like Scout to keep an eye on things and then debug the outliers.
RocketJob
-
Delayed Job vs. Sidekiq: Which Is Better?
rocket job is pretty solid too, has a lot of the pro sidekiq features for free https://rocketjob.io/
What are some alternatives?
Sidekiq - Simple, efficient background processing for Ruby
graphql-guard - Simple authorization gem for GraphQL :lock:
graphql-client - A Ruby library for declaring, composing and executing GraphQL queries
Que - A Ruby job queue that uses PostgreSQL's advisory locks for speed and reliability.
GQLi - Ruby GraphQL Client for Humans
BatchLoader - :zap: Powerful tool for avoiding N+1 DB or HTTP queries
moql - Mock GraphQL server for fast reliable integration tests.
Spree Commerce - A headless open source e-commerce platform for global brands
Shoryuken - A super efficient Amazon SQS thread based message processor for Ruby
Delayed::Job - Database based asynchronous priority queue system -- Extracted from Shopify
Resque - Resque is a Redis-backed Ruby library for creating background jobs, placing them on multiple queues, and processing them later.
Karafka - Ruby and Rails efficient Kafka processing framework