OpenThread ile bir Mesaj Dizisi ağını simüle etme

1. Giriş

26b7f4f6b3ea0700.png

Google tarafından kullanıma sunulan OpenThread, Thread ağ protokolünün açık kaynaklı bir uygulamasıdır. Google Nest, bağlı ev için ürünlerin geliştirilmesine hız kazandırmak amacıyla Nest ürünlerinde kullanılan teknolojiyi geliştiricilerin kullanımına kapsamlı bir şekilde sunmak için OpenThread API'yi kullanıma sunmuştur.

İleti dizisi spesifikasyonu, ev uygulamaları için IPv6 tabanlı güvenilir, güvenli ve düşük güçlü kablosuzdan cihaza iletişim protokolü tanımlar. OpenThread; IPv6, 6LoWPAN, IEEE 802.15.4 (MAC güvenliği, Örgü Bağlantısı Oluşturma ve Örgü Yönlendirme) dahil tüm İleti Dizisi ağ katmanını uygular.

Bu Codelab, simüle edilmiş cihazlarda bir İş Parçacığı ağı simüle etme konusunda size yol gösterir.

Neler öğreneceksiniz?

  • OpenThread derleme araç zincirini ayarlama
  • Thread ağı nasıl simüle edilir?
  • Mesaj dizisi düğümlerinin kimliğini doğrulama
  • Bir İş Parçacığı ağını OpenThread Daemon ile yönetme

Gerekenler

  • git
  • Linux ve ağ yönlendirme ile ilgili temel bilgiler

2. Derleme sistemini ayarlama

Git

Bu Codelab'i tamamlamak için Git gereklidir. Devam etmeden önce indirip indirin.

Yüklendikten sonra, OpenThread uygulamasını indirip oluşturmak için işletim sisteminize özel talimatları uygulayın.

Mac OS X için XCode

Mac OS X'te OpenThread'i yüklemek ve oluşturmak için XCode gerekir.

XCode yüklendikten sonra, XCode Command Satır Araçları'nı yükleyin:

$ xcode-select --install

Linux / Mac OS X'te derleme

Bu yükleme talimatları Ubuntu Server 14.04 LTS ve Mac OS X Sierra 10.12.6'da test edilmiştir.

OpenThread öğesini yükleyin. bootstrap komutları, araç zincirinin yüklü olduğundan ve ortamın düzgün şekilde yapılandırıldığından emin olur:

$ mkdir -p ~/src
$ cd ~/src
$ git clone --recursive https://github.com/openthread/openthread.git
$ cd openthread
$ ./script/bootstrap
$ ./bootstrap

Windows'u kullanma

Windows'u tercih ediyorsanız bu Codelab'in Docker sürümünü denemenizi öneririz.

3. OpenThread uygulamalarını oluşturma

Yüklemeniz tamamlandığında örnek OpenThread uygulamasını oluşturun. Bu Codelab'de simülasyon örneğini kullanıyoruz.

$ cd ~/src/openthread
$ make -f examples/Makefile-simulation

Şimdi OpenThread Daemon'ı oluşturun:

$ cd ~/src/openthread
$ make -f src/posix/Makefile-posix DAEMON=1

4. Mesaj Dizisi ağını simüle etme

Bu Codelab için kullanacağınız örnek uygulama, OpenThread yapılandırmasını ve yönetim arayüzlerini temel bir komut satırı arayüzü (CLI) üzerinden gösteren küçük bir OpenThread uygulaması gösteriyor.

Bu alıştırmada, simüle edilmiş bir İş Parçacığı cihazına başka bir simüle edilmiş cihaz cihazında ping göndermek için gereken minimum adım adım yol gösterilir.

Aşağıdaki şekilde, temel İş parçacığı ağı topolojisi açıklanmaktadır. Bu alıştırmada yeşil daire içindeki iki düğümü simüle edeceğiz: Bir İş Parçacığı Lideri ve aralarında tek bir bağlantı olan İş Parçacığı.

6e3aa07675f902dc.png

Düğüm pingleme

1. Düğüm 1'i başlat

openthread dizinine gidin ve ot-cli-ftd ikili programını kullanarak simüle edilmiş bir İş Parçacığı cihazı için CLI işlemi oluşturun.

$ cd ~/src/openthread
$ ./output/simulation/bin/ot-cli-ftd 1

