Thread가 네트워크에서 각 기기를 식별하는 방식과 서로 통신하는 데 사용하는 주소 유형을 살펴보겠습니다.
범위

스레드 네트워크에 유니캐스트 주소 지정을 위한 세 가지 범위가 있습니다.
- 링크-로컬 — 단일 무선 전송으로 도달할 수 있는 모든 인터페이스
- Mesh-Local — 동일한 스레드 네트워크 내에서 모든 인터페이스에 연결 가능
- 전역 — 스레드 네트워크 외부에서 연결할 수 있는 모든 인터페이스
처음 두 범위는 스레드 네트워크에서 지정한 프리픽스에 해당합니다.
Link-Local에는 fe80::/16
접두사가 있는 반면 Mesh-Local에는 fd00::/8
접두사가 있습니다.
Unicast
단일 스레드 기기를 식별하는 여러 IPv6 유니캐스트 주소가 있습니다. 범위와 사용 사례에 따라 함수도 다릅니다.
각 유형을 자세히 알아보기 전에 먼저 라우팅 로케이터 (RLOC)라고 하는 일반적인 유형을 자세히 알아보겠습니다. RLOC는 네트워크 토폴로지의 위치를 기반으로 스레드 인터페이스를 식별합니다.
라우팅 로케이터가 생성되는 방식
모든 기기에 라우터 ID와 하위 ID가 할당됩니다. 각 라우터는 토폴로지 내에서 기기를 고유하게 식별하는 모든 하위 요소의 테이블을 유지합니다. 예를 들어 다음 토폴로지에서 강조표시된 노드를 가정해 보겠습니다. 여기서 라우터 (오각형)의 번호는 라우터 ID이고 최종 기기 (원)의 번호는 하위 ID입니다.

각 하위 요소의 라우터 ID는 상위 요소 (라우터)입니다. 라우터는 하위 요소가 아니므로 라우터의 하위 ID는 항상 0입니다. 이러한 값은 스레드 네트워크의 각 기기에 대해 고유하며 RLOC의 마지막 16비트를 나타내는 RLOC16을 생성하는 데 사용됩니다.
예를 들어 다음은 왼쪽 상단 노드에 대한 RLOC16을 계산하는 방법입니다 (라우터 ID = 1 및 하위 ID = 1).

RLOC16은 IPv6 주소의 마지막 64비트에 해당하는 인터페이스 식별자 (IID)의 일부입니다. 일부 IID는 일부 유형의 스레드 인터페이스를 식별하는 데 사용할 수 있습니다. 예를 들어 RLOC의 IID는 항상 다음과 같은 형식입니다.
0000:00ff:fe00:RLOC16
IID를 Mesh-Local Prefix와 함께 사용하면 RLOC가 됩니다. 예를 들어 fde5:8dba:82e1:1::/64
의 Mesh-Local 프리픽스를 사용하면 RLOC16 = 0x401
인 노드의 RLOC는 다음과 같습니다.

이 동일한 로직을 사용하여 위의 샘플 토폴로지에서 강조표시된 모든 노드의 RLOC를 확인할 수 있습니다.

그러나 RLOC는 토폴로지의 노드 위치를 기반으로 하므로 토폴로지가 변경되면 노드의 RLOC가 변경될 수 있습니다.
예를 들어 노드 0x400
가 스레드 네트워크에서 삭제될 수 있습니다. 0x401
노드와 0x402
노드는 서로 다른 라우터에 대한 새 링크를 설정하므로 각각 새 RLOC16 및 RLOC가 할당됩니다.

