Testare la connettività

Visualizza il codice sorgente su GitHub

Dopo aver avviato Docker OTBR, forma una rete Thread e testa la sua connettività a internet.

Formare la rete Thread

Home page della GUI web OTBR

Sulla macchina su cui è in esecuzione Docker OTBR:

Apri una finestra del browser e vai alla pagina 127.0.0.1:8080. Se Docker OTBR è in esecuzione correttamente, viene caricata la GUI web di OTBR.

Seleziona l'opzione di menu "Modulo" e modifica alcune delle credenziali predefinite. Consigliamo di lasciare i valori predefiniti per canale e prefisso on-mesh. Qualunque cosa tu utilizzi, prendine nota per poter testare in un secondo momento un nodo Thread separato.

Parametro Valore di esempio
Nome rete OTBR4444
ID PAN 0x4444
Chiave di rete 33334444333344443333444433334444
ID PAN esteso 3333333344444444
Passphrase 444444
Canale 15
Prefisso sulla rete fd11:22::

Seleziona FORM per formare la rete Thread. Controlla l'output nella finestra del terminale che esegue OTBR Docker. Dovresti vedere l'output di log otbr-agent per l'aggiunta del prefisso on-mesh e di un indirizzo SLAAC:

otbr-agent[224]: [INFO]-CLI-----: execute command: prefix add fd11:22::/64 pasor

Questo output è necessario per la connettività a internet della rete Thread.

Visualizza un secondo nodo Thread

Una volta avviato Docker OTBR, aggiungi un nodo Thread autonomo alla rete Thread e verifica che abbia connettività a internet.

Se utilizzi un RCP fisico con Docker OTBR, utilizza un secondo nodo Thread fisico per eseguire il test. Se utilizzi un RCP simulato con Docker OTBR, utilizza un secondo nodo simulato per eseguire il test.

Nodo Thread fisico

Crea e esegui il flashing di un nodo Thread autonomo sulla piattaforma supportata di tua scelta. Questo nodo non deve essere compilato con opzioni di compilazione specifiche.

Per istruzioni di base sulla compilazione, consulta Compilare OpenThread.

Consulta la sezione Creare una rete Thread con schede nRF52840 e il Codelab OpenThread per istruzioni dettagliate su come compilare e eseguire il flashing della piattaforma Nordic nRF52840.

  1. Dopo la compilazione e il flashing, collega il dispositivo Thread alla macchina che esegue Docker OTBR tramite USB. Utilizza screen in una nuova finestra del terminale per accedere alla CLI. Ad esempio, se il dispositivo è montato sulla porta /dev/ttyACM1:

    screen /dev/ttyACM1 115200
    

  2. Premi il tasto Invio per visualizzare il prompt > dell'interfaccia a riga di comando OpenThread.

Nodo Thread simulato

  1. Apri una nuova finestra del terminale sulla macchina che esegue Docker OTBR.

  2. Avvia l'applicazione dell'interfaccia a riga di comando per visualizzare un nodo simulato:

    cd ~/openthread
    ./build/simulation/examples/apps/cli/ot-cli-ftd 2
    

  3. Premi il tasto Invio per visualizzare il prompt > dell'interfaccia a riga di comando OpenThread.

Unisci il secondo nodo alla rete Thread

Utilizzando il client OpenThread CLI per il tuo nodo Thread fisico o simulato, connetti il nodo alla rete Thread creata da OTBR Docker.

  1. Aggiorna le credenziali di rete Thread per il nodo, utilizzando i valori minimi richiesti da Docker OTBR:

    dataset networkkey 33334444333344443333444433334444
    Done
    dataset commit active
    Done
    

  2. Mostra l'interfaccia Thread e avvia Thread:

    ifconfig up
    Done
    thread start
    Done
    

  3. Il nodo dovrebbe unirsi automaticamente alla rete Thread OTBR. Entro due minuti lo stato dovrebbe essere router:

    state
    router
    

  4. Controlla gli indirizzi IP del nodo per assicurarti che abbia un indirizzo IPv6 con il prefisso on-mesh fd11:22::/64 come specificato durante la formazione della rete Thread:

    ipaddr
    fd11:22:0:0:614e:4588:57a1:a473
    fd33:3333:3344:0:0:ff:fe00:f801
    fd33:3333:3344:0:1b5f:db5:ecac:a9e
    fe80:0:0:0:e0c4:5304:5404:5f70:98cd
    

Invia un ping a un indirizzo pubblico

A questo punto dovresti essere in grado di eseguire un ping a un indirizzo IPv4 pubblico dal nodo Thread autonomo. Poiché Thread utilizza solo IPv6, l'indirizzo IPv4 pubblico verrà tradotto automaticamente in IPv6 combinando con il prefisso NAT64 nella rete Thread.

  1. Per visualizzare il prefisso NAT64 nella rete Thread:

    netdata show
    Prefixes:
    fd11:22:0:0::/64 paros med d400
    Routes:
    fdb5:7875:8e0e:2:0:0::/96 sn low d400
    fd11:1111:1122:2222::/64 s med d400
    Services:
    44970 5d fd5179ed685532847aaa91505f016bbad11f s d400
    44970 01 00000500000e10 s d400
    Done
    
    Qui fdb5:7875:8e0e:2:0:0::/96 è il prefisso NAT64 nella rete Thread.

  2. Invia un ping a un indirizzo IPv4 dall'interfaccia a riga di comando del nodo Thread autonomo per testare la connettività internet:

    ping 8.8.8.8
    Pinging synthesized IPv6 address: fdb5:7875:8e0e:2:0:0:808:808
    16 bytes from fdb5:7875:8e0e:2:0:0:808:808: icmp_seq=15 hlim=119 time=48ms
    

Operazione riuscita. Il secondo nodo Thread ora può comunicare con internet tramite Docker OTBR.