Informazioni su larghezza di banda ridotta e alta latenza

È importante capire come si utilizza la tua app o il tuo sito quando la connettività è scarsa o inaffidabile e creare di conseguenza. Esistono diversi strumenti per aiutarti.

Test con larghezza di banda ridotta e latenza elevata

Una proporzione crescente di persone esplora il web su dispositivi mobili. Anche a casa, molte persone stanno abbandonando la banda larga fissa per quella mobile.

In questo contesto, è importante capire come si sente un utente quando utilizza la tua app o il tuo sito quando la connettività è scarsa o inaffidabile. Una serie di strumenti software può aiutarti a emulare e simulare una larghezza di banda ridotta e un'elevata latenza.

Emulare la limitazione della rete

Quando crei o aggiorni un sito, devi garantire prestazioni adeguate in diverse condizioni di connettività. Esistono diversi strumenti che possono aiutarti.

Strumenti del browser

Chrome DevTools ti consente di testare il tuo sito con una serie di velocità di caricamento/download e tempi di transito, utilizzando preset o impostazioni personalizzate dal riquadro Rete. Per apprendere le nozioni di base, consulta la guida introduttiva all'analisi delle prestazioni di rete.

Limitazione di Chrome DevTools

Strumenti di sistema

Network Link Conditioner è un pannello delle preferenze disponibile su Mac se installi Hardware IO Tools per Xcode:

Pannello di controllo di Mac Network Link Conditioner

Impostazioni di Network Link Conditioner per Mac

Impostazioni personalizzate di Network Link Conditioner per Mac

Emulazione dispositivo

Android Emulator ti consente di simulare varie condizioni di rete durante l'esecuzione di app (inclusi browser web e app web ibride) su Android:

emulatore Android

Impostazioni dell'emulatore Android

Per iPhone, puoi utilizzare Network Link Conditioner per simulare condizioni di rete con problemi (vedi sopra).

Esegui test da posizioni e reti diverse

Le prestazioni della connettività dipendono dalla posizione del server e dal tipo di rete.

WebPagetest è un servizio online che consente di eseguire un insieme di test delle prestazioni per il tuo sito utilizzando una serie di reti e località di hosting. Ad esempio, puoi provare il tuo sito da un server in India su una rete 2G o via cavo da una città degli Stati Uniti.

Impostazioni di WebPagetest

Seleziona una località e, dalle impostazioni avanzate, un tipo di connessione. Puoi persino automatizzare i test utilizzando script (ad esempio per accedere a un sito) o le API RESTful. In questo modo puoi includere i test di connettività nei processi di compilazione o nel logging del rendimento.

Fiddler supporta il proxy globale tramite GeoEdge e le sue regole personalizzate possono essere utilizzate per simulare le velocità del modem:

Proxy Fiddler

Eseguire test su una rete con problemi

I proxy hardware e software ti consentono di emulare condizioni problematiche della rete mobile, come la limitazione della larghezza di banda, il ritardo dei pacchetti e la perdita di pacchetti casuale. Un proxy condiviso o una rete con problemi può consentire a un team di sviluppatori di incorporare nel proprio flusso di lavoro i test di rete reali.

Il controllo del traffico aumentato (ATC) di Facebook è un insieme di applicazioni con licenza BSD che può essere utilizzato per modellare il traffico ed emulare condizioni di rete con limitazioni:

Controllo del traffico aumentato di Facebook

Facebook ha persino istituito i 2G Tuesday per comprendere meglio in che modo le persone che utilizzano il 2G usano il suo prodotto. Il martedì i dipendenti visualizzano un popup che permette di simulare una connessione 2G.

Il proxy HTTP/HTTPS Charles può essere utilizzato per regolare la larghezza di banda e la latenza. Charles è un software commerciale, ma è disponibile una prova gratuita.

Impostazioni di larghezza di banda e latenza del proxy Charles

Ulteriori informazioni su Charles sono disponibili sul sito codewithchris.com.

Gestire la connettività inaffidabile e il "lie-fi"

Cos'è il lie-fi?

Il termine lie-fi risale almeno al 2008 (quando gli smartphone assomigliavano a questo) e si riferisce alla connettività che non è ciò che sembra. Il browser si comporta come se avesse connettività quando, per qualsiasi motivo, non è così.

Una connettività interpretata erroneamente può comportare un'esperienza negativa, in quanto il browser (o JavaScript) continua a tentare di recuperare le risorse anziché rinunciare e scegliere un'opzione di riserva ragionevole. Lie-fi può essere addirittura peggiore dell'offline; almeno se un dispositivo è definitivamente offline, il tuo codice JavaScript può intraprendere azioni evasive appropriate.

Il lie-fi probabilmente diventerà un problema più grande man mano che sempre più persone passano ai dispositivi mobili e allontanano la banda larga fissa. I dati del censimento statunitense recenti mostrano un ritiro dalla banda larga fissa. Il seguente grafico mostra l'utilizzo di internet mobile da casa nel 2015 rispetto al 2013:

Grafico tratto dai dati del censimento degli Stati Uniti
che mostra il passaggio alla rete mobile rispetto alla banda larga fissa, in particolare nei nuclei familiari a basso reddito

Utilizzare i timeout per gestire la connettività intermittente

In passato, per verificare la connettività intermittente sono stati utilizzati metodi poco ortodossi che utilizzano XHR, ma i worker di servizio consentono di utilizzare metodi più affidabili per impostare i timeout di rete. Per farlo, puoi utilizzare Workbox con poche righe di codice:

workboxSW.router.registerRoute(
  '/path/to/image',
  workboxSW.strategies.networkFirst({networkTimeoutSeconds: 3}),
);

Puoi scoprire di più su Workbox nel talk di Jeff Posnick al Chrome Dev Summit, Workbox: librerie PWA flessibili.

È in fase di sviluppo anche la funzionalità di timeout per l'API Fetch e l'API Streams dovrebbe contribuire a ottimizzare la pubblicazione dei contenuti ed evitare richieste monolitiche. Jake Archibald fornisce maggiori dettagli su come affrontare il problema del lie-fi in Supercharging page load.

Feedback