Skip to content
This repository has been archived by the owner on Sep 1, 2022. It is now read-only.

craigmulligan/clementine

Repository files navigation

Clementine 🍊

A self-hosted Graphql Analytics and Observability Platform

Most analytics tools don't work well for graphql because they are tuned for standard REST based services. Clementine aims to provide a simple way to understand the performance of your graphql server. Allowing you to quickly find your slowest queries and bottleneck resolvers. Its simple to install and has drop in support for graphql servers that support Apollo Tracing format.

Note: Clementine only implements a subset of Apollo Graph Manager features, if you can afford it you should just use their service.

Warning! Clementine is still alpha software. You can try on the demo. But you should really run your own instance if you care about uptime or reliability.

Features

Find Operations by Popularity, Latency, Error count and Error rate. Operation List
Requests and operations over time. Requests overtime
Latency distribution of all requests or specific operations. Latency Distribution
Global Filters. Global Filters
Resolver level timings of for each Trace. Resolver waterfall

Running an instance

Add all required environment variables in .env.

Then for development:

make dev

Then visit http://localhost:80

Or for production:

make start

Or for production with letsEncrypt

make start_with_ssl

Getting Started

First thing we need to do is create a graph and an ApiKey so you can start storing traces from your graphql server.

Create a graph

Once you have a clementine instance running. Login in through the dashboard and create a new graph.

Create a graph

Then navigate to the graphs settings page and create an apiKey.

Create a graph apiKey

We only store a hash of the key so make sure you copy it down.

Configure your server

Now configure your server to send traces to clementine.

This is what it looks like with ApolloServer:

const { ApolloServer } = require('apollo-server')

const server = new ApolloServer({
  typeDefs,
  resolvers,
  engine: {
    apiKey: '<YOUR-API-KEY-HERE>',
    endpointUrl: 'https://<YOUR-CLEMENTINE-HOST>'
  }
})

server.listen().then(({ url }) => {
  console.log(`πŸš€ Server ready at ${url}`)
})

Now run some queries and the them populate in the clementine dashboard.

graph list

Forwarding traces to Apollo Graph Manager.

If are trailing clementine and want to forward your traces to Apollo you can pass both the apolloKey and the clementineKey seperated by a ?. For example:

const { ApolloServer } = require('apollo-server')

const server = new ApolloServer({
  typeDefs,
  resolvers,
  engine: {
    apiKey: '<YOUR-CLEMENTINE-API-KEY-HERE>?<YOUR-APOLLO-API-KEY>',
    endpointUrl: 'https://<YOUR-CLEMENTINE-HOST>'
  }
})

server.listen().then(({ url }) => {
  console.log(`πŸš€ Server ready at ${url}`)
})

Road Map

  • Team/Org support.
  • Add error distribution views.
  • helm chart

About

A self-hosted Graphql Analytics and Observability Platform

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published