亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

docker自建rustdesk-server遠(yuǎn)程桌面的解決方案

 更新時(shí)間:2024年07月24日 15:02:10   作者:willops  
RustDesk 是一款可以平替 TeamViewer 的開源軟件,旨在提供安全便捷的自建方案,這篇文章主要介紹了docker自建rustdesk-server遠(yuǎn)程桌面的解決方案,需要的朋友可以參考下

rustdesk簡(jiǎn)介

RustDesk 是一款可以平替 TeamViewer 的開源軟件,旨在提供安全便捷的自建方案。

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)聽來自客戶端的連接請(qǐng)求,并在建立連接后向客戶端發(fā)送屏幕更新和接收輸入事件。
  • RustDesk 中繼服務(wù)器(Relay Server):運(yùn)行在服務(wù)器上,充當(dāng)客戶端之間的橋梁,轉(zhuǎn)發(fā)來自一方的數(shù)據(jù)包到另一方。在某些環(huán)境中(如經(jīng)過 NAT 出網(wǎng))設(shè)備之間無法進(jìn)行 P2P 連接,可以用服務(wù)器來中轉(zhuǎn)
  • ID 服務(wù)器(ID Server):運(yùn)行在服務(wù)器上,用于維護(hù)客戶端及中繼服務(wù)器的連接信息,促進(jìn)設(shè)備之間建立 P2P 連接。

在RustDesk的服務(wù)器端部署中,hbbrhbbs 是兩個(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無法連接,會(huì)使用hbbr進(jìn)行流量中繼。hbbr 是RustDesk的中繼服務(wù)器(Relay Server),用于在兩臺(tái)客戶端之間進(jìn)行連接中繼。它允許無法直接建立P2P連接的客戶端通過中繼服務(wù)器進(jìn)行通信。當(dāng)客戶端A和客戶端B之間無法建立直接連接時(shí),它們會(huì)通過hbbr中繼服務(wù)器進(jìn)行數(shù)據(jù)傳輸。
  • rustdesk-utils - RustDesk 命令行工具

P2P直連說明:

  • RustDesk 首先嘗試建立直接 P2P 連接,如果 P2P 失敗,將使用中繼服務(wù)器。
  • 確認(rèn)連接方式,首先連接到遠(yuǎn)程主機(jī),可以將鼠標(biāo)移動(dòng)到工具欄圖標(biāo)(綠色圖標(biāo)),將顯示它是直接連接還是通過中繼服務(wù)器連接。

使用端口說明:

序號(hào)服務(wù)端口協(xié)議用途是否可選
1hbbs21114TCP用于 Web 控制臺(tái)API,僅在專業(yè)版中可用可選
2hbbs21115TCPNAT類型測(cè)試必選
3hbbs21116TCP/UDPUDP用于ID注冊(cè)和心跳服務(wù),TCP用于TCP打洞和連接服務(wù)必選
4hbbr21117TCP用于Relay服務(wù)必選
5hbbs21118TCP用于支持Web客戶端可選
6hbbr21119TCP用于支持Web客戶端可選

部署rustdesk-server

rustdesk支持自行搭建屬于你的RustDesk服務(wù)器,所有的一切都是免費(fè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ù)器已安裝dockerdocker-compose工具

1、登錄阿里云控制臺(tái),配置防火墻規(guī)則,開通以下端口

端口放通說明:

放通TCP端口2111521116、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ù)說明:

  • 環(huán)境變量RELAY:指定hbbr 服務(wù)的地址和端口,由于使用同一個(gè)docker network,可以通過容器名稱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è)容器hbbrhbbs

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:填寫部署服務(wù)默認(rèn)生成的 id_ed25519.pub 文件中的內(nèi)容

示例配置如下:

所有客戶端必須都完成相應(yīng)配置,配置完成后連接測(cè)試:

1、中繼連接測(cè)試

連接成功后鼠標(biāo)指針放在左上角綠色圖標(biāo)處,顯示通過加密中繼連接,說明兩臺(tái)機(jī)器位于不同網(wǎng)絡(luò),無法通過P2P直連,要經(jīng)過阿里云rustdesk-server中繼連接。

