Stai visualizzando la documentazione di Apigee e Apigee hybrid.
Visualizza la documentazione di
Apigee Edge.
Apigee ti consente di richiamare un proxy API da un altro proxy API. Questa funzionalità è utile soprattutto se hai un proxy API che contiene codice riutilizzabile che può essere utilizzato da altri proxy API.
Antipattern
L'invocazione di un proxy API da un altro utilizzando HTTPTargetConnection nell'endpoint di destinazione o
il codice JavaScript personalizzato comporta un hop di rete aggiuntivo.
Richiamare il proxy 2 dal proxy 1 utilizzando HTTPTargetConnection
Il seguente esempio di codice richiama il proxy 2 dal proxy 1 utilizzando HTTPTargetConnection:
<!-- /antipatterns/examples/2-1.xml --> <HTTPTargetConnection> <URL>https://api-test.example.com/proxy2</URL> </HTTPTargetConnection>
Richiamare il proxy 2 dal proxy 1 dal codice JavaScript
Il seguente esempio di codice richiama il proxy 2 dal proxy 1 utilizzando JavaScript:
<!-- /antipatterns/examples/2-2.xml --> var response = httpClient.send('https://api-test.example.com/proxy2); response.waitForComplete();
Flusso codice
Per capire perché questo metodo presenta uno svantaggio intrinseco, dobbiamo comprendere il percorso di una richiesta come illustrato nel diagramma seguente:
Come illustrato nel diagramma, una richiesta attraversa più componenti distribuiti, tra cui il router e il processore di messaggi.
Negli esempi di codice riportati sopra, l'invocazione del proxy 2 dal proxy 1 significa che la richiesta deve essere instradata tramite il percorso tradizionale (router > MP) in fase di runtime. Sarebbe come richiamare un'API da un client, effettuando così più hop di rete che aumentano la latenza. Questi hop sono inutili, dato che la richiesta del proxy 1 ha già raggiunto il MP.
Impatto
L'invocazione di un proxy API da un altro proxy API comporta hop di rete non necessari, ovvero la richiesta deve essere trasmessa da un processore di messaggi a un altro.
Best practice
- Utilizza la funzionalità di concatenamento dei proxy
per richiamare un proxy API da un altro. Il concatenamento dei proxy è più efficiente perché utilizza la connessione locale per fare riferimento all'endpoint di destinazione (un altro proxy API).
L'esempio di codice mostra il concatenamento dei proxy utilizzando
LocalTargetConnectionnella definizione dell'endpoint:<!-- /antipatterns/examples/2-3.xml --> <LocalTargetConnection> <APIProxy>proxy2</APIProxy> <ProxyEndpoint>default</ProxyEndpoint> </LocalTargetConnection>
Il proxy API richiamato viene eseguito nello stesso processore di messaggi, pertanto evita l'hop di rete, come mostrato nella figura seguente:
Figura 2: flusso di codice con concatenamento dei proxy