Modern microservice systems usually need two traffic-control layers: an API gateway for external client traffic and a service mesh for internal service-to-service traffic. The key implementation decision is not always “service mesh vs API gateway,” but where each one belongs in your architecture.
In this guide, you’ll compare API gateways and service meshes by traffic scope, responsibilities, deployment model, and operational use cases. You’ll also see practical configuration examples and how API design/testing tools like Apidog fit into either approach.
What Is Service Mesh vs API Gateway?
Before choosing a tool, separate the two traffic paths in your system:
- North-south traffic: external clients calling internal services
- East-west traffic: internal services calling other internal services
API gateways primarily manage north-south traffic. Service meshes primarily manage east-west traffic.
What Is an API Gateway?
An API gateway is the single entry point for client requests into your microservices system.
Use it to control how external consumers access your APIs.
Common API gateway responsibilities include:
- Authentication and authorization
- Request routing
- Request aggregation
- Rate limiting and throttling
- Protocol translation, such as REST to gRPC
- API versioning
- Monitoring, logging, and analytics
- Developer portal support
Typical flow:
Client / Mobile App / Partner
|
v
API Gateway
|
v
Internal Services
An API gateway is usually placed at the edge of your system before requests reach internal services.
What Is a Service Mesh?
A service mesh is an infrastructure layer for managing communication between internal services.
Instead of making every service implement networking concerns directly, a service mesh usually uses lightweight sidecar proxies to intercept service-to-service traffic.
Common service mesh responsibilities include:
- Service discovery
- Internal load balancing
- Mutual TLS between services
- Traffic splitting
- Canary releases
- A/B testing
- Retries and timeouts
- Circuit breaking
- Distributed tracing
- Per-service observability
Typical flow:
Service A <--> Sidecar Proxy <--> Sidecar Proxy <--> Service B
A service mesh is most useful when internal service communication becomes difficult to secure, observe, or control manually.
Why the Difference Matters
Choosing the wrong layer creates operational complexity.
Use the distinction to decide where to implement each concern:
- Put external API security at the gateway.
- Put internal mTLS in the mesh.
- Put client-facing rate limits at the gateway.
- Put service-to-service retries and timeouts in the mesh.
- Put developer onboarding and API documentation near the gateway.
- Put distributed tracing and internal traffic policy in the mesh.
Service Mesh vs API Gateway: Key Differences
| Dimension | API Gateway | Service Mesh |
|---|---|---|
| Traffic scope | North-south | East-west |
| Primary users | External clients, partners, frontend apps | Internal services |
| Placement | Network edge | Inside the cluster/service runtime |
| Authentication | API keys, OAuth, JWT | Service identity, mTLS |
| Rate limiting | Common | Sometimes available |
| Request transformation | Common | Not a primary use case |
| Protocol translation | Common | Not a primary use case |
| Service discovery | Basic | Advanced |
| Load balancing | Basic to moderate | Advanced |
| Traffic splitting | Limited to edge traffic | Fine-grained internal traffic |
| Observability | API-level analytics | Per-service metrics and tracing |
| Resilience patterns | Limited | Retries, timeouts, circuit breaking |
| Developer portal | Common | Not applicable |
Where They Overlap
API gateways and service meshes can both support:
- Authentication and authorization
- Routing
- Load balancing
- Observability
- Traffic policy
The difference is the target boundary.
For example:
- An API gateway may validate an external client’s JWT.
- A service mesh may enforce mTLS between
orders-serviceandpayments-service.
They solve related problems at different layers.
When to Use an API Gateway
Use an API gateway when you need to expose services to external consumers.
Common cases:
- Public APIs
- Partner APIs
- Mobile or web app backends
- API monetization
- Centralized authentication
- API key management
- Rate limiting
- API documentation and onboarding
- Request transformation or aggregation
Example architecture:
Mobile App
|
v
API Gateway
|
+--> users-service
+--> orders-service
+--> payments-service
A SaaS product exposing REST APIs to web and mobile clients would typically use an API gateway for authentication, versioning, routing, and usage analytics.
When to Use a Service Mesh
Use a service mesh when internal service communication needs stronger control.
Common cases:
- Many microservices communicating inside Kubernetes
- Service-to-service encryption
- mTLS enforcement
- Canary releases
- Blue-green deployments
- Fine-grained traffic splitting
- Distributed tracing
- Internal retries and timeouts
- Circuit breaking
Example architecture:
orders-service
|
v
payments-service
|
v
billing-service
With a service mesh, these calls can be encrypted, traced, retried, and controlled without each application implementing that logic manually.
When to Use Both
In many production microservice architectures, you use both:
External Client
|
v
API Gateway
|
v
Internal Service A
|
v
Service Mesh
|
v
Internal Service B
A practical split looks like this:
| Concern | Use API Gateway | Use Service Mesh |
|---|---|---|
| External authentication | ✅ | |
| API keys | ✅ | |
| OAuth/JWT validation for clients | ✅ | |
| Developer portal | ✅ | |
| External rate limiting | ✅ | |
| Internal mTLS | ✅ | |
| Service-to-service authorization | ✅ | |
| Internal retries | ✅ | |
| Circuit breaking | ✅ | |
| Canary traffic between services | ✅ | |
| Distributed tracing | ✅ |
This layered approach gives you edge-level control plus internal service reliability.
Practical Examples
Example 1: E-Commerce Platform
Use an API gateway for customer-facing endpoints:
- Login
- Checkout
- Product search
- Partner API access
Use a service mesh for internal calls between:
- Inventory service
- Payment service
- Recommendation service
- Order service
Implementation split:
Customer
|
v
API Gateway
|
+--> checkout-service
|
v
Service Mesh
|
+--> inventory-service
+--> payment-service
+--> recommendation-service
Example 2: API Monetization
Use an API gateway for:
- Developer portal
- API key management
- Usage tracking
- Billing integration
- Client-level quotas
Use a service mesh for:
- Secure billing-service communication
- Internal analytics calls
- Resilient core service communication
Example 3: Canary Deployments
Use an API gateway to route some external traffic to a new API version.
Use a service mesh to manage more granular internal rollout behavior.
Example:
API Gateway:
90% traffic -> v1 API
10% traffic -> v2 API
Service Mesh:
checkout-service -> payment-service-v1: 95%
checkout-service -> payment-service-v2: 5%
Example 4: Protocol Translation
Use an API gateway when external clients need one protocol but internal services use another.
Example:
External REST request
|
v
API Gateway
|
v
Internal gRPC service
The service mesh can still secure and observe internal gRPC traffic, but protocol translation is typically handled by the gateway.
API Gateway Configuration Example
Here is a simplified Kong-style configuration for rate limiting and API key authentication.
apiVersion: configuration.konghq.com/v1
kind: KongIngress
metadata:
name: rate-limited-api
route:
strip_path: true
protocols:
- https
plugin:
- name: rate-limiting
config:
minute: 100
policy: redis
- name: key-auth
config:
key_names:
- x-api-key
This type of policy belongs at the API gateway because it protects external-facing APIs from unauthorized or excessive client traffic.
Service Mesh Configuration Example
Here is a simplified Istio VirtualService for internal routing and retries.
apiVersion: networking.istio.io/v1beta1
kind: VirtualService
metadata:
name: reviews-routing
spec:
hosts:
- reviews
http:
- match:
- sourceLabels:
app: productpage
route:
- destination:
host: reviews
subset: v2
retries:
attempts: 3
perTryTimeout: 2s
retryOn: 5xx
This policy belongs in the service mesh because it controls internal service-to-service behavior.
Implementation Checklist
Use this checklist when deciding what to deploy.
Start With an API Gateway If You Need To
- Expose APIs to public clients
- Authenticate external consumers
- Manage API keys
- Enforce client quotas
- Apply rate limits
- Publish API documentation
- Support API versioning
- Transform requests or responses
- Translate protocols
Add a Service Mesh If You Need To
- Encrypt service-to-service traffic
- Enforce internal service identity
- Add retries and timeouts consistently
- Use circuit breaking
- Perform canary releases between services
- Capture distributed traces
- Improve internal traffic observability
- Manage many microservices at scale
Use Both If You Need Layered Control
A common production setup:
Client
-> API Gateway
-> Kubernetes Service
-> Service Mesh Sidecar
-> Internal Microservice
In this model:
- The gateway manages external API access.
- The mesh manages internal service reliability and security.
Best Practices
Do Not Use a Service Mesh as a Full API Gateway
A service mesh is not designed for external API management features such as:
- Developer portals
- API key onboarding
- Client-facing API documentation
- Protocol mediation for external consumers
- API monetization workflows
Do Not Overload the API Gateway
Some gateways provide mesh-like capabilities, but avoid using the gateway as the main control plane for all internal traffic at scale.
Internal service communication often needs:
- Service identity
- mTLS
- Per-hop retries
- Per-service metrics
- Fine-grained traffic splitting
Those are service mesh concerns.
Apply Security at Both Layers
Use layered security:
External client security:
API Gateway
Internal service security:
Service Mesh
For example:
- Validate external JWTs at the gateway.
- Enforce mTLS between internal services with the mesh.
Design APIs Before Deploying Traffic Policies
Before configuring a gateway or mesh, define:
- API contracts
- Request/response schemas
- Error formats
- Versioning rules
- Authentication requirements
- Test cases
This keeps implementation consistent across gateway-managed APIs and mesh-managed service calls.
Where Apidog Fits
Whether you use an API gateway, service mesh, or both, Apidog can support the API lifecycle around that architecture.
Use Apidog for:
- API design and documentation
- Mocking client-to-service calls
- Testing service-to-service APIs
- Managing API versions
- Collaborating across backend, frontend, and QA teams
For an API gateway workflow, you can design and document APIs before exposing them through the gateway.
For a service mesh workflow, you can model and test internal service contracts before deploying traffic policies such as retries, timeouts, and canary routing.
Conclusion
API gateways and service meshes solve different parts of the microservices networking problem.
Use an API gateway for external API access, authentication, rate limiting, documentation, and protocol handling.
Use a service mesh for internal service communication, mTLS, retries, traffic splitting, and deep observability.
In many modern systems, the best implementation is both: an API gateway at the edge and a service mesh inside the cluster.
Top comments (0)