跳至內容

ISATAP

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書

ISATAP(Intra-Site Automatic Tunnel Addressing Protocol)是一種IPv6轉換傳送機制,允許IPv6數據包通過IPv4網絡上雙棧節點傳輸。

不同於6over4,ISATAP視IPv4網絡為一個非廣播多路訪問網絡數據鏈路層,因此它不需要底層的IPv4網絡基礎設施來支持多播。

運行方法

[編輯]

ISATAP包含一種基於IPv4地址生成IPv6本地鏈路地址的方法,和基於IPv4網絡的鄰居發現機制。

地址產生

[編輯]

任何一個希望通過特定IPv4網絡使用ISATAP的主機都可以建立虛擬的IPv6網絡接口。將主機的IPv4地址比特串加上特定IPv6前綴作為接口的IPv6地址,對於全球單播地址使用fe80::0200:5efe:,對於專用網絡地址則使用fe80::0000:5efe:。例如,一個主機IPv4地址為192.0.2.143,則其ISATAP接口的IPv6地址為fe80::0200:5efe:192.0.2.143,轉為完整最短IPv6為fe80::200:5efe:c000:28fc000:28f為其IPv4地址192.0.2.143的十六進制值)。[1]

鄰居發現

[編輯]

由於ISATAP將IPv4基礎網絡視為一個非廣播或多播多路訪問網絡的數據鏈路層,不同於以太網,使其原有的ICMPv6鄰居發現不能如常操作,使ISATAP比6over4的運作有所困難。

對於IPv6數據包來說,IPv4網絡是它的物理鏈路層,由於其IPv6地址已經包含了作為鏈路層的地址,即IPv4地址,所以其無需進行鄰居發現。但是缺少多播功能導致其無法進行路由自動發現,所以ISATAP主機必須配置一個潛在路由器列表(potential routers list,PRL),這列表中的路由器通常不需要使用ICMPv6的路由發現來尋獲和確定其是否已在線可運行,並且其只進行單播地址自動配置(通常可以藉此為ISATAP的接口自動配置到其他IPv6前綴)。

實際上,PRL是通過DNS查詢獲得,例如如果本地網絡域名為example.com,可通過查詢isatap.example.com。本地網絡域名通過IPv4網路上的DHCP或者本地靜態配置獲得。

實現

[編輯]

ISATAP已經在Microsoft Windows XPWindows VistaWindows 7Windows 8Windows 10(但在1703更新中默認關閉,1803更新後會移除)[2]Windows Server 2008Windows Server 2012Windows MobileLinuxCisco IOS(自IOS 12.2(14)S、 IOS XE Release 2.1)[3]中實現。

由於專利權利要求,早期在KAME英語KAME project(*BSD)和USAGI(Linux)的內核實現被移除過,然而,IETF知識產權披露搜索引擎報道,該侵權專利的持有者不需要實現者的許可。[4]Linux內核自2.6.35版本實現了內核支持,[5]並提供了一個用戶空間配置工具isatapd[6]對於之前的Linux內核,開源項目Miredo提供了一個不完整的用戶空間實現,之後版本1.1.6中被移除。

批評

[編輯]

ISATAP通過查詢DNS來構建PRL,因此,對應於OSI模型,其依賴於一個高層協議來構建低層協議。其依賴於IPv4的DNS來避免循環,而不是IPv6路由的構建。然而,有些網絡專家認為這這違反了他們認為普遍接受的設計原則,並進一步聲稱這些違規行為會導致協議不健全。[7]

ISATAP有着和6over4一樣的安全風險,也就是IPv4虛擬鏈路需要在網絡邊緣被小心地分隔開,以便外部IPv4主機不能假裝成為ISATAP鏈路的一部分。通常是通過將IP協議號為41的IP包(也就是6in4等所使用的IP協議號)使用防火牆來攔截。

參考文獻

[編輯]
  1. ^ R. Hinden, S. Deering. RFC 4291: Section 2.2 - Text Representation of Addresses. IETF. February 2006 [2015-02-09]. (原始內容存檔於2020-03-07). 
  2. ^ lizap. Windows 10, version 1803 - Features that have been removed. docs.microsoft.com. [2018-05-28]. (原始內容存檔於2018-05-09) (美國英語). 
  3. ^ Cisco IOS IPv6 Command Reference. [2015-05-06]. (原始內容存檔於2015-05-16). 
  4. ^ Peter Marcotullio. SRI International's statement about IPR claimed in draft-ietf-ngtrans-isatap-24.txt. 2005-03-15 [2015-02-09]. (原始內容存檔於2015-02-10). 
  5. ^ Fred L. Templin. IPV6: Add RFC4214 support. 2007-11-29 [2015-02-09]. 
  6. ^ Sascha Hlusiak. ISATAP client for Linux. 2010 [2015-02-09]. (原始內容存檔於2015-02-10). 
  7. ^ itojun. Request to Publish ISATAP. v6ops Mailing List. 2002-12-25 [2015-02-09]. (原始內容存檔於2016-03-06). 

外部連結

[編輯]