SoftEther VPN
SoftEther VPN是一個由日本程式設計師登大遊(日語:登 大遊)因就讀筑波大學時的碩士論文研究主題而開發的開源、跨平台、多重協定之虛擬私人網路方案,此方案讓一些虛擬私人網路協定像是SSL VPN、L2TP、IPsec、OpenVPN以及微軟SSTP都由同一個VPN伺服器提供。在2014年1月4日以GNU通用公共授權條款的方式轉變為開源軟件。2019年1月21日轉變為Apache License 2.0授權。
原作者 | 筑波大學的SoftEther VPN 項目 |
---|---|
開發者 | Daiyuu Nobori、Tetsuo Sugiyama、Takao Ito、Christopher Smith、Mei Sharie Ann Yamaguchi和其他開發者[1] |
首次發布 | 2014年1月4日 |
當前版本 |
|
源代碼庫 | |
編程語言 | C語言及C++ |
操作系統 | Windows、Linux、MacOS、FreeBSD、 Solaris、iOS、Android |
語言 | 英文、日文、簡體中文[3] |
類型 | VPN |
許可協議 | GPL v2 [4] Apache License 2.0(自2019年1月21日起)[5] |
網站 | www |
SoftEther VPN是專門被設計為穿過防火牆的,支援NAT穿透,使其能越過政府或組織的防火牆建立VPN通道。2013年3月,官方開始提供VPN Gate公共VPN中繼服務器列表插件,以簡化高強度網絡審查地區有突破網絡封鎖(翻牆)需求的用戶的操作複雜程度。因為用了HTTPS來偽裝連接,防火牆的深度封包檢測無法偵測到SoftEther的VPN傳送封包構成的VPN通道。但SoftEther的SSL VPN協定在中國大陸的部分地區仍然被封鎖。[來源請求]
性能優化也是SoftEther VPN的一個目標。它使用像是利用全部乙太網幀的策略,減少了記憶體複製的操作、平行傳輸和群集,這減少了通常VPN連接會有的延遲並增加了運輸吞吐量。
互用性
編輯VPN伺服器和VPN橋接器支援微軟、Linux、Mac OS X(除了10.9.x)、FreeBSD還有Solaris這些作業系統。SoftEther VPN支援自己的VPN協定但可以和OpenVPN、微軟Secure Socket Tunneling Protocol(SSTP)、SSL VPN、EtherIP、L2TPv3、IPsec相容。藉由L2TP/IPsec/OpenVPN/SSTP,可以支援行動裝置系統如iOS、安卓、微軟Windows手機。SoftEther自身的VPN客戶端支援微軟、Linux、Mac。支援其他VPN協定的VPN客戶端和終端也可能會被使用;這包括了來自諸如思科、Juniper、Linksys(有DD-WRT)、Asus等等公司生產的各式各樣的路由器。
軟件組成
編輯VPN伺服器
編輯SoftEther VPN伺服器和其他VPN伺服器一樣,功能是接聽來自客戶端或橋接器使用各式協定的連接。
一個VPN伺服器可以有好幾個虛擬的集線器和交換器。虛擬集線器和實體的交換器一樣,有完整的第二層網路封包交換功能。此外,虛擬集線器能被配置來定義IP封包過濾項目,過濾經過集線器的封包。虛擬的Network layer層交換器則像實體的路由器一樣,有第三層IP靜態路由功能。
一個VPN伺服器可以有自帶的橋接器。這個橋接器是一個在實體網路轉接器和虛擬集線器之間的封包交換結構。系統管理員定義連接虛擬集線器和現有的企業網路之間的橋接器,去建立一個遠端存取的或站對站的VPN伺服器。
VPN客戶端
編輯SoftEther VPN客戶端是個虛擬化的網路適配器。一個有安裝客戶端程式的電腦能建立與伺服器的連接。因為VPN伺服器支援多種VPN協定的關係,VPN使用者並不需要在電腦上安裝SofthEther VPN客戶端,而是用內建在作業系統內的VPN客戶端程式建立連接。然而,SoftEther VPN客戶端比系統內建程式還多了些進階功能。想要充分利用SothEther VPN伺服器的全部效能的話,建議還是安裝客戶端程式。
VPN橋接器
編輯SoftEther VPN橋接器是個建立站對站VPN的程式。要建立這樣的VPN,系統管理員必須安裝SoftEther VPN伺服器程式在中央電腦,然後要一個以上的遠端電腦安裝VPN橋接器。VPN橋接器會以級聯連接連接中央VPN伺服器。級連連接類似在兩個實體網路交換機之間,一個虛擬化的上行連接。
VPN伺服器微軟版管理程式
編輯這是個SoftEther VPN伺服器和橋接器會用到的圖型化介面管理工具。系統管理員可用來連接遠端的伺服器或橋接器並管理。連接使用了SSL,管理指令則用RPC在SSL上傳輸。
VPN命令行管理實用工具
編輯vpncmd是個自訂介面管理工具,用在伺服器、各戶端和橋接器上。它可以在所有支援的作業系統上執行。當有使用者無法用Wine執行微軟或Linux時,它可以轉換到vpncmd來管理VPN。vpncmd也很適合用來執行批量操作,例如在虛擬集線器上創建好幾個使用者,或在伺服器上創建好幾個虛擬集線器。
架構
編輯SoftEther VPN某些部分的架構有別一般傳統使用IPsec的VPN系統。
虛擬集線器
編輯虛擬集線器就是以軟體方式模擬網路交換機。它會更新和維持自身擁有的轉發資料對照表(MAC 位址表)。雖然傳統的網路交換機將這功能做在硬體上,SoftEther VPN以軟體實現了同樣功能。一個VPN伺服器可以有好幾個虛擬集線器,各自獨立。VPN客戶端和橋接端的連接就是以集線器用封包交換來處理。
當一個伺服器上有數個虛擬的集線器時,為了安全,這些集線器都會獨立分開。各個不同的管理員可以對相應的虛擬集線器授予權限。每個虛擬極限的管理員可以限定使用者物件和ACLs,而這僅限於被授權的集線器上。
虛擬網絡轉接器
編輯一個VPN客戶端可以在自己的電腦上創立數個網路轉接器。VPN使用者能在虛擬網路轉接器和遠端目標的虛擬集線器間建立可用連接。當建立了可用連接,使用者就能藉此和遠端的VPN網路溝通。它可以讓任何程式或作業系統不用特定設定就能使用,就和硬體版的使用方式一樣。
虛擬交換機
編輯它以軟體方式模擬了IP路由器。一個伺服器上可以同時間創立好幾個虛擬交換機。虛擬交換機有虛擬的IP介面連接虛擬集線器。它也有幾個固定的對照表上的分配項目。
虛擬交換機也適合用來做大型的站對站VPN網路。雖然有個簡單的方式可以達成,就是用橋接建立VPN,但如果有很多台電腦,輸入站點間的連接的廣播封包數量就會大增。為了預防這樣規模擴張的問題,VPN管理者用虛擬交換機來隔絕IP網路。
虛擬集線器之間的級聯連接
編輯管理員可以在地區或遠端的虛擬集線器間定義一個級聯連接。當級聯連接被設立,原先獨立的兩個網段就被整合成一個了。所以這個級聯連接功能被用來建立站對站的橋接。
虛擬集線器和網路間的地區橋接器
編輯因為虛擬集線器和虛擬網路轉接器都只是軟體模擬的裝置,藉此傳送的封包是無法和硬體設備溝通的。因此,需要一個模擬和實體裝置之間的橋接,才能建立遠端存取VPN或站對站VPN。要做出橋接,地區橋接器功能轉會轉換虛擬集線器和實體網路轉接器間的封包,結合兩個獨立網段成為一個單一的網段。
在VPN伺服器上定義過地區橋接器後,各VPN客戶端就可以藉由地區橋接器,連到VPN伺服器並和其他網路上的裝置溝通。這就是遠端存取VPN。
如果網路管理者設立了遠端站點VPN橋接器,並在VPN伺服器和VPN橋接器上分別定義了兩個地區橋接,然後定義伺服器和橋接器間的級聯連接,遠端的兩個網段在第二層級上就會直接連在一起。這就是站對站VPN。
防火牆,代理服務器
編輯SoftEther VPN很重要的功能是對防火牆的穿透和藉助代理服務器中轉VPN流量。為此,SoftEther VPN支援SSL-VPN。它使用HTTPS協定來建立VPN通道,可以與Web網站同樣使用TCP/IP 443端口。
可使用多條TCP連接的傳輸機制
編輯當使用者選擇SSL-VPN協定時,SoftEther VPN伺服器和客戶端會用一套平行傳輸機制來改善SSL-VPN通道的吞吐量。使用者可以創建1到32條TCP連接同時並行傳輸。當處在一個網速非常慢的地方時,這項性能調整會導致更快的吞吐量。一旦這功能被啟用,邏輯VPN連接將包含多個TCP(HTTPS)連接。所有的封包將會在適當的TCP連接中,被加進最佳化模組的運算。如果邏輯VPN連接的TCP連接偵測到封包的遺失,新的封包就使用其他正常的TCP連接。這項快速切換最佳化的功能造就高吞吐量。
NAT穿透
編輯傳統的VPN系統需要使用者去請求公司的防火牆管理者,在防火牆或公司與網路間的NAT開放一個終端點(TCP或UDP端口)。為了減少需要開放終端點的情形,SoftEther VPN伺服器有NAT通透功能。NAT通透會預設是啟動狀態。只要它啟動,VPN客戶端的電腦就能連接到被防火牆或NAT阻隔的VPN伺服器,不需要在防火牆或NAT上特別設定。
通過ICMP和DNS上的VPN
編輯有少數限制很多的網路只允許通過ICMP或DNS的封包。在這種情形,TCP或UDP會被濾掉。為了讓SoftEther VPN也能在這種網路建立連接,SoftEther VPN有特別為此設計的VPN功能。
這功能對穿過這樣嚴格的防火牆非常有用。所有的VPN封包都再度包成ICMP或DNS封包來傳輸。接收端會從外層提出內層的封包。因為有些公共Wi-Fi只能通過ICMP或DNS封包,這讓在公共Wi-Fi也能使用VPN。如果你為了出門,安裝一個伺服器在家中或辦公室,你可以在限制網路中享受這自由協定的網路通訊。
缺陷
編輯SoftEtherVPN服務端同時支持SoftEtherVPN、OpenVPN、L2TP、IPsec、SSTP等。儘管SoftEtherVPN因為使用Https通訊可以抵抗GFW的深度包檢測,但服務端的OpenVPN等功能若是開啟仍會暴露出VPN服務器的存在。
VPN Gate
編輯VPN Gate是個SoftEther VPN的插件,它讓使用者能連接由志願者提供,在自家電腦安裝SoftEther的免費公共VPN伺服器,此功能可用於幫助用戶繞過政府的互聯網審查。VPN Gate由筑波大學贊助。
參考資料
編輯- ^ Authors of SoftEther VPN on GitHub. [2018-01-25]. (原始內容存檔於2019-02-17).
- ^ Release 5.02.5181.
- ^ Multi-language, Single Binary Package and Unicode Support. [2018-09-07]. (原始內容存檔於2018-09-07).
- ^ License of SoftEther VPN. [2018-09-07]. (原始內容存檔於2018-09-07).
- ^ Declaration of license switch for SoftEther VPN from GPLv2 to Apache License 2.0. 2019-01-21. (原始內容存檔於2020-08-05).