Skip to content

nabeelbukhari/node-graphql-benchmarks

This branch is 49 commits ahead of, 46 commits behind benawad/node-graphql-benchmarks:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Nabeel Bukhari
Aug 1, 2023
6b042d2 · Aug 1, 2023
Aug 1, 2023
Jul 31, 2023
Aug 1, 2023
Dec 1, 2018
Aug 6, 2022
Nov 24, 2020
Nov 25, 2020
Jul 22, 2023
Sep 11, 2017
Aug 6, 2022
Nov 24, 2020
Nov 16, 2021
Mar 1, 2019
Sep 9, 2017
Sep 9, 2017
Aug 6, 2022
Aug 1, 2023
Jul 19, 2023
Jul 22, 2023
Nov 25, 2020
Aug 1, 2023
Jan 5, 2020

Repository files navigation

TL;DR

  • graphql-jit helps
  • apollo-server adds overhead
  • tracing resolvers kills performance
  • type-graphql adds overhead

Introduction

This is a fork of node-graphql-benchmark repo and has following changes:

  • Changed default setting for benchmark as this repo contains worker-thread examples so it takes more time to start.
  • All benchmarks that perform slower than http server are moved to others folder subfolder of benchmark folder.
  • Fixed bug in go-graphql benchmark and it turns out to be very slow.
  • Dependencies updates
  • For metrics (cold-start) see metrics.md

Explanation

For further details, please check out this video.

Usage

git clone https://github.com/nabeelbukhari/node-graphql-benchmarks
cd node-graphql-benchmarks
npm install
npm start

Benchmarks

machine: Apple M1 with 16 GB RAM duration: 15s connections: 10 pipelining: 1

Server Requests/s Latency Throughput/Mb Memory Usage CPU Usage
uWebSockets-graphql+jit-worker 25778.7 0.01 159.50 Startup: 50.92MB, Max: 607.52MB User: 42478.74 sec(s), System: 5981.34 sec(s)
core-graphql-jit-micro-worker 24418.7 0.01 151.80 Startup: 51.86MB, Max: 601.63MB User: 43302.26 sec(s), System: 5885.66 sec(s)
fastify-graphql-jit-worker 22524.3 0.03 140.92 Startup: 60.91MB, Max: 656.77MB User: 41470.41 sec(s), System: 5872.09 sec(s)
rust-graphql 22171.2 0.05 130.25 Startup: 38.66MB, Max: 39.06MB User: 2.90 sec(s), System: 0.50 sec(s)
fastify-graphql-jit-threads 20465.6 0.03 128.03 Startup: 62.20MB, Max: 406.61MB User: 40679.48 sec(s), System: 6427.14 sec(s)
bun-graphql-jit 17261.3 0.05 107.27 Startup: 29.11MB, Max: 36.34MB User: 4.40 sec(s), System: 2.35 sec(s)
uWebSockets-graphql+jit 11717.1 0.13 72.50 Startup: 52.34MB, Max: 345.77MB User: 26744.50 sec(s), System: 4616.30 sec(s)
mercurius+graphql-jit 11328.3 0.15 70.92 Startup: 75.42MB, Max: 82.33MB User: 13260.18 sec(s), System: 804.50 sec(s)
core-graphql-jit-buf-fjs 10841.9 0.16 67.40 Startup: 58.61MB, Max: 101.97MB User: 27831.61 sec(s), System: 1322.16 sec(s)
core-graphql-jit-buf 10663.2 0.15 66.29 Startup: 52.91MB, Max: 93.36MB User: 27372.09 sec(s), System: 1628.83 sec(s)
core-graphql-jit-str 10602.4 0.15 65.90 Startup: 53.52MB, Max: 100.36MB User: 27487.35 sec(s), System: 1345.96 sec(s)
benzene-jit-http 10397.6 0.18 65.14 Startup: 53.16MB, Max: 97.80MB User: 28704.27 sec(s), System: 1201.85 sec(s)
core-graphql-jit-micro 10356.5 0.20 64.37 Startup: 70.08MB, Max: 100.20MB User: 13791.71 sec(s), System: 681.91 sec(s)
fastify-graphql-jit 10232.9 0.20 64.02 Startup: 79.88MB, Max: 99.59MB User: 13527.90 sec(s), System: 686.47 sec(s)
go-graphql 8606.3 0.71 48.15 Startup: 29.11MB, Max: 36.05MB User: 4.11 sec(s), System: 2.99 sec(s)
mercurius 7223.6 1.13 45.23 Startup: 75.45MB, Max: 106.41MB User: 13792.65 sec(s), System: 668.08 sec(s)
benzene-http 6820.7 1.13 42.73 Startup: 51.78MB, Max: 107.13MB User: 14279.67 sec(s), System: 640.61 sec(s)
fastify-graphql-jit-threads-pool 5515.9 1.34 1.52 Startup: 61.95MB, Max: 322.86MB User: 27729.25 sec(s), System: 1346.91 sec(s)

About

Benchmarks for different Node.js GraphQL Servers

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 93.0%
  • Rust 2.6%
  • TypeScript 2.4%
  • Go 2.0%