腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记

腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记

RustDesk是一个基于Rust编写的全平台开源远程桌面软件,其最大的特点为开箱即用,且数据完全自主掌控,甚至可以依托此项目定制化开发自己专属的远程桌面软件。

一、前言

由于我个人经常性出差,对远程桌面软件有强需求,而微软自带的RDP并不能完全满足我的需求,且国内的向日葵/ToDesk/TeamViewer的定价与吃相属实太过美丽,所以目光转向了开源的方案,最终敲定为RustDesk的原因是没有带宽分辨率限制(你也不想720P的远程分辨率吧),且拥有较为完善的第三方WebUI管理后台。

二、服务器准备

由于腾讯云近期推出了锐驰型轻量应用服务器,拥有200M不限流量的大带宽国内网络,这极大的满足了我对大带宽的需求,所以我也是迫不及待的申请内测试了下。定价相对来说还算不错,此次使用的是2C1G的套餐,月付40元。以下为配置清单:

  • 操作系统模板:Ubuntu 24.04 LTS
  • 地域:上海(可根据自身需求选择地域位置)
  • 套餐类型:锐驰型
  • 套餐配置:2C 1G 40G 200Mbps

目前看来锐驰套餐的缺点是CPU抽奖,我运气比较好直接开出了AMD 7K62的CPU,如果开出 Intel的建议删了重开……

三、环境准备

在购买完成且服务器已自动初始化完成运行后,我们可以直接使用腾讯云自带的OrcaTerm一键登录,无需下载第三方SSH客户端。

登录成功后,执行以下命令更新软件包

sudo su
apt update -y
apt upgrade -y

安装Docker&Docker-Composer

sudo apt-get update
sudo apt-get install ca-certificates curl -y
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://mirrors.cloud.tencent.com/docker-ce/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc
echo   "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://mirrors.cloud.tencent.com/docker-ce/linux/ubuntu/ \
  $(. /etc/os-release && echo "$VERSION_CODENAME") stable" |   sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

查看安装是否成功

docker info
图片[3]-腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记-Rain's Blog
出现以上内容则代表安装成功

软连接docker-composer

ln -s /usr/libexec/docker/cli-plugins/docker-compose /usr/local/bin/docker-compose

查看软连接是否正常

docker-composer -v
图片[4]-腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记-Rain's Blog
出现以上内容即代表成功安装

配置腾讯云Docker镜像源

由于Docker在国内的公共镜像源服务因政策被下线,所以只能使用腾讯云内网的Docker镜像源

执行以下命令,打开 /etc/docker/daemon.json 配置文件。

vim /etc/docker/daemon.json

i 切换至编辑模式,添加以下内容,并保存。

{
   "registry-mirrors": [
   "https://mirror.ccs.tencentyun.com"
  ]
}

执行以下命令重启 Docker 即可

systemctl restart docker

四、配置中继服务器

创建目录

mkdir /home/rustdesk

创建HBBR/HBBS 服务

创建docker-composer.yml文件

cd /home/rustdesk
vi docker-compose.yml
networks:
  rustdesk-net:
    external: false

services:
  hbbs:
    container_name: hbbs
    ports:
      - 21115:21115  # NAT-Test
      - 21116:21116 # TCP-Connect
      - 21116:21116/udp # ID&Heart
      - 21118:21118 #web-client
    image: rustdesk/rustdesk-server
    command: hbbs -r xx.example.com -k abc123456 # 填入个人域名或 IP + hbbr 暴露端口
    volumes:
      - /home/rustdesk:/root # 自定义挂载目录
    networks:
      - rustdesk-net
    depends_on:
      - hbbr
    restart: unless-stopped
    deploy:
      resources:
        limits:
          memory: 64M

  hbbr:
    container_name: hbbr
    ports:
      - 21117:21117 # 中继
      - 21119:21119 #web-client
    image: rustdesk/rustdesk-server
    command: hbbr -k abc123456
    volumes:
      - /home/rustdesk:/root # 自定义挂载目录
    networks:
      - rustdesk-net
    restart: unless-stopped
    deploy:
      resources:
        limits:
          memory: 64M

保存后,执行docker-composer up -d启动容器

注意事项

在第一次启动HBBR/HBBS服务时,当前的新版本会自动创建两个key文件id_ed25519id_ed25519.pub,此文件用于链接的加密,以及ID服务器的授权认证。