Unicast 주소 유형
RLOC는 스레드 기기가 보유할 수 있는 여러 IPv6 유니캐스트 주소 중 하나일 뿐입니다. 또 다른 주소 카테고리인 EID (엔드포인트 식별자)는 스레드 네트워크 파티션 내의 고유한 스레드 인터페이스를 식별합니다. EID는 스레드 네트워크 토폴로지와는 별개입니다.
일반적인 유니캐스트 유형은 아래에 자세히 설명되어 있습니다.
링크-로컬 주소 (LLA) |
|
---|---|
단일 무선 전송으로 연결할 수 있는 스레드 인터페이스를 식별하는 EID | |
예 | fe80::54db:881c:3845:57f4 |
IID | 802.15.4 확장 주소 기반 |
범위 | 로컬 링크 |
세부정보 |
|
메시-로컬 EID (ML-EID) |
|
---|---|
네트워크 토폴로지와 관계없이 스레드 인터페이스를 식별하는 EID 동일한 스레드 파티션 내의 스레드 인터페이스에 도달하는 데 사용됩니다. 고유 지역 주소 (ULA)라고도 합니다. | |
예 | fde5:8dba:82e1:1:416:993c:8399:35ab |
IID | 무작위, 의뢰 완료 후 선택됨 |
범위 | 메시-로컬 |
세부정보 |
|
라우팅 로케이터 (RLOC) |
|
---|---|
네트워크 토폴로지의 위치를 기반으로 스레드 인터페이스를 식별합니다. | |
예 | fde5:8dba:82e1:1::ff:fe00:1001 |
IID | 0000:00ff:fe00:RLOC16 |
범위 | 메시-로컬 |
세부정보 |
|
Anycast Locator (ALOC) |
|
---|---|
대상의 RLOC를 알 수 없는 경우 RLOC 조회를 통해 스레드 인터페이스를 식별합니다. | |
예 | fde5:8dba:82e1:1::ff:fe00:fc01 |
IID | 0000:00ff:fe00:fcXX |
범위 | 메시-로컬 |
세부정보 |
|
전역 유니캐스트 주소 (GUA) |
|
---|---|
스레드 네트워크 외의 전역 범위에서 스레드 인터페이스를 식별하는 EID | |
예 | 2000::54db:881c:3845:57f4 |
IID |
|
범위 | 전역 |
세부정보 |
|
멀티캐스트
멀티캐스트는 여러 기기에 정보를 한 번에 통신하는 데 사용됩니다. 스레드 네트워크에서 특정 주소는 범위에 따라 서로 다른 기기 그룹에서 멀티캐스트 사용을 위해 예약됩니다.
IPv6 주소 | 범위 | 받는사람: |
---|---|---|
ff02::1 |
로컬 링크 | 모든 FTD 및 MED |
ff02::2 |
로컬 링크 | 모든 FTD |
ff03::1 |
메시-로컬 | 모든 FTD 및 MED |
ff03::2 |
메시-로컬 | 모든 FTD |
Sleepy End Devices (SED)는 위의 멀티캐스트 표에 수신자로 포함되지 않은 것을 알 수 있습니다. 대신 스레드는 SED를 포함하여 모든 스레드 노드에 사용되는 링크-로컬 및 영역 로컬 범위 유니캐스트 프리픽스 기반 IPv6 멀티캐스트 주소를 정의합니다. 이러한 멀티캐스트 주소는 유니캐스트 메시-로컬 프리픽스에 빌드되어 있으므로 스레드 네트워크에 따라 다릅니다 (유니캐스트 프리픽스 기반 IPv6 멀티캐스트 주소에 관한 자세한 내용은 RFC 3306을 참조하세요).
스레드 목록에 이미 나열된 범위를 초과하는 임의의 범위도 지원됩니다.
Anycast
Anycast는 대상의 RLOC를 알 수 없는 경우 트래픽을 스레드 인터페이스로 라우팅하는 데 사용됩니다. Anycast Locator (ALOC)는 스레드 파티션 내에서 여러 인터페이스의 위치를 식별합니다. ALOC16이라고 하는 ALOC의 마지막 16비트는 ALOC 유형을 나타내는 0xfcXX
형식입니다.
예를 들어 0xfc01
과 0xfc0f
사이의 ALOC16은 DHCPv6 에이전트용으로 예약되어 있습니다. 특정 DHCPv6 에이전트 RLOC를 알 수 없다면 (네트워크 토폴로지가 변경된 경우) RLOC를 가져오기 위해 DHCPv6 에이전트 ALOC에 메시지를 보낼 수 있습니다.
스레드는 다음 ALOC16 값을 정의합니다.
ALOC16 | 유형 |
---|---|
0xfc00 |
선두 |
0xfc01 ~0xfc0f |
DHCPv6 에이전트 |
0xfc10 ~0xfc2f |
서비스 |
0xfc30 ~0xfc37 |
협회 회장 |
0xfc40 ~0xfc4e |
이웃 탐색 에이전트 |
0xfc38 ~0xfc3f 0xfc4f ~0xfcff |
예약됨 |
요약
지금까지 학습한 내용은 다음과 같습니다.
- 스레드 네트워크는 링크-로컬, 메시-로컬, 글로벌의 세 가지 범위로 구성됩니다.
- 스레드 기기에 유니캐스트 IPv6 주소가 여러 개 있음
- RLOC는 스레드 네트워크에서 기기의 위치를 나타냅니다.
- ML-EID는 파티션 내의 스레드 기기에 고유하며 애플리케이션에서 사용해야 합니다.
- 스레드가 멀티캐스트를 사용하여 노드 및 라우터 그룹에 데이터 전달
- 대상의 RLOC를 알 수 없는 경우 스레드는 Anycast를 사용합니다.
스레드의 IPv6 주소 지정에 관한 자세한 내용은 스레드 사양의 섹션 5.2와 5.3을 참고하세요.
이해도 확인
ff03::2
멀티캐스트 주소를 구독합니다. 기기에 관해 어떤 정보를 제공하나요?ff03::2
멀티캐스트 주소를 구독합니다. 메시-로컬 범위에서 지정합니다.