Docs
Launch GraphOS Studio

Setting up a self-hosted supergraph

Host your enterprise router in your own infrastructure


Self-hosted supergraphs are an Enterprise feature for organizations with advanced performance or compliance requirements.

If your organization might benefit from Enterprise features, please get in touch with us!

This tutorial gets you up and running with and a self-hosted . If your organization doesn't currently have an Enterprise plan and you want to test out this functionality, sign up for a free Enterprise trial.

Important: This tutorial uses Docker for containerization of your 's .

Supergraph concepts

Before we get started, let's quickly cover what a self-hosted is.

A supergraph combines multiple GraphQL APIs into a single unified GraphQL service. The individual APIs in a are called subgraphs:

Supergraph
Router
Subgraph A
Subgraph B
Subgraph C
Clients

A separate service called the router sits in front of your s and provides the publicly accessible endpoint for your . Clients query the , which distributes each query across the appropriate combination of s and returns the combined result.

The uses a special GraphQL called the supergraph schema. This incorporates the types and s in each , along with metadata that enables the to correctly distribute queries across s.

A self-hosted supergraph is a with a that you host and manage in your own infrastructure. This is in contrast to a cloud supergraph, which uses a that's hosted and managed by Apollo.

We'll cover these concepts in more detail as we proceed through the steps below.

1. Set up Apollo tools

This quickstart uses the following Apollo tools:

  • GraphOS Studio. This is the primary web interface for . Studio helps you monitor, manage, and collaborate on your .
  • The Rover CLI. This is the primary command-line interface for . helps you interact with your graphs and their s.

Let's set these up first.

Create an Apollo account

To manage our with , we need an Apollo account. Let's create one if you don't have one yet.

Complete the first step of Get started with GraphOS (Create your Apollo account), then return here.

Create a graph in GraphOS Studio

After you create your Apollo account, create your first graph in Studio by following the instructions for your organization's plan type:

Install the Rover CLI

Rover is Apollo's CLI for managing all kinds of graphs, including s and s. We'll use it throughout this quickstart.

Even if you already have installed, you should update your version now by completing this step.

Install the latest release with the appropriate command for your system:

Mac/Unix
curl -sSL https://rover.apollo.dev/nix/latest | sh
Windows
iwr 'https://rover.apollo.dev/win/latest' | iex