当前版本中,被控端可不输入key,而控制端则强制要求key的存在。

由于第三方API在Key的加密上存在一定的问题,所以如果要使用第三方客户端,则必须在hbbs启动命令中带有-k的指定密钥参数即可修正此问题。而使用了-k命令,则不会使用服务器自动创建的两个密钥对文件。

此问题仅存在于第三方API上,如果不使用第三方API则无需增加。参考以下Issue

五、软件配置

由于版本更新较快,本次客户端配置仅限Windws x64 1.3.7 版本

Rustdesk支持免安装控制/被控,但由于Windows系统原因,如果想要开机自启等一系列进阶功能,则仍需要安装后使用。安装完成后,点击右上角的设置按钮进行ID服务器配置。

点开ID/中继服务器后,在ID服务器中输入服务器IP+端口或者自定义域名即可,Key为hbbs中-k后指定的字符串。

六、RustDesk WebUI/API配置(可选)

RustDesk API是一个 Go 实现的 Rustdesk API 接口,支持简单的 Web Admin 和 Web 客户端功能。

由于官方的Pro版本对个人来说有些昂贵,而社区版本并不带有WebUI等功能,所以我们这里可以使用第三方的WebUI来进行简单的客户端管理。

推荐使用此项目:lejianwen/rustdesk-api: Custom Rustdesk Api Server, include web admin ,web client, web client v2 preview and oidc login

修改docker-composer.yml文件

使用docker-composer down停止容器,修改docker-composer.yml,如下所示(完整配置)

networks:
  rustdesk-net:
    external: false

services:
  hbbs:
    container_name: hbbs
    ports:
      - 21115:21115  # NAT-Test
      - 21116:21116 # TCP-Connect
      - 21116:21116/udp # ID&Heart
      - 21118:21118 #web-client
    image: rustdesk/rustdesk-server
    command: hbbs -r 122.152.219.191:21116 -k abc123456 # 填入个人域名或 IP + hbbr 暴露端口
    volumes:
      - /home/rustdesk:/root # 自定义挂载目录
    networks:
      - rustdesk-net
    depends_on:
      - hbbr
    restart: unless-stopped
    deploy:
      resources:
        limits:
          memory: 64M

  hbbr:
    container_name: hbbr
    ports:
      - 21117:21117 # 中继
      - 21119:21119 #web-client
    image: rustdesk/rustdesk-server
    command: hbbr -k abc123456
    volumes:
      - /home/rustdesk:/root # 自定义挂载目录
    networks:
      - rustdesk-net
    restart: unless-stopped
    deploy:
      resources:
        limits:
          memory: 64M
  rustdesk-api:
    container_name: rustdesk-api
    environment:
      - TZ=Asia/Shanghai
      - RUSTDESK_API_LANG=zh-CN
      - RUSTDESK_API_RUSTDESK_ID_SERVER=hbbs:21116
      - RUSTDESK_API_RUSTDESK_RELAY_SERVER=hbbr:21117
      - RUSTDESK_API_RUSTDESK_API_SERVER=http://122.152.219.191:21114
      - RUSTDESK_API_RUSTDESK_KEY=abc123456
    ports:
      - 21114:21114
    image: lejianwen/rustdesk-api
    volumes:
      - /home/rustdesk/api:/app/data #将数据库挂载出来方便备份
      #- /home/rustdesk/server:/app/conf/data #挂载key文件到api容器,可以不用使用 RUSTDESK_API_RUSTDESK_KEY
    networks:
      - rustdesk-net
    restart: unless-stopped
    depends_on:
      - hbbs
      - hbbr

保存后,使用docker-compose up -d启动服务

查看运行状态与管理员密码

启动服务后,输入docker-compose logs查看服务输出日志,如下图所示则成功运行,日志中会输出API服务器管理员临时密码。

图片[7]-腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记-Rain's Blog

此时访问http://<服务器IP地址>[:port]/_admin/ 即可进入管理后台

图片[8]-腾讯云锐驰型轻量服务器搭建开源远程桌面软件RustDesk中继服务器小记-Rain's Blog

此时项目部署就已彻底完成,按第五节配置软件即可进行远程链接!

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
评论 抢沙发
头像
说点什么?
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容