Estás viendo la documentación de Apigee Edge.
Ve a la
Documentación de Apigee X. información
Lo que aprenderás en este tema
Después de leer este tema, sabrás lo siguiente:
- ¿Qué es la transmisión de solicitudes y respuestas en Apigee Edge?
- Cuándo usar la transmisión de solicitudes y respuestas
- Cómo habilitar la transmisión de solicitudes y respuestas
¿Qué es la transmisión de solicitudes y respuestas?
De forma predeterminada, la transmisión HTTP está inhabilitada y las cargas útiles de solicitud y respuesta HTTP se escriben en un búfer de memoria antes de que la canalización del proxy de API las procese. Para cambiar este comportamiento, habilita la transmisión. Con la transmisión habilitada, las cargas útiles de solicitud y respuesta se transmiten sin modificación a la app cliente (para las respuestas) y al extremo de destino (para las solicitudes).
¿Cuándo debo habilitar la transmisión?
Si tu proxy de API maneja solicitudes o respuestas muy grandes (para conocer los límites de tamaño, consulta ¿Qué más debo saber acerca de la transmisión? a continuación), te recomendamos habilitar la transmisión.
¿Qué más debo saber sobre la transmisión?
El tamaño de la carga útil del mensaje se restringe a 10 MB en Edge Cloud y
Nube privada, incluso con la transmisión habilitada. En las solicitudes y respuestas no transmitidas, si superas ese tamaño, se produce un error protocol.http.TooBigBody
.
En Edge para implementaciones de nube privada, puedes modificar el tamaño de la solicitud/respuesta no transmitida límite. Asegúrate de realizar pruebas antes de implementar el cambio en producción.
- Para las versiones de Edge para la nube privada anteriores a la versión 4.16.01:
En todos los procesadores de mensajes, edita el archivohttp.properties
para aumentar la límite en el parámetroHTTPResponse.body.buffer.limit
y, luego, reinicia Message Processor. -
Para Edge for Private Cloud versión 4.16.01 y posteriores:
-
Edita el archivo /<inst_root>/apigee/customer/application/message-processor.properties. Si ese archivo no existe, créalo.
-
Configura conf_http_HTTPResponse.body.buffer.limit en message-processor.properties. Para ejemplo:
conf_http_HTTPResponse.body.buffer.limit=5m -
Reinicia el Message Processor:
> /<inst_root>/apigee/apigee-service/bin/apigee-service perimetral-message-processor reiniciar -
Repite el procedimiento para todos los procesadores de mensajes.
-
Cómo habilitar la transmisión de solicitudes y respuestas
Para habilitar la transmisión de solicitudes, debes agregar la propiedad request.streaming.enabled
a las definiciones de ProxyEndpoint y TargetEndpoint en el paquete del proxy y establecerla como true
. De manera similar, configura la propiedad response.streaming.enabled
para habilitar la transmisión de respuestas.
Puedes ubicar estos archivos de configuración en la IU de administración en la vista Desarrollo de tu
proxy. Si desarrollas de manera local, estos archivos de definición están en apiproxy/proxies
y apiproxy/targets
.
En esta muestra, se indica cómo habilitar la transmisión de solicitudes y respuestas en la definición de TargetEndpoint.
<TargetEndpoint name="default"> <HTTPTargetConnection> <URL>http://mocktarget.apigee.net</URL> <Properties> <Property name="response.streaming.enabled">true</Property> <Property name="request.streaming.enabled">true</Property> <Property name="supports.http10">true</Property> <Property name="request.retain.headers">User-Agent,Referer,Accept-Language</Property> <Property name="retain.queryparams">apikey</Property> </Properties> </HTTPTargetConnection> </TargetEndpoint>
En este ejemplo, se muestra cómo habilitar la transmisión de solicitudes y respuestas en la definición de ProxyEndpoint:
<ProxyEndpoint name="default"> <HTTPProxyConnection> <BasePath>/v1/weather</BasePath> <Properties> <Property name="allow.http10">true</Property> <Property name="response.streaming.enabled">true</Property> <Property name="request.streaming.enabled">true</Property> </Properties> </HTTPProxyConnection> </ProxyEndpoint>
Para obtener más información sobre cómo configurar las definiciones de extremos, consulta Referencia de propiedades de extremos.
Muestras de código relacionadas
Las muestras de proxy de API en GitHub son fáciles de descargar y usar. Para obtener más información, consulta Cómo utilizar los proxies de API de muestra descargar y usar las muestras.
Entre los proxies de muestra que incluyen la transmisión, se incluyen los siguientes:
- Transmisión: Muestra un proxy de API configurado para la transmisión HTTP.
- Texto destacado perimetral: generador de URL firmadas: ilustra la práctica recomendada de generar una URL firmada para acceder a archivos grandes en lugar de intentar transmitirlos en una solicitud o respuesta.