Not: Bu komutu çalıştırdıktan sonra > istemini görmüyorsanız enter tuşuna basın.

Bu ikili program, POSIX'ün üst kısmında simüle edilmiş bir OpenThread cihazı uygular. IEEE 802.15.4 radyo sürücüsü, UDP'nin üstüne uygulanır (IEEE 802.15.4 çerçeveleri UDP yükleri içinde iletilir).

1 bağımsız değişkeni, simüle edilmiş cihaz için "fabrika tarafından atanan" IEEE EUI-64'ün en az önemli bitlerini temsil eden bir dosya tanımlayıcısıdır. Bu değer, IEEE 802.15.4 radyo emülasyonu (bağlantı noktası = 9000 + dosya tanımlayıcısı) için UDP bağlantı noktasına bağlanırken de kullanılır. Bu Codelab'deki simüle edilmiş iş parçacığı cihazının her örneği, farklı bir dosya tanımlayıcısı kullanır.

Not: Simüle edilmiş cihaz için işlem oluşturulurken yalnızca bu Codelab'de belirtilen 1 veya daha büyük dosya tanımlayıcıları kullanın. 0 dosyasının dosya tanımlayıcısı başka bir amaçla kullanılmak üzere ayrılmıştır.

Yeni bir Operasyonel Veri Kümesi oluşturun ve bunu etkin veri kümesi olarak belirleyin. Operasyonel Veri Kümesi, oluşturduğunuz Thread ağının yapılandırmasıdır.

> dataset init new
Done
> dataset
Active Timestamp: 1
Channel: 20
Channel Mask: 07fff800
Ext PAN ID: d6263b6d857647da
Mesh Local Prefix: fd61:2344:9a52:ede0/64
Network Key: e4344ca17d1dca2a33f064992f31f786
Network Name: OpenThread-c169
PAN ID: 0xc169
PSKc: ebb4f2f8a68026fc55bcf3d7be3e6fe4
Security Policy: 0, onrcb
Done

Bu veri kümesini etkin veri kümesi olarak verin:

> dataset commit active
Done

IPv6 arayüzünü getirin:

> ifconfig up
Done

Mesaj Dizisi protokol işlemini başlatın:

> thread start
Done

Birkaç saniye bekleyin ve cihazın Mesaj Dizisi Lideri olduğunu doğrulayın. Lider, yönlendirici kimliği atamasını yönetmekten sorumlu cihazdır.

> state
leader
Done

Düğüm 1's Mesaj Dizisi arayüzüne atanan IPv6 adreslerini görüntüleyin (çıkışınız farklı olur):

> ipaddr
fd61:2344:9a52:ede0:0:ff:fe00:fc00
fd61:2344:9a52:ede0:0:ff:fe00:5000
fd61:2344:9a52:ede0:d041:c5ba:a7bc:5ce6
fe80:0:0:0:94da:92ea:1353:4f3b
Done

Belirli IPv6 adres türlerine dikkat edin:

  • fd ile başlar = bağlantılı-yerel
  • fe80 ile başlar = link-local

Örgü yerel adres türleri daha fazla sınıflandırılır:

  • ff:fe00 içerir = Yönlendirici Bulucu (RLOC)
  • ff:fe00 içermez = Uç Nokta Tanımlayıcı (EID)

Konsol çıktınızdaki EID'yi tanımlayarak daha sonra kullanmak üzere not edin. Yukarıdaki örnek çıkışta EID:

fd61:2344:9a52:ede0:d041:c5ba:a7bc:5ce6

2. Düğüm 2'yi başlat

Yeni bir terminal açın ve openthread dizinine gidip KSA işlemini oluşturun. Bu, simüle edilen ikinci Thread cihazınızdır:

$ cd ~/src/openthread
$ ./output/simulation/bin/ot-cli-ftd 2

Not: Bu komutu çalıştırdıktan sonra > istemini görmüyorsanız enter tuşuna basın.

İş Parçacığı Ağ Anahtarı ve PAN Kimliğini, Düğüm 1''in Operasyonel Veri Kümesi ile aynı değerleri kullanarak yapılandırın:

> dataset networkkey e4344ca17d1dca2a33f064992f31f786
Done
> dataset panid 0xc169
Done

Bu veri kümesini etkin veri kümesi olarak verin:

> dataset commit active
Done

