欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

docker自建rustdesk-server遠程桌面的解決方案

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

rustdesk簡介

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

RustDesk 是一款功能齊全的遠程桌面應用,具有以下特性:

  • 支持 Windows、macOS、Linux、iOS、Android、Web 等多個平臺。
  • 支持 VP8 / VP9 / AV1 軟件編解碼器和 H264 / H265 硬件編解碼器。
  • 完全掌控數(shù)據(jù),輕松自建。
  • P2P 連接,端到端加密。
  • 在 Windows 上可以非管理員不安裝運行,根據(jù)需要在本地或遠程提升權限。
  • 我們崇尚簡單,盡一切可能讓它簡單。

官方網(wǎng)站:https://rustdesk.com/zh/

項目地址:https://github.com/rustdesk/rustdesk

RustDesk 架構

RustDesk 采用了經(jīng)典的客戶端-服務器模型,其中涉及三個主要組件:RustDesk 客戶端、RustDesk 服務器和 ID Server。

  • RustDesk 客戶端:運行在你的設備上(Windows,macOS,Linux,Android, iPhone)用于連接兩個設備的軟件,它負責監(jiān)聽來自客戶端的連接請求,并在建立連接后向客戶端發(fā)送屏幕更新和接收輸入事件。
  • RustDesk 中繼服務器(Relay Server):運行在服務器上,充當客戶端之間的橋梁,轉發(fā)來自一方的數(shù)據(jù)包到另一方。在某些環(huán)境中(如經(jīng)過 NAT 出網(wǎng))設備之間無法進行 P2P 連接,可以用服務器來中轉
  • ID 服務器(ID Server):運行在服務器上,用于維護客戶端及中繼服務器的連接信息,促進設備之間建立 P2P 連接。

在RustDesk的服務器端部署中,hbbrhbbs 是兩個重要的組件,分別用于不同的功能:

  • hbbs - 代表 RustDesk ID / Rendezvous Server,RustDesk ID注冊服務器,用于分配和注冊ID;hbbs 是RustDesk的中介服務器(Broker Server),用于管理和協(xié)調(diào)客戶端連接。它幫助客戶端找到并建立P2P連接。hbbs 負責維護客戶端的在線狀態(tài),并處理連接請求。當客戶端A希望連接客戶端B時,它會向hbbs發(fā)送請求,hbbs會幫助它們建立連接。
  • hbbr -代表 RustDesk Relay Server,RustDesk 中繼服務器,如果P2P無法連接,會使用hbbr進行流量中繼。hbbr 是RustDesk的中繼服務器(Relay Server),用于在兩臺客戶端之間進行連接中繼。它允許無法直接建立P2P連接的客戶端通過中繼服務器進行通信。當客戶端A和客戶端B之間無法建立直接連接時,它們會通過hbbr中繼服務器進行數(shù)據(jù)傳輸。
  • rustdesk-utils - RustDesk 命令行工具

P2P直連說明:

  • RustDesk 首先嘗試建立直接 P2P 連接,如果 P2P 失敗,將使用中繼服務器。
  • 確認連接方式,首先連接到遠程主機,可以將鼠標移動到工具欄圖標(綠色圖標),將顯示它是直接連接還是通過中繼服務器連接。

使用端口說明:

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

部署rustdesk-server

rustdesk支持自行搭建屬于你的RustDesk服務器,所有的一切都是免費且開源的。所謂自建服務器,也就是自建 ID Server 和 Relay Server。

整體部署架構如下:

官方文檔:https://github.com/rustdesk/rustdesk-server/blob/master/README-ZH.md

前置部署要求

前置要求:

  • 準備一臺公網(wǎng)linux服務器,并綁定公網(wǎng)IP地址,以阿里云輕量應用服務器為例,操作系統(tǒng)為Ubuntu 22.04。
  • 服務器已安裝dockerdocker-compose工具

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

端口放通說明:

放通TCP端口2111521116、2111721118、21119放通UDP端口21116

2、登錄阿里云控制臺,配置域名解析(可選):

配置一條A記錄,將rustdesk-server公網(wǎng)IP地址解析到rustdesk.example.com域名(需自行準備域名并進行備案)。

部署rustdesk-server

配置主機名

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 服務的地址和端口,由于使用同一個docker network,可以通過容器名稱hbbr連接
  • 環(huán)境變量ENCRYPTED_ONLY:啟用加密連接并使用key驗證,防止其他獲取地址的客戶端非法連接

執(zhí)行以下命令運行容器

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    

查看運行的兩個容器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# 

查看主機當前目錄結構

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:~# 

連接驗證

服務端搭建好后,在要連接的兩個客戶端設備上都下載 RustDesk 客戶端。

下載地址是:https://github.com/rustdesk/rustdesk/releases

在rustdesk-server上獲取默認生成的公鑰key

root@rustdesk-server:~# cat /data/rustdesk/root/id_ed25519.pub 
G2yFoE+0pWWqXAHM174TXbsoUqJB1brHKOxZhEKv7hA=

首先找到 RustDesk 客戶端的 設置 -> ID/中繼服務器 ,然后輸入如下三個信息

  • ID 服務器:rustdesk.example.com:21116,默認端口為21116時可以省略端口配置
  • 中級服務器:rustdesk.example.com:21117,默認端口為21117時可以省略端口配置
  • Key:填寫部署服務默認生成的 id_ed25519.pub 文件中的內(nèi)容

示例配置如下:

所有客戶端必須都完成相應配置,配置完成后連接測試:

1、中繼連接測試

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

2、直連連接測試

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

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

相關文章

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

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

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

    Docker容器互訪的三種方法

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

    Docker容器使用jenkins部署web項目(總結)

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

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

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

    安裝Docker Desktop報錯WSL 2 installation is incomplete的問題(解決報錯)

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

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

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

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

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

    docker?registry?私有倉庫的搭建過程

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

    Node.js服務Docker容器化應用實踐小結

    這篇文章主要介紹了Node.js服務Docker容器化應用實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    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),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06

最新評論