可以平替TeamViewer的开源远程软件-RustDesk
程序员真的很难,有时候放个假吧,还没睡醒,就被夺命连环call,这时候,也不得不起来处理问题。大部分是需要连接到办公室的电脑去登录堡垒机,我要想连接办公网,就直接登录VPN即可,其实我个人也很喜欢VPN+远程桌面的方式来远程处理问题。可是,VPN是真的慢,很磨炼人的心性。后来,我也就换了其他方式,比如TeamViewer
,可是后来又是一些政治原因,不允许用它了,后来又换了向日葵
,想必用过向日葵人也清楚,没充钱的话,是限流的。后来公司花钱买了另外一个收费的远程软件,用起来来不错,因为充钱了。但是也有一个限制,只能在电脑端远程。
那么如果有人对这方面比较感兴趣并且想自建这类远程软件,这里推荐一个开源项目-RustDesk
。RustDesk 是一款能齐全可以平替 TeamViewer 的开源远程桌面应用,旨在提供安全便捷的自建方案。开箱即用,无需任何配置。您完全掌控数据,不用担心安全问题.
RustDesk
的特性:
随时随地访问任何设备
- 支持 Windows、macOS、Linux、iOS、Android、Web 等多个平台。
- 支持 VP8 / VP9 / AV1 软件编解码器和 H264 / H265 硬件编解码器。
- 完全掌控数据,轻松自建。
- P2P 连接,端到端加密。
- 在 Windows 上可以非管理员不安装运行,根据需要在本地或远程提升权限。
免费的公共服务器
以下是您可以使用的、免费的、会随时更新的公共服务器列表,在国内也许网速会很慢或者无法访问。
Location | Vendor | Specification |
---|---|---|
Germany | Hetzner | 2 vCPU / 4 GB RAM |
Ukraine (Kyiv) | dc.volia | 2 vCPU / 4 GB RAM |
Dev Container
如果你已经安装了 VS Code 和 Docker, 你可以点击上面的徽章开始使用. 点击后, VS Code 将自动安装 Dev Containers 扩展(如果需要),将源代码克隆到容器卷中, 并启动一个 Dev 容器供使用.
Go through DEVCONTAINER.md for more info.
依赖
桌面版本界面使用sciter, 请自行下载。
基本构建步骤
请准备好 Rust 开发环境和 C++ 编译环境
安装 vcpkg, 正确设置
VCPKG_ROOT
环境变量- Windows: vcpkg install libvpx:x64-windows-static libyuv:x64-windows-static opus:x64-windows-static aom:x64-windows-static
- Linux/macOS: vcpkg install libvpx libyuv opus aom
运行
cargo run
构建
在 Linux 上编译
Ubuntu 18 (Debian 10)
1 | sudo apt install -y zip g++ gcc git curl wget nasm yasm libgtk-3-dev clang libxcb-randr0-dev libxdo-dev \ |
openSUSE Tumbleweed
1 | sudo zypper install gcc-c++ git curl wget nasm yasm gcc gtk3-devel clang libxcb-devel libXfixes-devel cmake alsa-lib-devel gstreamer-devel gstreamer-plugins-base-devel xdotool-devel |
Fedora 28 (CentOS 8)
1 | sudo yum -y install gcc-c++ git curl wget nasm yasm gcc gtk3-devel clang libxcb-devel libxdo-devel libXfixes-devel pulseaudio-libs-devel cmake alsa-lib-devel |
Arch (Manjaro)
1 | sudo pacman -Syu --needed unzip git cmake gcc curl wget yasm nasm zip make pkg-config clang gtk3 xdotool libxcb libxfixes alsa-lib pipewire |
安装 vcpkg
1 | git clone https://github.com/microsoft/vcpkg |
修复 libvpx (仅仅针对 Fedora)
1 | cd vcpkg/buildtrees/libvpx/src |
构建
1 | curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh |
把 Wayland 修改成 X11 (Xorg)
RustDesk 暂时不支持 Wayland,不过正在积极开发中。
点我
查看如何将 Xorg 设置成默认的 GNOME session.
Wayland 支持
Wayland 似乎没有提供任何将按键发送到其他窗口的 API. 因此, RustDesk 使用较低级别的 API, 即 /dev/uinput
devices (Linux kernal level).
当 Wayland 是受控方时,您必须以下列方式开始操作:
1 | # Start uinput service |
Notice: Wayland 屏幕录制使用不同的接口. RustDesk 目前只支持 org.freedesktop.portal.ScreenCast.
1 | $ dbus-send --session --print-reply \ |
使用 Docker 编译
克隆版本库并构建 Docker 容器:
1 | git clone https://github.com/rustdesk/rustdesk # 克隆Github存储库 |
请注意:
- 针对国内网络访问问题,可以做以下几点优化:
Dockerfile 中修改系统的源到国内镜像
1
2
3
4在Dockerfile的RUN apt update之前插入两行:
RUN sed -i "s/deb.debian.org/mirrors.163.com/g" /etc/apt/sources.list
RUN sed -i "s/security.debian.org/mirrors.163.com/g" /etc/apt/sources.list修改容器系统中的 cargo 源,在
RUN ./rustup.sh -y
后插入下面代码:1
2
3
4
5
6
7
8RUN echo '[source.crates-io]' > ~/.cargo/config \
&& echo 'registry = "https://github.com/rust-lang/crates.io-index"' >> ~/.cargo/config \
&& echo '# 替换成你偏好的镜像源' >> ~/.cargo/config \
&& echo "replace-with = 'sjtu'" >> ~/.cargo/config \
&& echo '# 上海交通大学' >> ~/.cargo/config \
&& echo '[source.sjtu]' >> ~/.cargo/config \
&& echo 'registry = "https://mirrors.sjtug.sjtu.edu.cn/git/crates.io-index"' >> ~/.cargo/config \
&& echo '' >> ~/.cargo/configDockerfile 中加入代理的 env
1
2
3
4在User root后插入两行
ENV http_proxy=http://host:port
ENV https_proxy=http://host:portdocker build 命令后面加上 proxy 参数
1
docker build -t "rustdesk-builder" . --build-arg http_proxy=http://host:port --build-arg https_proxy=http://host:port
构建 RustDesk 程序
然后, 每次需要构建应用程序时, 运行以下命令:
1 | docker run --rm -it -v $PWD:/home/user/rustdesk -v rustdesk-git-cache:/home/user/.cargo/git -v rustdesk-registry-cache:/home/user/.cargo/registry -e PUID="$(id -u)" -e PGID="$(id -g)" rustdesk-builder |
请注意:
- 因为需要缓存依赖项,首次构建一般很慢(国内网络会经常出现拉取失败,可以多试几次)。
- 如果您需要添加不同的构建参数,可以在指令末尾的
<OPTIONAL-ARGS>
位置进行修改。例如构建一个”Release”版本,在指令后面加上--release
即可。 - 如果出现以下的提示,则是无权限问题,可以尝试把
-e PUID="$(id -u)" -e PGID="$(id -g)"
参数去掉。1
2
3usermod: user user is currently used by process 1
groupmod: Permission denied.
groupmod: cannot lock /etc/group; try again later.原因: 容器的 entrypoint 脚本会检测 UID 和 GID,在度判和给定的环境变量的不一致时,会强行修改 user 的 UID 和 GID 并重新运行。但在重启后读不到环境中的 UID 和 GID,然后再次进入判错重启环节
运行 RustDesk 程序
生成的可执行程序在 target 目录下,可直接通过指令运行调试 (Debug) 版本的 RustDesk:
1 | target/debug/rustdesk |
或者您想运行发行 (Release) 版本:
1 | target/release/rustdesk |
请注意:
- 请保证您运行的目录是在 RustDesk 库的根目录内,否则软件会读不到文件。
install
、run
等 Cargo 的子指令在容器内不可用,宿主机才行。
文件结构
- libs/hbb_common: 视频编解码, 配置, tcp/udp 封装, protobuf, 文件传输相关文件系统操作函数, 以及一些其他实用函数
- libs/scrap: 屏幕截取
- libs/enigo: 平台相关的鼠标键盘输入
- src/ui: GUI
- src/server: 被控端服务音频、剪切板、输入、视频服务、网络连接的实现
- src/client.rs: 控制端
- src/rendezvous_mediator.rs: 与rustdesk-server保持UDP通讯, 等待远程连接(通过打洞直连或者中继)
- src/platform: 平台服务相关代码
- flutter: 移动版本的Flutter代码
- flutter/web/js: Flutter Web版本中的Javascript代码
可以平替TeamViewer的开源远程软件-RustDesk