SoftEther VPN
原作者 | 筑波大學的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是一個由日本程式設計師登大遊(日語:登 大遊)因就讀筑波大學時的碩士論文研究主題而開發的開源、跨平台、多重協定之虛擬私人網路方案,此方案讓一些虛擬私人網路協定像是SSL VPN、L2TP、IPsec、OpenVPN以及微軟SSTP都由同一個VPN伺服器提供。在2014年1月4日以GNU通用公共授權條款的方式轉變為開源軟件。2019年1月21日轉變為Apache License 2.0授權。
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).