WireGuard 教程:WireGuard 的工作原理
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
無論你是想破墻而出,還是想在服務器之間組網,WireGuard 都不會讓你失望,它就是組網的『樂高積木』,就像 ZFS 是構建文件系統的『樂高積木』一樣。 WireGuard 與其他 威屁恩 協議的性能測試對比: 可以看到 WireGuard 直接碾壓其他 威屁恩 協議。再來說說 WireGuard 優點:
WireGuard 不能做的事:
當然,你可以使用 WireGuard 作為底層協議來實現自己想要的功能,從而彌補上述這些缺憾。 本系列 WireGuard 教程分為兩個部分,第一部分偏理論,第二部分偏實踐。本文是第一部分,下面開始正文教程。 1. WireGuard 術語 Peer/Node/Device連接到 威屁恩 并為自己注冊一個 威屁恩 子網地址(如 192.0.2.3)的主機。還可以通過使用逗號分隔的 CIDR 指定子網范圍,為其自身地址以外的 IP 地址選擇路由。 中繼服務器(Bounce Server)一個公網可達的對等節點,可以將流量中繼到 子網(Subnet)一組私有 IP,例如 CIDR 表示法這是一種使用掩碼表示子網大小的方式,這個不用解釋了。 NAT子網的私有 IP 地址由路由器提供,通過公網無法直接訪問私有子網設備,需要通過 NAT 做網絡地址轉換。路由器會跟蹤發出的連接,并將響應轉發到正確的內部 IP。 公開端點(Public Endpoint)節點的公網 IP 地址:端口,例如 私鑰(Private key)單個節點的 WireGuard 私鑰,生成方法是: 公鑰(Public key)單個節點的 WireGuard 公鑰,生成方式為: DNS域名服務器,用于將域名解析為 威屁恩 客戶端的 IP,不讓 DNS請求泄漏到 威屁恩 之外。 2. WireGuard 工作原理 中繼服務器工作原理中繼服務器(Bounce Server)和普通的對等節點一樣,它能夠在 如果所有的對等節點都是公網可達的,則不需要考慮中繼服務器,只有當有對等節點位于 NAT 后面時才需要考慮。 在 WireGuard 里,客戶端和服務端基本是平等的,差別只是誰主動連接誰而已。雙方都會監聽一個 UDP 端口,誰主動連接,誰就是客戶端。主動連接的客戶端需要指定對端的公網地址和端口,被動連接的服務端不需要指定其他對等節點的地址和端口。如果客戶端和服務端都位于 NAT 后面,需要加一個中繼服務器,客戶端和服務端都指定中繼服務器作為對等節點,它們的通信流量會先進入中繼服務器,然后再轉發到對端。 WireGuard 是支持漫游的,也就是說,雙方不管誰的地址變動了,WireGuard 在看到對方從新地址說話的時候,就會記住它的新地址(跟 mosh 一樣,不過是雙向的)。所以雙方要是一直保持在線,并且通信足夠頻繁的話(比如配置 Wireguard 如何路由流量利用 WireGuard 可以組建非常復雜的網絡拓撲,這里主要介紹幾個典型的拓撲: ① 端到端直接連接 這是最簡單的拓撲,所有的節點要么在同一個局域網,要么直接通過公網訪問,這樣 ② 一端位于 NAT 后面,另一端直接通過公網暴露 這種情況下,最簡單的方案是:通過公網暴露的一端作為服務端,另一端指定服務端的公網地址和端口,然后通過 ③ 兩端都位于 NAT 后面,通過中繼服務器連接 大多數情況下,當通信雙方都在 NAT 后面的時候,NAT 會做源端口隨機化處理,直接連接可能比較困難。可以加一個中繼服務器,通信雙方都將中繼服務器作為對端,然后維持長連接,流量就會通過中繼服務器進行轉發。 ④ 兩端都位于 NAT 后面,通過 UDP NAT 打洞 上面也提到了,當通信雙方都在 NAT 后面的時候,直接連接不太現實,因為大多數 NAT 路由器對源端口的隨機化相當嚴格,不可能提前為雙方協調一個固定開放的端口。必須使用一個信令服務器( 如果某一端同時連接了多個對端,當它想訪問某個 IP 時,如果有具體的路由可用,則優先使用具體的路由,否則就會將流量轉發到中繼服務器,然后中繼服務器再根據系統路由表進行轉發。你可以通過測量 ping 的時間來計算每一跳的長度,并通過檢查對端的輸出( WireGuard 報文格式WireGuard 使用加密的 UDP 報文來封裝所有的數據,UDP 不保證數據包一定能送達,也不保證按順序到達,但隧道內的 TCP 連接可以保證數據有效交付。WireGuard 的報文格式如下圖所示: 關于 WireGuard 報文的更多信息可以參考下面幾篇文檔: WireGuard 的性能WireGuard 聲稱其性能比大多數 威屁恩 協議更好,但這個事情有很多爭議,比如某些加密方式支持硬件層面的加速。 WireGuard 直接在內核層面處理路由,直接使用系統內核的加密模塊來加密數據,和 Linux 原本內置的密碼子系統共存,原有的子系統能通過 關于性能比較的更多信息可以參考下面幾篇文檔:
WireGuard 安全模型WireGuard 使用以下加密技術來保障數據的安全:
WireGuard 的加密技術本質上是 關于 WireGuard 加密的更多資料請參考下方鏈接: WireGuard 密鑰管理WireGuard 通過為每個對等節點提供簡單的公鑰和私鑰來實現雙向認證,每個對等節點在設置階段生成密鑰,且只在對等節點之間共享密鑰。每個節點除了公鑰和私鑰,不再需要其他證書或預共享密鑰。 在更大規模的部署中,可以使用 下面是一些有助于密鑰分發和部署的服務: 如果你不想在
從技術上講,多個服務端之間可以共享相同的私鑰,只要客戶端不使用相同的密鑰同時連接到兩個服務器。但有時客戶端會需要同時連接多臺服務器,例如,你可以使用 該文章在 2024/7/24 18:54:39 編輯過 |
關鍵字查詢
相關文章
正在查詢... |