guides: Add interceptors (#1267)

This commit is contained in:
Eric Anderson 2024-02-29 13:17:39 -08:00 committed by GitHub
parent 59733711dc
commit d9bbae5fd2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 103 additions and 2 deletions

View File

@ -0,0 +1,100 @@
---
title: Interceptors
description: >-
Explains how interceptors can be used for implementing generic behavior that
applies to many RPC methods.
---
### Overview
The core of making gRPC services is implementing RPC methods. But some
functionality is independent of the method being run and should apply to all or
most RPCs. Interceptors are well suited to this task.
### When to Use Interceptors
You may already be familiar with the concept of interceptors, but may be used to
calling them "filters" or "middleware." Interceptors are very well suited to
implementing logic that is not specific to a single RPC method. They are also
easy to share across different clients or servers. Interceptors are an important
and frequently-used way to extend gRPC. You might find some functionality you
want is already available as an interceptor in the wider gRPC ecosystem.
Some example use cases for interceptors are:
* [Metadata](/docs/guides/metadata/) handling
* Logging
* Fault injection
* Caching
* Metrics
* Policy enforcement
* Server-side Authentication
* Server-side Authorization
{{% alert title="Note" color="info" %}}
While _client-side_ authentication could be done via an interceptor, gRPC
provides a specialized "call credentials" API that is better suited to the task.
See the [Authentication Guide](/docs/guides/auth/) for details about client-side
authentication.
{{% /alert %}}
### How to Use Interceptors
Interceptors can be added when building a gRPC channel or server. The
interceptor is then called for every RPC on that channel or server. The
interceptor APIs are different for client-side than server-side, so an
interceptor will either be a "client interceptor" or a "server interceptor."
Interceptors are inherently per-call; they are not useful for managing TCP
connections, configuring the TCP port, or configuring TLS. While the proper tool
for most customization, they can't be used for everything.
#### Interceptor Order
When using multiple interceptors, their order is significant. You'll want to
make sure to understand the order your gRPC implementation will execute them. It
is useful to think about the interceptors as being in a line between the
application and the network. Some interceptors will be "closer to the network"
and have more control over what is sent and others will be "closer to the
application" which have a better view into the application's behavior.
Suppose you have two client interceptors: a caching interceptor and a logging
interceptor. What order should they be in? You might want the logging
interceptor closer to the network to better monitor your application's
communication and ignore cached RPCs:
```mermaid
flowchart LR
APP(Application) --> INT1
INT1(Caching\nInterceptor) -->|Cache miss| INT2
INT2(Logging\nInterceptor) --> NET
NET(Network)
```
Or you might want it closer to the application to understand your app's behavior
and see what information it is loading:
```mermaid
flowchart LR
APP(Application) --> INT2
INT1(Caching\nInterceptor) -->|Cache miss| NET
INT2(Logging\nInterceptor) --> INT1
NET(Network)
```
You can choose between these options by just changing the order of the
interceptors.
### Language Support
| Language | Example |
|----------|------------------|
| C++ | [C++ example] |
| Go | [Go example] |
| Java | [Java example] |
| Python | [Python example] |
[C++ example]: https://github.com/grpc/grpc/tree/master/examples/cpp/interceptors
[Go example]: https://github.com/grpc/grpc-go/tree/master/examples/features/interceptor
[Java example]: https://github.com/grpc/grpc-java/tree/master/examples/src/main/java/io/grpc/examples/header
[Python example]: https://github.com/grpc/grpc/tree/master/examples/python/interceptors

View File

@ -62,7 +62,8 @@ client. The header includes things like authentication credentials and how to
handle the RPC. Some of the headers, such as authorization, are generated by
gRPC for you.
Custom header handling is language dependent, generally through interceptors.
Custom header handling is language dependent, generally through
[interceptors](/docs/guides/interceptors/).
#### Trailers
@ -115,4 +116,4 @@ the server.
[Python Metadata]: https://github.com/grpc/grpc/tree/master/examples/python/metadata
[Go Documentation]: https://github.com/grpc/grpc-go/blob/master/Documentation/grpc-metadata.md
[Go Documentation]: https://github.com/grpc/grpc-go/blob/master/Documentation/grpc-metadata.md