IPv6 arayüzünü getirin:

> ifconfig up
Done

Mesaj Dizisi protokol işlemini başlatın:

> thread start
Done

Cihaz bir Alt Yayıncı olarak başlatılır. Bir İş Parçacığı Alt Öğesi, yalnızca Üst Öğe ile tek seferlik trafik aktaran ve alan bir İleti Dizisi cihazı olan Son Cihaz'a eşdeğerdir.

> state
child
Done

2 dakika içinde, child yerine router durumuna geçiş yapıldığını göreceksiniz. Mesaj Dizisi Yönlendiricisi, trafiği İleti Dizisi cihazları arasında yönlendirebilir. Üst Öğe olarak da adlandırılır.

> state
router
Done

Ağı doğrulama

Örgü ağını doğrulamanın kolay bir yolu, yönlendirici tablosuna bakmaktır.

1. Bağlantıyı kontrol et

Düğüm 2'de RLOC16 alın. RLOC16, cihazın RLOC IPv6 adresinin son 16 bitidir.

> rloc16
5800
Done

Düğüm 1'de, yönlendirici tablosunda Düğüm 2's RLOC16'yı kontrol edin. Öncelikle Düğüm 2'nin yönlendirici durumuna geçtiğinden emin olun.

> router table
| ID | RLOC16 | Next Hop | Path Cost | LQI In | LQI Out | Age | Extended MAC  |
+----+--------+----------+----------+-------+---------+-----+------------------+
| 20 | 0x5000 |       63 |         0 |     0 |      0 |   0 | 96da92ea13534f3b |
| 22 | 0x5800 |       63 |         0 |     3 |      3 |  23 | 5a4eb647eb6bc66c |

Tabloda 0xa800 Düğümü 1&R3C, ağa bağlı olduğunu doğrulamak için bulundu.

2. Düğüm 2'den Düğüm 1'i pingle

Simüle edilmiş iki Mesaj Dizisi cihazı arasındaki bağlantıyı doğrulayın. Düğüm 2'de, ping Düğüm 1'e atanan EID için:

> ping fd61:2344:9a52:ede0:d041:c5ba:a7bc:5ce6
> 16 bytes from fd61:2344:9a52:ede0:d041:c5ba:a7bc:5ce6: icmp_seq=1
hlim=64 time=12ms

> KSA istemine dönmek için enter tuşuna basın.

Ağı test etme

Artık simüle edilen iki İş Parçacığı cihazı arasında başarıyla pingleyebileceğinize göre bir düğümü çevrimdışı olarak örgü ağını test edebilirsiniz.

Düğüm 1'e dönün ve Mesaj dizisini durdurun:

> thread stop
Done

Düğüm 2'ye geçin ve durumu kontrol edin. İki dakika içinde 2. Düğüm, liderin (1. Düğüm) çevrimdışı olduğunu algılar ve 2. Düğümün ağın leader değerine geçtiğini görürsünüz:

> state
router
Done
...
> state
leader
Done

Onaylandıktan sonra, çıkış yapmadan önce İş Parçacığını durdurun ve Düğüm 2'yi fabrika ayarlarına sıfırlayın. Bu alıştırmada kullandığımız ileti dizisi ağ kimlik bilgilerinin sonraki egzersize aktarılmamasını sağlamak için fabrika ayarlarına sıfırlama işlemi yapılır.

> thread stop
Done
> factoryreset
>
> exit

Ayrıca, fabrika ayarlarına sıfırlayın ve 1. Düğümden çıkın:

> factoryreset
>
> exit

Mevcut tüm KSA komutlarını incelemek için OpenThread CLI Referansı bölümüne bakın.

5. Komisyon ile düğümleri doğrulama

Önceki alıştırmada, simüle edilmiş iki cihaz ve doğrulanmış bağlantı bulunan bir Thread ağı kurdunuz. Ancak bu, yalnızca kimliği doğrulanmamış IPv6 bağlantı yerel trafiğinin cihazlar arasında geçişine izin verir. Genel IPv6 trafiğini aralarında (ve ileti dizisi kenarlık yönlendiricisi üzerinden internet) yönlendirmek için düğümlerin kimliği doğrulanmalıdır.

