Quando si costruisce un'applicazione con ASP.NET, si utilizza un'istanza della classe HttpClient per effettuare una richiesta HTTP. Usare HttpClient può sembrare semplice. Tuttavia, alcuni potenziali problemi non vengono notati fino a quando l'applicazione è sotto forte carico.
Problemi relativi alla classe HttpClient originale fornita in .NET:Il login del link ipertestuale è visibile.
HttpClient, pur implementando IDisposable, dichiararlo e istanziarlo nell'istruzione using non è un'operazione preferita, perchéQuando si rilascia un oggetto HttpClient, il socket sottostante non lo faimmediatamenterilascio, che può causare problemi di esaurimento della cava.
Il problema non è davvero HttpClient in sé, ma il costruttore predefinito di HttpClient, poiché crea una nuova istanza reale di HttpMessageHandler con i problemi di "socket exhaustion" e di modifica DNS menzionati sopra.
Creazione diretta di HttpClient (uso errato)
Istanzia direttamente l'oggetto HttpClient e aggiungi usando per garantire la chiamata al metodo Dispose, il codice è il seguente:
Chiama l'interfaccia 5 volte, invia una richiesta HTTP usando HttpClient e verifica la connessione di rete con il seguente comando:
Puoi vedere che quando viene rilasciato l'HttpClient, la connessione tra il computer locale e il server di destinazione èTIME_WAITNel caso di alta concorrenza, l'errore sarà riportato come segue:
Impossibile connettersi al server remoto
System.Net.Sockets.SocketException: Only one usage of each socket address (protocol/network address/port) is normally permitted.
Per domande, puoi anche fare riferimento a:
Creare un HttpClinet con IHttpClientFactory (uso corretto)
Utilizzando l'iniezione di dipendenza DI, IHttpClientFactory è lo stesso di HttpLinet, che viene creato tramite IHttpClientFactory.
Aggiungi il servizio al file di avvio, il codice è il seguente:
Il codice del controller HomeController è il seguente:
Usiamo anche HttpClinet per inviare 5 richieste attraverso l'interfaccia chiamata, e la macchina stabilisce una connessione solo con il server target, e la connessione viene riutilizzata durante il processo di richiesta. Come mostrato di seguito:
IHttpClientFactory raggruppa istanze HttpMessageHandler create in fabbrica in un pool per ridurre il consumo di risorse. Quando crei una nuova istanza HttpClient, puoi riutilizzare l'istanza HttpMessageHandler nel pool se la durata non è scaduta.
{ "Vita": "Singleton", "ServiceType": "System.Net.Http.IHttpClientFactory", "ImplementationType": "Microsoft.Extensions.Http.DefaultHttpClientFactory" }, { "Vita": "Singleton", "ServiceType": "System.Net.Http.IHttpMessageHandlerFactory", "ImplementationType": "Microsoft.Extensions.Http.DefaultHttpClientFactory" } IHttpClientFactory è implementato di default come DefaultHttpClientFactory, con l'indirizzo del codice sorgente:Il login del link ipertestuale è visibile.
Utilizzando IHttpClientFactory in un'applicazione abilitata DI, puoi evitare:
- Risolvere il problema dell'esaurimento delle risorse condividendo l'istanza HttpMessageHandler.
- Risolvi la stagnazione DNS passando periodicamente in loop le istanze di HttpMessageHandler.
Inoltre, esistono altri modi per risolvere i problemi sopra menzionati utilizzando istanze SocketsHttpHandler a lunga durata.
- Crea un'istanza di SocketsHttpHandler all'avvio dell'app e usala durante tutto il ciclo di vita dell'app.
- Configura PooledConnectionLifetime al valore appropriato in base al tempo di aggiornamento DNS.
- Crea un'istanza di HttpClient usando il nuovo HttpClient (handler, disposeHandler: false) secondo necessità.
L'approccio sopra risolve i problemi di gestione delle risorse in modo simile a IHttpClientFactory.
- SocketsHttpHandler tra le istanze HttpClientConnessioni condivise。 Questa condivisione previene l'esaurimento delle porte.
- SocketsHttpHandler fa looping alle connessioni basate su PooledConnectionLifetime per evitare che il DNS non venga obsoleto.
Per ulteriori utilizzi e configurazioni, si prega di consultare a:
Il login del link ipertestuale è visibile.
Il login del link ipertestuale è visibile.
|