docker自建rustdesk-server遠(yuǎn)程桌面的解決方案
rustdesk簡(jiǎn)介
RustDesk 是一款可以平替 TeamViewer 的開(kāi)源軟件,旨在提供安全便捷的自建方案。
RustDesk 是一款功能齊全的遠(yuǎn)程桌面應(yīng)用,具有以下特性:
- 支持 Windows、macOS、Linux、iOS、Android、Web 等多個(gè)平臺(tái)。
- 支持 VP8 / VP9 / AV1 軟件編解碼器和 H264 / H265 硬件編解碼器。
- 完全掌控?cái)?shù)據(jù),輕松自建。
- P2P 連接,端到端加密。
- 在 Windows 上可以非管理員不安裝運(yùn)行,根據(jù)需要在本地或遠(yuǎn)程提升權(quán)限。
- 我們崇尚簡(jiǎn)單,盡一切可能讓它簡(jiǎn)單。
官方網(wǎng)站:https://rustdesk.com/zh/
項(xiàng)目地址:https://github.com/rustdesk/rustdesk
RustDesk 架構(gòu)
RustDesk 采用了經(jīng)典的客戶端-服務(wù)器模型,其中涉及三個(gè)主要組件:RustDesk 客戶端、RustDesk 服務(wù)器和 ID Server。
- RustDesk 客戶端:運(yùn)行在你的設(shè)備上(Windows,macOS,Linux,Android, iPhone)用于連接兩個(gè)設(shè)備的軟件,它負(fù)責(zé)監(jiān)聽(tīng)來(lái)自客戶端的連接請(qǐng)求,并在建立連接后向客戶端發(fā)送屏幕更新和接收輸入事件。
- RustDesk 中繼服務(wù)器(Relay Server):運(yùn)行在服務(wù)器上,充當(dāng)客戶端之間的橋梁,轉(zhuǎn)發(fā)來(lái)自一方的數(shù)據(jù)包到另一方。在某些環(huán)境中(如經(jīng)過(guò) NAT 出網(wǎng))設(shè)備之間無(wú)法進(jìn)行 P2P 連接,可以用服務(wù)器來(lái)中轉(zhuǎn)
- ID 服務(wù)器(ID Server):運(yùn)行在服務(wù)器上,用于維護(hù)客戶端及中繼服務(wù)器的連接信息,促進(jìn)設(shè)備之間建立 P2P 連接。
在RustDesk的服務(wù)器端部署中,hbbr
和 hbbs
是兩個(gè)重要的組件,分別用于不同的功能:
- hbbs - 代表
RustDesk ID / Rendezvous Server
,RustDesk ID注冊(cè)服務(wù)器,用于分配和注冊(cè)ID;hbbs
是RustDesk的中介服務(wù)器(Broker Server),用于管理和協(xié)調(diào)客戶端連接。它幫助客戶端找到并建立P2P連接。hbbs
負(fù)責(zé)維護(hù)客戶端的在線狀態(tài),并處理連接請(qǐng)求。當(dāng)客戶端A希望連接客戶端B時(shí),它會(huì)向hbbs
發(fā)送請(qǐng)求,hbbs
會(huì)幫助它們建立連接。 - hbbr -代表
RustDesk Relay Server
,RustDesk 中繼服務(wù)器,如果P2P無(wú)法連接,會(huì)使用hbbr進(jìn)行流量中繼。hbbr
是RustDesk的中繼服務(wù)器(Relay Server),用于在兩臺(tái)客戶端之間進(jìn)行連接中繼。它允許無(wú)法直接建立P2P連接的客戶端通過(guò)中繼服務(wù)器進(jìn)行通信。當(dāng)客戶端A和客戶端B之間無(wú)法建立直接連接時(shí),它們會(huì)通過(guò)hbbr
中繼服務(wù)器進(jìn)行數(shù)據(jù)傳輸。 - rustdesk-utils - RustDesk 命令行工具
P2P直連說(shuō)明:
- RustDesk 首先嘗試建立直接 P2P 連接,如果 P2P 失敗,將使用中繼服務(wù)器。
- 確認(rèn)連接方式,首先連接到遠(yuǎn)程主機(jī),可以將鼠標(biāo)移動(dòng)到工具欄圖標(biāo)(綠色圖標(biāo)),將顯示它是直接連接還是通過(guò)中繼服務(wù)器連接。
使用端口說(shuō)明:
序號(hào) | 服務(wù) | 端口 | 協(xié)議 | 用途 | 是否可選 |
---|---|---|---|---|---|
1 | hbbs | 21114 | TCP | 用于 Web 控制臺(tái)API,僅在專(zhuān)業(yè)版中可用 | 可選 |
2 | hbbs | 21115 | TCP | NAT類(lèi)型測(cè)試 | 必選 |
3 | hbbs | 21116 | TCP/UDP | UDP用于ID注冊(cè)和心跳服務(wù),TCP用于TCP打洞和連接服務(wù) | 必選 |
4 | hbbr | 21117 | TCP | 用于Relay服務(wù) | 必選 |
5 | hbbs | 21118 | TCP | 用于支持Web客戶端 | 可選 |
6 | hbbr | 21119 | TCP | 用于支持Web客戶端 | 可選 |
部署rustdesk-server
rustdesk支持自行搭建屬于你的RustDesk服務(wù)器,所有的一切都是免費(fèi)且開(kāi)源的。所謂自建服務(wù)器,也就是自建 ID Server 和 Relay Server。
整體部署架構(gòu)如下:
官方文檔:https://github.com/rustdesk/rustdesk-server/blob/master/README-ZH.md
前置部署要求
前置要求:
- 準(zhǔn)備一臺(tái)公網(wǎng)linux服務(wù)器,并綁定公網(wǎng)IP地址,以阿里云輕量應(yīng)用服務(wù)器為例,操作系統(tǒng)為Ubuntu 22.04。
- 服務(wù)器已安裝
docker
和docker-compose
工具
1、登錄阿里云控制臺(tái),配置防火墻規(guī)則,開(kāi)通以下端口
端口放通說(shuō)明:
放通TCP端口21115
、21116
、21117
、21118
、21119
放通UDP端口21116
2、登錄阿里云控制臺(tái),配置域名解析(可選):
配置一條A記錄,將rustdesk-server公網(wǎng)IP地址解析到rustdesk.example.com
域名(需自行準(zhǔn)備域名并進(jìn)行備案)。
部署rustdesk-server
配置主機(jī)名
hostnamectl set-hostname rustdesk-server
創(chuàng)建部署目錄
mkdir -p /data/rustdesk/composecd /data/rustdesk/compose
創(chuàng)建docker-compose文件
root@rustdesk-server:/data/rustdesk/compose# vim docker-compose.yaml services: hbbs: container_name: hbbs image: rustdesk/rustdesk-server:1.1.11 command: hbbs environment: - "RELAY=hbbr:21117" - "ENCRYPTED_ONLY=1" ports: - 21115:21115 - 21116:21116 - 21116:21116/udp - 21118:21118 volumes: - /data/rustdesk/root:/root networks: - rustdesk-net depends_on: - hbbr restart: unless-stopped hbbr: container_name: hbbr image: rustdesk/rustdesk-server:1.1.11 command: hbbr ports: - 21117:21117 - 21119:21119 volumes: - /data/rustdesk/root:/root networks: - rustdesk-net restart: unless-stopped networks: rustdesk-net: external: false
主要參數(shù)說(shuō)明:
- 環(huán)境變量
RELAY
:指定hbbr 服務(wù)的地址和端口,由于使用同一個(gè)docker network,可以通過(guò)容器名稱(chēng)hbbr
連接 - 環(huán)境變量
ENCRYPTED_ONLY
:?jiǎn)⒂眉用苓B接并使用key驗(yàn)證,防止其他獲取地址的客戶端非法連接
執(zhí)行以下命令運(yùn)行容器
root@rustdesk-server:/data/rustdesk/compose# docker-compose up -d [+] Building 0.0s (0/0) docker:default [+] Running 3/3 ? Network compose_rustdesk-net Created 0.1s ? Container hbbr Started 0.1s ? Container hbbs Started
查看運(yùn)行的兩個(gè)容器hbbr
和hbbs
root@rustdesk-server:/data/rustdesk/compose# docker-compose ps NAME IMAGE COMMAND SERVICE CREATED STATUS PORTS hbbr rustdesk/rustdesk-server:1.1.11 "hbbr" hbbr 44 seconds ago Up 43 seconds 0.0.0.0:21117->21117/tcp, :::21117->21117/tcp, 0.0.0.0:21119->21119/tcp, :::21119->21119/tcp hbbs rustdesk/rustdesk-server:1.1.11 "hbbs" hbbs 44 seconds ago Up 42 seconds 0.0.0.0:21115-21116->21115-21116/tcp, :::21115-21116->21115-21116/tcp, 0.0.0.0:21118->21118/tcp, :::21118->21118/tcp, 0.0.0.0:21116->21116/udp, :::21116->21116/udp root@rustdesk-server:/data/rustdesk/compose#
查看主機(jī)當(dāng)前目錄結(jié)構(gòu)
root@rustdesk-server:~# apt install -y tree root@rustdesk-server:~# tree /data/rustdesk/ /data/rustdesk/ ├── compose │ └── docker-compose.yaml └── root ├── db_v2.sqlite3 ├── db_v2.sqlite3-shm ├── db_v2.sqlite3-wal ├── id_ed25519 └── id_ed25519.pub 2 directories, 6 files root@rustdesk-server:~#
連接驗(yàn)證
服務(wù)端搭建好后,在要連接的兩個(gè)客戶端設(shè)備上都下載 RustDesk 客戶端。
下載地址是:https://github.com/rustdesk/rustdesk/releases
在rustdesk-server上獲取默認(rèn)生成的公鑰key
root@rustdesk-server:~# cat /data/rustdesk/root/id_ed25519.pub G2yFoE+0pWWqXAHM174TXbsoUqJB1brHKOxZhEKv7hA=
首先找到 RustDesk 客戶端的 設(shè)置
-> ID/中繼服務(wù)器
,然后輸入如下三個(gè)信息
- ID 服務(wù)器:
rustdesk.example.com:21116
,默認(rèn)端口為21116
時(shí)可以省略端口配置 - 中級(jí)服務(wù)器:
rustdesk.example.com:21117
,默認(rèn)端口為21117
時(shí)可以省略端口配置 - Key:填寫(xiě)部署服務(wù)默認(rèn)生成的
id_ed25519.pub
文件中的內(nèi)容
示例配置如下:
所有客戶端必須都完成相應(yīng)配置,配置完成后連接測(cè)試:
1、中繼連接測(cè)試
連接成功后鼠標(biāo)指針?lè)旁谧笊辖蔷G色圖標(biāo)處,顯示通過(guò)加密中繼連接,說(shuō)明兩臺(tái)機(jī)器位于不同網(wǎng)絡(luò),無(wú)法通過(guò)P2P直連,要經(jīng)過(guò)阿里云rustdesk-server中繼連接。
2、直連連接測(cè)試
如果位于同一網(wǎng)絡(luò)的兩臺(tái)客戶端互聯(lián),由于中間不存在NAT設(shè)備和防火墻,將顯示兩臺(tái)客戶端為加密直連,無(wú)需經(jīng)過(guò)中繼:
到此這篇關(guān)于docker自建rustdesk-server遠(yuǎn)程桌面的文章就介紹到這了,更多相關(guān)docker自建rustdesk-server內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于docker清理Overlay2占用磁盤(pán)空間的問(wèn)題(親測(cè)有效)
使用Docker過(guò)程中,長(zhǎng)時(shí)間運(yùn)行服務(wù)容器,導(dǎo)致不能進(jìn)行上傳文件等操作,今天通過(guò)本文給大家詳細(xì)介紹下docker清理Overlay2占用磁盤(pán)空間的相關(guān)知識(shí),感興趣的朋友一起看看吧2022-03-03docker?環(huán)境搭建、docker?與容器常用指令大全(推薦)
這篇文章主要介紹了docker?環(huán)境搭建、docker?與容器常用指令大全,主要包括docker容器操作命令匯總,文中介紹需要注意的是如果想要?jiǎng)h除一個(gè)容器,需要先停止該容器且如果鏡像中有運(yùn)行狀態(tài)的容器,也是無(wú)法刪除容器的,需要的朋友可以參考下2022-06-06docker中安裝elasticsarch 等鏡像的過(guò)程
這篇文章主要介紹了docker中安裝elasticsarch 等鏡像,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12阿里云ECS部署Docker服務(wù)的實(shí)現(xiàn)步驟
本文主要介紹了阿里云ECS部署Docker服務(wù)的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06docker安裝minio及實(shí)現(xiàn)文件上傳、刪除、下載方式
這篇文章主要介紹了docker安裝minio及實(shí)現(xiàn)文件上傳、刪除、下載方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03