Kimlik doğrulama için bir cihazın Komisyoncu olarak hareket etmesi gerekir. Komisyoncu, yeni İş Parçacığı cihazları için şu anda seçilmiş olan kimlik doğrulama sunucusu ve cihazların ağa katılması için gereken ağ kimlik bilgilerini sağlayan yetkilendirmedir.

Bu alıştırmada, daha önce olduğu gibi iki düğümlü topolojiyi kullanacağız. Kimlik doğrulama için Thread Lideri, Komisyoncu olarak görev alır, Thread Yönlendirici de birleştirici olarak hareket eder.

d6a67e8a0d0b5dcb.png

1. Ağ oluşturun

Önceki egzersize devam ederseniz iki açık pencereniz açık olmalıdır. Açık değilse iki öğenin de açık ve kullanıma hazır olduğundan emin olun. Bir düğüm 1. Düğüm, diğeri 2. Düğüm olarak işlev görür.

Düğüm 1'de KSA sürecini oluşturun:

$ cd ~/src/openthread
$ ./output/simulation/bin/ot-cli-ftd 1

Not: Bu komutu çalıştırdıktan sonra > istemini görmüyorsanız enter tuşuna basın.

Yeni bir Operasyonel Veri Kümesi oluşturun, bunu etkin veri kümesi olarak belirleyin ve İleti Dizisini başlatın:

> dataset init new
Done
> dataset
Active Timestamp: 1
Channel: 12
Channel Mask: 07fff800
Ext PAN ID: e68d05794bf13052
Mesh Local Prefix: fd7d:ddf7:877b:8756/64
Network Key: a77fe1d03b0e8028a4e13213de38080e
Network Name: OpenThread-8f37
PAN ID: 0x8f37
PSKc: f9debbc1532487984b17f92cd55b21fc
Security Policy: 0, onrcb
Done

Bu veri kümesini etkin veri kümesi olarak verin:

> dataset commit active
Done

IPv6 arayüzünü getirin:

> ifconfig up
Done

Mesaj Dizisi protokol işlemini başlatın:

> thread start
Done

Birkaç saniye bekleyin ve cihazın bir Mesaj Dizisi Lideri olduğunu doğrulayın:

> state
leader
Done

2. Komisyoncu rolünü başlatma

Düğüm 1'deyken Komisyoncu rolünü başlatın:

> commissioner start
Done

J01NME Tamamlayıcı Kimlik Bilgisi'ne sahip herhangi bir Tamamlayıcı'nın (* joker karakterini kullanarak) ağa komisyon vermesine izin verin. Birleştirici, gerçek bir yönetici tarafından yaptırılan bir İş Parçacığı Ağına eklenen bir cihazdır.

> commissioner joiner add * J01NME
Done

3. Birleştirici rolünü başlatma

İkinci bir terminal penceresinde yeni bir KSA işlemi oluşturur. Bu, Düğüm 2.

$ cd ~/src/openthread
$ ./output/simulation/bin/ot-cli-ftd 2

Düğüm 2'de, J01NME Birleştirici Kimlik Bilgisi'ni kullanarak Birleştirici rolünü etkinleştirin.

> ifconfig up
Done
> joiner start J01NME
Done

... onay için birkaç saniye bekleyin ...

Join success

Birleştirilmiş olarak cihaz (Düğüm 2), Komisyon (Düğüm 1) ile kendi kimliğini başarıyla doğrulamıştır ve İleti Dizisi Ağı kimlik bilgilerini almıştır.

Düğüm 2'nin kimliği doğrulandıktan sonra İleti Dizisini başlatın:

> thread start
Done

4. Ağ kimlik doğrulamasını doğrulama

Ağa katıldığını doğrulamak için Düğüm 2'deki state öğesini kontrol edin. İki dakika içinde, 2. Düğüm child - router geçişi yapar:

> state
child
Done
...
> state
router
Done

5. Yapılandırmayı sıfırla

Bir sonraki egzersize hazırlanmak için yapılandırmayı sıfırlayın. Her Düğümde, Thread'i durdurun, fabrika ayarlarına sıfırlayın ve simüle edilen Thread cihazından çıkın:

> thread stop
Done
> factoryreset
>
> exit

factoryreset komutunun ardından > istemini geri getirmek için enter tuşuna birkaç kez basmanız gerekebilir.

6. OpenThread Daemon ile ağı yönetme

Bu alıştırmada bir CLI örneği (tek bir yerleşik SoC Thread cihazı) ve bir Radyo Ortak İşlemci (RCP) örneği simüle edeceğiz.

