<ph type="x-smartling-placeholder"></ph>
Vous consultez la documentation Apigee Edge.
Accédez à la page
Documentation sur Apigee X. En savoir plus
Cet article décrit les propriétés de transport qui peuvent être définies dans les configurations TargetEndpoint et ProxyEndpoint pour contrôler le comportement de la messagerie et de la connexion. Pour une couverture complète des configurations TargetEndpoint et ProxyEndpoint, consultez la documentation de référence sur la configuration de proxy d'API.
Propriétés de transport TargetEndpoint
L'élément HTTPTargetConnection des configurations TargetEndpoint définit un ensemble des propriétés de transport. Vous pouvez utiliser ces propriétés pour définir des configurations au niveau du transport.
Les propriétés sont définies sur les éléments HTTPTargetConnection de TargetEndpoint comme indiqué ci-dessous :
<TargetEndpoint name="default"> <HTTPTargetConnection> <URL>http://mocktarget.apigee.net</URL> <Properties> <Property name="supports.http10">true</Property> <Property name="request.retain.headers">User-Agent,Referer,Accept-Language</Property> <Property name="retain.queryparams">apikey</Property> </Properties> <CommonName>COMMON_NAME_HERE</CommonName> </HTTPTargetConnection> </TargetEndpoint>
Propriété de transport TargetEndpoint Spécification
Nom de la propriété | Valeur par défaut | Description |
---|---|---|
keepalive.timeout.millis |
60000 |
Délai d'inactivité pour la connexion cible dans le pool de connexions. Si la connexion au pool est inactive au-delà de la limite spécifiée, la connexion est fermée. |
connect.timeout.millis |
|
Délai d'inactivité de la connexion cible Edge renvoie un code d'état HTTP |
io.timeout.millis |
55000 |
Si aucune donnée n'est disponible pour le nombre de millisecondes spécifié ou si le socket n'est pas prêt à écrire des données pour le nombre de millisecondes spécifié, la transaction est traitée comme un délai d'inactivité.
Cette valeur doit toujours être inférieure à celle de la propriété proxy_read_timeout de l'hôte virtuel. Cette valeur doit être inférieure au délai d'inactivité utilisé par Routeur pour communiquer avec le processeur de messages. Pour en savoir plus, consultez la page Configurer le délai d'inactivité du routeur. Voir Définir io.timeout.millis et api.timeout pour Edge pour en savoir plus. |
supports.http10 |
true |
Si cette valeur est true et que le client envoie une requête 1.0, la cible reçoit également une valeur 1.0.
requête. Sinon, la requête 1.1 est envoyée à la cible. |
supports.http11 |
true |
Si cette valeur est true et que le client envoie une requête 1.1, la cible reçoit également une requête 1.1.
sinon la requête 1.0 est envoyée à la cible. |
use.proxy |
true |
Si ce paramètre est défini sur true et que les configurations de proxy sont spécifiées dans http.properties (déploiements sur site uniquement), les connexions cibles sont définies pour utiliser le proxy spécifié. |
use.proxy.tunneling |
true |
Si ce paramètre est défini sur true et que les configurations de proxy sont spécifiées dans http.properties (déploiements sur site uniquement), les connexions cibles sont définies pour utiliser le tunnel spécifié. Si la cible utilise TLS/SSL, cette propriété est ignorée et le message est toujours envoyé via un tunnel. |
enable.method.override |
false |
Pour la méthode HTTP spécifiée, définit un en-tête X-HTTP-Method-Override sur la requête sortante vers le service cible. Par exemple, <Property
name="GET.override.method">POST</Property> . |
*.override.method |
ND | Pour la méthode HTTP spécifiée, définit un en-tête X-HTTP-Method-Override sur la requête sortante. Par exemple, <Property
name="GET.override.method">POST</Property> . |
request.streaming.enabled |
false |
Par défaut ( |
response.streaming.enabled |
false |
Par défaut ( |
success.codes |
N/A |
Par défaut, Apigee Edge traite le code HTTP La définition de cette propriété écrase les valeurs par défaut. Par conséquent, si vous souhaitez ajouter le code HTTP <Property name="success.codes">1XX,2XX,3XX,400</Property> Si vous souhaitez que seul le code HTTP <Property name="success.codes">400</Property> Si vous définissez le code HTTP |
compression.algorithm |
N/A |
Par défaut, Apigee Edge transmet les requêtes à la cible en utilisant le même type de compression que la requête du client. Si la requête est reçue par un client qui utilise, par exemple, une compression gzip, Apigee Edge transmet la requête à la cible à l'aide de la compression gzip. Si la réponse reçue de la cible utilise Deflate, Apigee Edge transmet la réponse au client à l'aide de Deflate. Les valeurs compatibles sont :
Voir aussi: Apigee prend-il en charge la compression/décompression avec la compression GZIP/deflate ? |
request.retain.headers. |
true |
Par défaut, Apigee Edge conserve toujours tous les en-têtes HTTP des messages sortants. Lorsque ce paramètre est défini sur true , tous les en-têtes HTTP présents dans la requête entrante sont définis sur la requête sortante. |
request.retain.headers |
ND | Définit les en-têtes HTTP spécifiques de la requête qui doivent être définis sur la requête sortante vers le service cible. Par exemple, pour transmettre l'en-tête User-Agent , définissez la valeur de request.retain.headers sur User-Agent .
Plusieurs en-têtes HTTP sont spécifiés sous la forme d'une liste d'éléments séparés par une virgule (par exemple, User-Agent,Referer,Accept-Language ). Cette propriété remplace request.retain.headers.enabled . Si request.retain.headers.enabled est défini sur false , tous les en-têtes spécifiés dans la propriété request.retain.headers sont toujours définis sur le message sortant. |
response.retain.headers. |
true |
Par défaut, Apigee Edge conserve toujours tous les en-têtes HTTP des messages sortants. Lorsque ce paramètre est défini sur true , tous les en-têtes HTTP présents dans la réponse entrante du service cible sont définis sur la réponse sortante avant que celle-ci ne soit transmise au ProxyEndpoint. |
response.retain.headers |
ND | Définit les en-têtes HTTP spécifiques de la réponse qui doivent être définis sur le trafic sortant
avant d'être transmis au ProxyEndpoint. Par exemple, pour effectuer un passthrough,
Expires , définissez la valeur de response.retain.headers sur
Expires Plusieurs en-têtes HTTP sont spécifiés sous forme de liste d'éléments séparés par une virgule, par
Exemple : Expires,Set-Cookie . Cette propriété remplace response.retain.headers.enabled . Si
response.retain.headers.enabled est défini sur false , tous les en-têtes
spécifiées dans la propriété response.retain.headers sont toujours définies sur la
le message sortant. |
retain.queryparams. |
true |
Par défaut, Apigee Edge conserve toujours tous les paramètres de requête sur les requêtes sortantes. Lorsqu'ils sont définis sur true , tous les paramètres de requête présents dans la requête entrante sont définis sur la requête sortante vers le service cible. |
retain.queryparams |
ND | Définit des paramètres de requête spécifiques à définir sur la requête sortante. Par exemple, pour inclure le paramètre de requête apikey à partir du message de requête, définissez retain.queryparams sur apikey . Plusieurs paramètres de requête sont spécifiés sous forme de liste d'éléments séparés par une virgule, par exemple apikey,environment . Cette propriété remplace retain.queryparams.enabled . |
Propriétés de transport ProxyEndpoint
Les éléments HTTPTargetConnection de ProxyEndpoint définissent un ensemble de propriétés de transport HTTP. Ces propriétés permettent de définir des configurations au niveau du transport.
Les propriétés sont définies sur les éléments HTTPProxyConnection de ProxyEndpoint comme suit :
<ProxyEndpoint name="default"> <HTTPProxyConnection> <BasePath>/v1/weather</BasePath> <Properties> <Property name="request.streaming.enabled">true</Property> </Properties> <VirtualHost>default</VirtualHost> <VirtualHost>secure</VirtualHost> </HTTPProxyConnection> </ProxyEndpoint>
Pour plus d'informations sur les hôtes virtuels, voir À propos des hôtes virtuels.
Propriété de transport ProxyEndpoint Spécification
Nom de la propriété | Valeur par défaut | Description |
---|---|---|
X-Forwarded-For |
false |
Si la valeur est true , l'adresse IP de l'hôte virtuel est ajoutée à la requête sortante en tant que
de l'en-tête HTTP X-Forwarded-For . |
request.streaming. |
false |
Par défaut (false ), les charges utiles de requêtes HTTP sont lues dans un tampon et les règles pouvant
opèrent sur la charge utile
comme prévu. Dans les cas où les charges utiles sont supérieures à
de la mémoire tampon (10 Mo), vous pouvez la définir
à true . Lorsque la valeur est true , les charges utiles de requêtes HTTP ne sont pas lues dans un tampon. ils sont
diffusées telles quelles vers le flux de requêtes TargetEndpoint. Dans ce cas, toutes les règles qui s'exécutent sur la charge utile dans le flux de requête ProxyEndpoint sont ignorées. Consultez également la section Requêtes et réponses de streaming. |
response.streaming. |
false |
Par défaut (false ), les charges utiles de réponse HTTP sont lues dans un tampon, et les règles qui
peut fonctionner comme prévu sur
la charge utile. Dans les cas où les charges utiles sont supérieures à
la taille de la mémoire tampon (10 Mo), vous pouvez la définir
à true . Lorsque la valeur est true , les charges utiles de réponse HTTP ne sont pas lues dans un tampon. ils sont
diffusées telles quelles au client. Dans ce cas, toutes les règles qui s'exécutent sur la charge utile dans le flux de réponse ProxyEndpoint sont ignorées. Consultez également la section Requêtes et réponses de streaming. |
compression.algorithm |
ND |
Par défaut, Apigee Edge respecte le type de compression défini pour chaque message reçu. Par exemple, si un client envoie une requête utilisant la compression gzip, Apigee Edge transmet la requête à la cible à l'aide de la compression gzip. Vous pouvez configurer les algorithmes de compression pour qu'ils soient explicitement appliqués en définissant cette propriété sur le TargetEndpoint ou le ProxyEndpoint. Les valeurs compatibles sont :
Voir aussi: Apigee prend-il en charge la compression/décompression avec la compression GZIP/deflate ? |
api.timeout |
N/A |
Configurer le délai d'inactivité pour des proxy d'API individuels Vous pouvez configurer des proxys d'API, même ceux pour lesquels la diffusion est activée, afin qu'ils expirent au bout d'une période spécifiée avec un état
Vous ne pouvez pas définir cette propriété avec une variable. Les clients qui ne peuvent pas modifier les délais d'inactivité Edge peuvent également configurer un proxy d'API délai avant expiration, à condition qu'il soit plus court que celui du processeur de messages Edge standard et un délai avant expiration de 57 secondes. Voir Définir io.timeout.millis et api.timeout pour Edge pour en savoir plus. |
Définir io.timeout.millis et api.timeout pour Edge
Sur Edge, le fonctionnement de io.timeout.millis
et api.timeout
sont liés.
À chaque requête envoyée à un proxy d'API :
- Le routeur envoie sa valeur de délai d'inactivité au processeur de messages. La valeur du délai avant expiration du routeur correspond soit à la valeur
proxy_read_timeout
définie par l'hôte virtuel qui gère la requête, soit à la valeur par défaut de 57 secondes. - Le processeur de messages définit ensuite
api.timeout
:- Si
api.timeout
n'est pas défini au niveau du proxy, définissez-le sur le délai d'inactivité du routeur. - Si
api.timeout
est défini au niveau du proxy, définissez-le sur le processeur de messages sur la valeur inférieure du délai d'inactivité du routeur ou la valeur deapi.timeout
.
- Si
La valeur de
api.timeout
spécifie la durée maximale pendant laquelle un proxy d'API doit s'exécuter à partir de la requête API à la réponse.Après l'exécution de chaque stratégie dans le proxy d'API, ou avant que le processeur de messages envoie la requête au point de terminaison cible, le processeur de messages calcule (
api.timeout
- temps écoulé depuis le début de la requête). Si la valeur est inférieure à zéro, cela signifie que la durée maximale de traitement de la requête a expiré. le processeur de messages renvoie504
.La valeur de
io.timeout.millis
spécifie la durée maximale pendant laquelle le point de terminaison cible peut répondre.Avant de se connecter à un point de terminaison cible, le processeur de messages détermine le plus petit (
api.timeout
: temps écoulé depuis le début de la requête) etio.timeout.millis
. Il définit ensuiteio.timeout.millis
sur cette valeur.- Si un délai d'inactivité se produit lors de l'écriture de la requête HTTP, le code
408, Request Timeout
est renvoyé. - Si un délai d'inactivité se produit lors de la lecture de la réponse HTTP, le code
504, Gateway Timeout
est renvoyé.
- Si un délai d'inactivité se produit lors de l'écriture de la requête HTTP, le code
À propos de ScriptTarget pour les applications Node.js
L'élément ScriptTarget permet d'intégrer une application Node.js à votre proxy. Pour sur l'utilisation de Node.js et ScriptTarget, consultez les pages suivantes:
À propos des points de terminaison HostedTarget
Une balise <HostedTarget/>
vide indique à Edge d'utiliser comme cible un nœud.js
qui est déployée dans l'environnement de cibles hébergées. Pour en savoir plus, consultez
Présentation des cibles hébergées