Docs
Launch GraphOS Studio

Does Apollo Router replace my API gateway?

federationroutergateway

Apollo Router is a high-performant GraphQL gateway that supports Apollo Federation. It handles GraphQL requests that can then be resolved by many GraphQL subraphs underneath. When comparing to other API technologies in the market today, a natural first comparison to draw is to API gateways. Tools like Apigee, Kong, or your cloud provider offer capabilities to secure, manage, and monitor your API endpoints. These gateways usually live at the outermost edges of your companies infrastructure. Sometimes they are even required by your security team so that all inbound and outbound traffic flows through the same top layer of your tech stack.

The key distinction of the is that is not based on URLs or REST endpoints; Apollo Router is a GraphQL-native solution to handle your clients API s.

GraphQL native

First, let's define what we mean by "GraphQL native". Apollo runs all the client s against a supergraph. This means that requests processed by the are not for any random service, but are restricted to what is defined and published by the GraphQL subgraphs for a given . s define the schema and capabilities they want to expose. A well-defined GraphQL schema does not just expose all the data available in a company, instead, a demand-oriented schema gives clients access to all the s they need to execute, but without over exposing your data. Since s are also the ones that define their service capabilities, the can be the central location to enforce standardized rules or policies that are declared by subgraphs, for example, a directive-based authN/Z plugin.

type Query {
bankAccounts: [BankAccount] @authenticated @hasRole(role: ADMIN)
}

API gateways usually have no understanding of all the services underneath them or what their capabilities are. They may have configuration options and rules that can apply to a list of services, but these are blanket rules that must be configured at the gateway level, not at the service definition. If you wanted to apply a common rule across many services it would be up to the API gateway managers to configure, deploy, and apply that new rule to a set of services rather than the individual service teams.

# Mock gateway rules
gatewayConfig:
myCustomRule:
tags: [requiresAuth]
ruleToApply: validate-jwt-plugin
myOtherCustomRule:
URL: "/accounts"
ruleToApply: requires-admin-permissions-plugin

Support for non-GraphQL APIs

GraphQL is an innovative technology that give clients much more control over their s and a common language for service teams to communicate. However, GraphQL usually is not the one and only API technology used by companies today. If you need to have a common gateway to secure REST endpoints and GraphQL endpoints, Apollo can be a complimentary tool that lives underneath this higher-level API gateway. You can configure company-wide policies at the outermost edge layer, and anything else that is better defined as a GraphQL-specific policy can be managed by the Router. In addition, using a defense-in-depth security strategy reduces your companies risk, so having both an API gateway and applying shared rules can lead to a more secure environment.

Data Layer
GraphQL
Edge
Partners
Clients
REST1
REST2
gRPC1
DB1
DB2
Router
Subgraph1
Subgraph2
API-Gateway
Partner1
Partner2
Client1
Client2
Client3

When to consider Apollo Router

If you are running a GraphQL API in production, and you want to be able to:

And do all of this with minimal latency and scalable performance then consider adopting GraphOS and Apollo Router today!

Next
Home
Edit on GitHubEditForumsDiscord