ot-daemon, OpenThread çekirdeğinin hizmet olarak çalıştırılabilmesi için giriş ve çıkış olarak UNIX soketi kullanan bir OpenThread Posix uygulaması modudur. Bir istemci, protokol olarak OpenThread CLI'yı kullanarak yuvaya bağlanarak bu hizmetle iletişim kurabilir.

ot-ctl, ot-daemon tarafından RCP'yi yönetmek ve yapılandırmak için sağlanan bir KSA'dır. Bu şekilde, RCP'yi Thread cihazı tarafından oluşturulan ağa bağlarız.

ot-daemon kullanın

Bu alıştırmada üç terminal penceresi kullanılacaktır:

  1. Simüle edilmiş İleti Dizisi cihazının CLI örneği (Düğüm 1)
  2. ot-daemon işlem
  3. ot-ctl KSA örneği

Önceki egzersize devam ederseniz iki açık pencereniz açık olmalıdır. Bu alıştırmada üç terminal aralığınız olduğundan emin olmak için bir üçüncü taraf açın.

1. Düğüm 1'i başlat

İlk terminal penceresinde, simüle edilen İş Parçacığı cihazınız için CLI işlemi oluşturun:

$ cd ~/src/openthread
$ ./output/simulation/bin/ot-cli-ftd 1

Not: Bu komutu çalıştırdıktan sonra > istemini görmüyorsanız enter tuşuna basın.

Yeni bir Operasyonel Veri Kümesi oluşturun, bunu etkin veri kümesi olarak belirleyin ve İleti Dizisini başlatın:

> dataset init new
Done
> dataset
Active Timestamp: 1
Channel: 13
Channel Mask: 07fff800
Ext PAN ID: 97d584bcd493b824
Mesh Local Prefix: fd55:cf34:dea5:7994/64
Network Key: ba6e886c7af50598df1115fa07658a83
Network Name: OpenThread-34e4
PAN ID: 0x34e4
PSKc: 38d6fd32c866927a4dfcc06d79ae1192
Security Policy: 0, onrcb
Done

Bu veri kümesini etkin veri kümesi olarak verin:

> dataset commit active
Done

IPv6 arayüzünü getirin:

> ifconfig up
Done

Mesaj Dizisi protokol işlemini başlatın:

> thread start
Done

Düğüm 1's Mesaj Dizisi arayüzüne atanan IPv6 adreslerini görüntüleyin:

> ipaddr
fd55:cf34:dea5:7994:0:ff:fe00:fc00
fd55:cf34:dea5:7994:0:ff:fe00:d000
fd55:cf34:dea5:7994:460:872c:e807:c4ab
fe80:0:0:0:9cd8:aab6:482f:4cdc
Done
>

Bir İş Parçacığı ağı simüle et adımında açıklandığı gibi, bir adres bağlantı yerel (fe80), üçü ise örgü yerel (fd) şeklindedir. EID, adreste ff:fe00 içermeyen örgü yerel adresidir. Bu örnek çıktıda EID, fd55:cf34:dea5:7994:460:872c:e807:c4ab şeklindedir.

ipaddr çıkışınızdan belirli EID'yi tanımlayın. Bu kimlik, düğümle iletişim kurmak için kullanılır.

2. Ot Daemon'u başlat

İkinci terminal penceresinde openthread dizinine gidin ve bir RCP düğümü ot-daemon başlatın. Bu düğüme Düğüm 2 adını verelim. Günlük ayrıntısını görmek ve çalıştığını doğrulamak için -v ayrıntılı işaretini kullanın:

$ cd ~/src/openthread
$ ./output/posix/bin/ot-daemon -v \
    'spinel+hdlc+forkpty://output/simulation/bin/ot-rcp?forkpty-arg=2'

Başarılı olduğunda, ayrıntılı modda ot-daemon aşağıdakine benzer bir çıkış oluşturur:

ot-daemon[228024]: Running OPENTHREAD/20191113-00831-gfb399104; POSIX; Jun 7 2020 18:05:15
ot-daemon[228024]: Thread version: 2
ot-daemon[228024]: RCP version: OPENTHREAD/20191113-00831-gfb399104; SIMULATION; Jun 7 2020 18:06:08