2、直連連接測(cè)試

如果位于同一網(wǎng)絡(luò)的兩臺(tái)客戶端互聯(lián),由于中間不存在NAT設(shè)備和防火墻,將顯示兩臺(tái)客戶端為加密直連,無需經(jīng)過中繼:

到此這篇關(guān)于docker自建rustdesk-server遠(yuǎn)程桌面的文章就介紹到這了,更多相關(guān)docker自建rustdesk-server內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用docker安裝hadoop的實(shí)現(xiàn)過程

    使用docker安裝hadoop的實(shí)現(xiàn)過程

    這篇文章主要介紹了使用docker安裝hadoop的詳細(xì)過程,本文給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • Docker容器互訪的三種方法

    Docker容器互訪的三種方法

    這篇文章主要介紹了Docker容器互訪的三種方法,幫助大家更好的理解和使用docker容器,感興趣的朋友可以了解下。
    2020-09-09
  • Docker容器使用jenkins部署web項(xiàng)目(總結(jié))

    Docker容器使用jenkins部署web項(xiàng)目(總結(jié))

    這篇文章主要介紹了Docker容器使用jenkins部署web項(xiàng)目(總結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • 在Windows系統(tǒng)下安裝docker窗口的配置過程

    在Windows系統(tǒng)下安裝docker窗口的配置過程

    相信大家都知道Docker有很多種安裝的選擇,其中支持最好的是Ubuntu系統(tǒng)。而且docker如果想在windows上運(yùn)行必須借助docker-machine,這篇文章將給大家詳細(xì)的介紹在Windows系統(tǒng)上安裝docker窗口的配置過程,有需要的朋友們可以參考借鑒。
    2016-10-10
  • 安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問題(解決報(bào)錯(cuò))

    安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問題(解決報(bào)錯(cuò))

    這篇文章主要介紹了安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問題,解決方法很簡(jiǎn)單只需我們自己手動(dòng)更新一下,我們根據(jù)提示去微軟官網(wǎng)下載最新版的wsl2安裝后即可正常打開,需要的朋友可以參考下
    2021-06-06
  • docker?環(huán)境搭建、docker?與容器常用指令大全(推薦)

    docker?環(huán)境搭建、docker?與容器常用指令大全(推薦)

    這篇文章主要介紹了docker?環(huán)境搭建、docker?與容器常用指令大全,主要包括docker容器操作命令匯總,文中介紹需要注意的是如果想要?jiǎng)h除一個(gè)容器,需要先停止該容器且如果鏡像中有運(yùn)行狀態(tài)的容器,也是無法刪除容器的,需要的朋友可以參考下
    2022-06-06
  • nerdctl替代docker及docker-compose的安裝使用

    nerdctl替代docker及docker-compose的安裝使用

    這篇文章主要為大家介紹了nerdctl替代docker及docker-compose的安裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • docker?registry?私有倉(cāng)庫(kù)的搭建過程

    docker?registry?私有倉(cāng)庫(kù)的搭建過程

    這篇文章主要介紹了docker?registry?私有倉(cāng)庫(kù),私有倉(cāng)庫(kù)最常用的就是Registry、Harbor兩種,那接下來詳細(xì)介紹如何搭建registry私有倉(cāng)庫(kù),感興趣的朋友跟隨小編一起看看吧
    2022-01-01
  • Node.js服務(wù)Docker容器化應(yīng)用實(shí)踐小結(jié)

    Node.js服務(wù)Docker容器化應(yīng)用實(shí)踐小結(jié)

    這篇文章主要介紹了Node.js服務(wù)Docker容器化應(yīng)用實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Docker命令中的各種參數(shù)使用(run、v、rm、-w、-u、-e)

    Docker命令中的各種參數(shù)使用(run、v、rm、-w、-u、-e)

    本文主要介紹了Docker命令中的各種參數(shù)使用(run、v、rm、-w、-u、-e),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06

最新評(píng)論