After installing, run rover in your terminal with no s to confirm that it installed successfully. Verify that the printed version number matches the latest full release (if it doesn't, you might need to manually delete a previous outdated installation).

Authenticate Rover with GraphOS

We'll use to publish our s to . To do that, we first need to authenticate with .

Complete the first two steps of Configuring Rover (Obtain an API key and Provide the API key to Rover), then return here.

2. Clone the router project template

For this quickstart, we'll use some Apollo-hosted example services as our s, and we'll set up the Apollo Router in front of them. The Apollo is a high-performance, precompiled Rust executable that acts as the for a .

First, let's create a project directory for your :

  1. Open this GitHub template. It provides out-of-the box configuration for deploying and running the Apollo via a Dockerfile.
  2. On the template page, click Use this template > Create a new repository to copy the template into a new repository in your GitHub account.
    • If you don't use GitHub, you can instead clone the template directly via the Code menu.
  3. Clone your new repository to your local machine.

3. Start the router with Docker

To run the Apollo locally, you need a way to build and run containers. Here are some popular options:

This tutorial uses the docker command. Alternative commands usually look similar.

Try building and running your container:

docker build -t router .
docker run -it -p4000:4000 router

When you do, you'll get a startup error message like the following:

That's because we aren't currently providing a supergraph schema to the ! We'll fix that soon.

3. Obtain your subgraph schemas

This quickstart uses two Apollo-hosted s (named locations and reviews) from an imaginary space tourism application called FlyBy. Here are their URLs and s for reference:

If you have your own existing s that you want to use instead of these examples, feel free! Provide their names and URLs wherever you see the example s used in the steps below.

To compose a for our , needs the following information about each of our subgraphs:

  • The 's
  • The URL of the 's GraphQL endpoint (which must be accessible by the )

Fortunately, we have all of this information! Let's send it to .

4. Publish your subgraph schemas

Because we've already configured the CLI, we can now use its subgraph publish command to publish our s to .

In GraphOS Studio, click the graph you created back in the first step. Because we haven't published any s to it yet, the following dialog appears:

Schema registration options

To publish our , we'll first use to introspect the running , then pass the obtained to subgraph publish.

  1. Paste the following multi-line command into your terminal, but don't run it—you need to modify it first.

    rover subgraph introspect https://flyby-locations-sub.herokuapp.com/ | \
    rover subgraph publish --name locations \
    --routing-url https://flyby-locations-sub.herokuapp.com/ \
    --schema - <GRAPH_REF>
  2. In your terminal, replace the final value <GRAPH_REF> with the appropriate value for your graph. In the screenshot above, this value is MyGraph-1ncyus@current, but your value will be different.

  3. Run the modified command.

    • If the command is successful, you'll see output like the following:

      A new subgraph called 'locations' was created in 'docs-example-graph@main'
      The supergraph schema for 'docs-example-graph@main' was updated, composed from the updated 'locations' subgraph
    • If the command fails, make sure you've authenticated Rover with GraphOS. All commands that interact with require a valid API key.

    If you open your graph's details in Studio now, you'll see types and s from the locations listed on the page:

    locations subgraph schema in Studio
  4. Do the same thing for the reviews , again substituting your graph ref:

    rover subgraph introspect https://flyby-reviews-sub.herokuapp.com/ | \
    rover subgraph publish --name reviews \
    --routing-url https://flyby-reviews-sub.herokuapp.com/ \
    --schema - <GRAPH_REF>

    You only need to provide a 's --routing-url the first time you publish that 's to a particular (unless you need to change that URL later).

    If you refresh the page in Studio, you'll now see types and s from the reviews as well.

Every time we publish a , automatically composes all of our s into a supergraph schema! However, our isn't yet fetching that from Apollo. We'll tackle that next.

5. Connect the router to GraphOS

It's time to enable our to fetch its from . To do that, we need a graph API key that we set as the value of an environment .

We recommend that you create a separate API key for each system that communicates with . This reduces the impact whenever you need to replace an API key that might be compromised.

  1. Obtain a graph API key for your Studio graph by following these steps:

    If you have an Enterprise plan, set the API key's role according to the following:

    • If your will use a protected variant, choose Graph Admin.
    • Otherwise, choose Contributor.

    Make sure to copy and paste the API key's value somewhere so you can reference it (for security, API keys are not visible in Studio after creation).

  2. Create a file called .env in your project and paste in the following (replace <API_KEY> with your graph API key and <GRAPH_REF> with your graph ref):

    APOLLO_KEY=<API_KEY>
    APOLLO_GRAPH_REF=<GRAPH_REF>

    ⚠️ API keys are secret credentials. Never share them outside your organization or commit them to version control. Delete and replace API keys that you believe are compromised. Make sure always to add .env files to your .gitignore file (the template project already does this).

  3. Paste this command into your terminal and run it:

    docker run -it --env-file .env -p4000:4000 router

    This time there's no error, and you'll see output similar to the following (timestamps omitted for brevity):

    By providing an API key to the , you also automatically enable operation metrics reporting to , enabling you visualize your graph's performance. Learn more about metrics.

Now that our is running, we can quickly open our browser to localhost:4000 to explore our composed in Apollo Sandbox:

Schema view in Apollo Sandbox

While we're here, execute some test queries against the ! We'll look at metrics for those test queries in the next step.

6. View operation metrics

Because our is connected to , it automatically collects and reports metrics on incoming s. You can then visualize those metrics in Studio.

Return to GraphOS Studio and go to your 's s page, which looks like this:

The Operations page in Studio after executing an operation

The test queries you executed in the previous step should already be represented on this page! (If they aren't there yet, check the page again in a few minutes.) After you update all of your clients to query your , the s page becomes vital to monitoring your 's performance.

7. Deploy your router and connect clients

Now that our is running successfully in our development environment, we can deploy it to our preferred platform (AWS, Google Cloud, etc.) so clients can begin querying it!

The exact details for deploying the depend on which platform you use, but these high-level steps hold true for most platforms:

  1. Build the Docker image in CI and push it to a container (some providers let you skip this step).

  2. Deploy the image to your preferred platform (there are additional resources for Kubernetes deployments).

  3. Set the APOLLO_KEY and APOLLO_GRAPH_REF environment s in the 's deployment environment, as we did locally in this step.

    • Keep in mind that APOLLO_KEY is a secret, so use an appropriate mechanism for storing it in your deployment environment.
  4. If your platform expects the to listen on a particular port, set this port in the router.yaml file included with the template:

    router.yaml
    supergraph:
    # The socket address and port to listen on
    listen: 127.0.0.1:4000
    # OR if the port is specified via environment variable
    listen: 127.0.0.1:${env.PORT}

After you successfully deploy your , it's ready to start receiving client s! If you have any existing client applications that connect directly to your GraphQL API, you can update their GraphQL endpoint URL to your router's URL.

Similarly, any new client applications should use your 's URL.

⚠️ Important considerations:

  • For browser-based clients, make sure their origin is allowed in your 's CORS rules, which you can set in the 's YAML configuration file.
  • Only update clients that communicate with the correct instance of your GraphQL API! For example, if your API has staging and production instances, only update clients that communicate with the instance used by this .

Next steps

Nice work! We've registered two subgraph schemas with , and we've set up a router that fetches its composed supergraph schema so it can execute s across s.

If we now publish changes to one of our s, our running automatically fetches the corresponding changes to the (assuming composition succeeds).

Next, we'll cover some of the most common and important actions to perform on your new , including:

  • Updating s
  • Adding another
  • Setting up

Go to next steps.

Previous
Cloud setup
Next
Next steps
Edit on GitHubEditForumsDiscord