Bu terminali açık ve arka planda çalışır durumda bırakın. Bu alana başka komutlar girmeyeceksiniz.

3. Ağa katılmak için ot-ctl kullanma

Henüz herhangi bir ileti dizisi ağına 2. Düğüm (ot-daemon RCP) yaptırmadık. ot-ctl tanıtımı burada devreye girer. ot-ctl, OpenThread CLI uygulamasıyla aynı KSA'yı kullanır. Bu nedenle, ot-daemon düğümlerini diğer simüle edilmiş İş Parçacığı cihazlarıyla aynı şekilde kontrol edebilirsiniz.

Üçüncü bir terminal penceresinde ot-ctl başlatın:

$ ./output/posix/bin/ot-ctl
>

ot-daemon ile ikinci terminal penceresinde başlattığınız Düğüm 2'yi (RCP düğümü) yönetmek için bu üçüncü terminal penceresinde ot-ctl kullanırsınız. Düğüm 2'nin state bilgisini kontrol edin:

> state
disabled
Done

Belirli bir Birleştirici'ye katılımı kısıtlamak için Düğüm 2'nin eui64 numarasını alın:

> eui64
18b4300000000001
Done

Düğüm 1'de (ilk terminal penceresi), Komisyoncuyu başlatın ve birleştirme işlemini yalnızca bu eui64 ile kısıtlayın:

> commissioner start
Done
> commissioner joiner add 18b4300000000001 J01NME
Done

Düğüm 2'de (üçüncü terminal penceresi) ağ arayüzünü açıp ağa katılın:

> ifconfig up
Done
> joiner start J01NME
Done

... onay için birkaç saniye bekleyin ...

Join success

Bir Katılımcı olarak RCP (Düğüm 2), Komisyon (Düğüm 1) ile kendi kimliğini başarıyla doğrulamıştır ve İleti Dizisi Ağı kimlik bilgilerini almıştır.

Şimdi Düğüm 2'yi İleti Dizisi ağına ekleyin:

> thread start
Done

4. Ağ kimlik doğrulamasını doğrulama

Ağa katıldığını doğrulamak için Düğüm 2'deki state öğesini kontrol edin. İki dakika içinde, 2. Düğüm child - router geçişi yapar:

> state
child
Done
...
> state
router
Done

5. Bağlantıyı doğrulayın

Ctrl+D veya exit komutunu kullanarak ve ana makinenizin komut satırında EID'yi ping6 komutuyla kullanarak Düğüm 1'i pingleyerek ot-ctl uygulamasından çıkın. ot-daemon RCP örneği, İş Parçacığı ağına başarıyla katılır ve bu ağla iletişim kurarsa ping başarılı olur:

$ ping6 -c 4 fd55:cf34:dea5:7994:460:872c:e807:c4ab
PING fd55:cf34:dea5:7994:460:872c:e807:c4ab (fd55:cf34:dea5:7994:460:872c:e807:c4ab): 56 data bytes
64 bytes from fd55:cf34:dea5:7994:460:872c:e807:c4ab: icmp_seq=0 ttl=64 time=4.568 ms
64 bytes from fd55:cf34:dea5:7994:460:872c:e807:c4ab: icmp_seq=1 ttl=64 time=6.396 ms
64 bytes from fd55:cf34:dea5:7994:460:872c:e807:c4ab: icmp_seq=2 ttl=64 time=7.594 ms
64 bytes from fd55:cf34:dea5:7994:460:872c:e807:c4ab: icmp_seq=3 ttl=64 time=5.461 ms
--- fd55:cf34:dea5:7994:460:872c:e807:c4ab ping statistics ---
4 packets transmitted, 4 packets received, 0% packet loss
round-trip min/avg/max/stddev = 4.568/6.005/7.594/1.122 ms

7. Tebrikler!

OpenThread öğesini kullanarak ilk İş Parçacığı ağınızı başarıyla simüle ettiniz. Mükemmel!

Bu Codelab'de şunları nasıl yapacağınızı öğrendiniz:

  • OpenThread derleme araç zincirini ayarlama
  • Mesaj Dizisi ağını simüle etme
  • Mesaj Dizisi düğümlerinin kimliğini doğrulama
  • Bir İş Parçacığı ağını OpenThread Daemon ile yönetme

Daha fazla bilgi edinmek istiyorsanız şu referansları keşfedin: