8.5 KiB
Serwery •
Kompilacja •
Docker •
Struktura •
Snapshot
[English] | [Українська] | [česky] | [中文] | [Magyar] | [Español] | [فارسی] | [Français] | [Deutsch] | [Indonesian] | [Suomi] | [മലയാളം] | [日本語] | [Nederlands] | [Italiano] | [Русский] | [Português (Brasil)] | [Esperanto] | [한국어] | [العربي] | [Tiếng Việt] | [Ελληνικά]
Potrzebujemy twojej pomocy w tłumaczeniu README na twój ojczysty język
Porozmawiaj z nami na: Discord | Twitter | Reddit
Kolejny program do zdalnego pulpitu, napisany w Rust. Działa od samego początku, nie wymaga konfiguracji. Masz pełną kontrolę nad swoimi danymi, bez obaw o bezpieczeństwo. Możesz skorzystać z naszego darmowego serwera publicznego , skonfigurować własny, lub napisać własny serwer.
RustDesk zaprasza do współpracy każdego. Zobacz docs/CONTRIBUTING.md
pomoc w uruchomieniu programu.
Darmowe Serwery Publiczne
Poniżej znajdują się serwery, z których można korzystać za darmo, może się to zmienić z upływem czasu. Jeśli nie znajdujesz się w pobliżu jednego z nich, Twoja prędkość połączenia może być niska.
Lokalizacja | Dostawca | Specyfikacja |
---|---|---|
Korea Płd. (Seul) | AWS lightsail | 1 vCPU / 0.5GB RAM |
Niemcy | Hetzner | 2 vCPU / 4GB RAM |
Niemcy | Codext | 4 vCPU / 8GB RAM |
Finlandia (Helsinki) | Netlock | 4 vCPU / 8GB RAM |
USA (Ashburn) | Netlock | 4 vCPU / 8GB RAM |
Ukraina (Kijów) | dc.volia | 2 vCPU / 4GB RAM |
Zależności
Wersje desktopowe używają sciter dla GUI, proszę pobrać samodzielnie bibliotekę sciter.
Podstawowe kroki do kompilacji
-
Przygotuj środowisko programistyczne Rust i środowisko programowania C++
-
Zainstaluj vcpkg, i ustaw prawidłowo zmienną
VCPKG_ROOT
- Windows: vcpkg install libvpx:x64-windows-static libyuv:x64-windows-static opus:x64-windows-static
- Linux/MacOS: vcpkg install libvpx libyuv opus
-
uruchom
cargo run
Jak Kompilować na Linuxie
Ubuntu 18 (Debian 10)
sudo apt install -y g++ gcc git curl wget nasm yasm libgtk-3-dev clang libxcb-randr0-dev libxdo-dev libxfixes-dev libxcb-shape0-dev libxcb-xfixes0-dev libasound2-dev libpulse-dev cmake
Fedora 28 (CentOS 8)
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)
sudo pacman -Syu --needed unzip git cmake gcc curl wget yasm nasm zip make pkg-config clang gtk3 xdotool libxcb libxfixes alsa-lib pipewire
Zainstaluj vcpkg
git clone https://github.com/microsoft/vcpkg
cd vcpkg
git checkout 2021.12.01
cd ..
vcpkg/bootstrap-vcpkg.sh
export VCPKG_ROOT=$HOME/vcpkg
vcpkg/vcpkg install libvpx libyuv opus
Popraw libvpx (Dla Fedora)
cd vcpkg/buildtrees/libvpx/src
cd *
./configure
sed -i 's/CFLAGS+=-I/CFLAGS+=-fPIC -I/g' Makefile
sed -i 's/CXXFLAGS+=-I/CXXFLAGS+=-fPIC -I/g' Makefile
make
cp libvpx.a $HOME/vcpkg/installed/x64-linux/lib/
cd
Kompilacja
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source $HOME/.cargo/env
git clone https://github.com/rustdesk/rustdesk
cd rustdesk
mkdir -p target/debug
wget https://raw.githubusercontent.com/c-smile/sciter-sdk/master/bin.lnx/x64/libsciter-gtk.so
mv libsciter-gtk.so target/debug
cargo run
Zmień Wayland na X11 (Xorg)
RustDesk nie obsługuje Waylanda. Sprawdź tutaj, jak skonfigurować Xorg jako domyślną sesję GNOME.
Jak kompilować za pomocą Dockera
Rozpocznij od sklonowania repozytorium i stworzenia kontenera docker:
git clone https://github.com/rustdesk/rustdesk
cd rustdesk
docker build -t "rustdesk-builder" .
Następnie, za każdym razem, gdy potrzebujesz skompilować aplikację, uruchom następujące polecenie:
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
Zauważ, że pierwsza kompilacja może potrwać dłużej zanim zależności zostaną zbuforowane, kolejne będą szybsze. Dodatkowo, jeśli potrzebujesz określić inne argumenty dla polecenia budowania, możesz to zrobić na końcu komendy w miejscu <OPTIONAL-ARGS>
. Na przykład, jeśli chciałbyś zbudować zoptymalizowaną wersję wydania, uruchomiłbyś powyższą komendę a następnie --release
. Powstały plik wykonywalny będzie dostępny w folderze docelowym w twoim systemie, i może być uruchomiony z:
target/debug/rustdesk
Lub jeśli uruchamiasz plik wykonywalny wersji:
target/release/rustdesk
Upewnij się, że uruchamiasz te polecenia z katalogu głównego repozytorium RustDesk, w przeciwnym razie aplikacja może nie być w stanie znaleźć wymaganych zasobów. Należy również pamiętać, że inne podpolecenia ładowania, takie jak install
lub run
nie są obecnie obsługiwane za pomocą tej metody, ponieważ instalowałyby lub uruchamiały program wewnątrz kontenera zamiast na hoście.
Struktura plików
- libs/hbb_common: kodek wideo, konfiguracja, obsługa tcp/udp, protobuf, funkcje systemu plików do transferu plików i kilka innych funkcji użytkowych
- libs/scrap: przechwytywanie ekranu
- libs/enigo: specyficzne dla danej platformy sterowanie klawiaturą/myszą
- src/ui: GUI
- src/server: audio/schowek/wejście(input)/wideo oraz połączenia sieciowe
- src/client.rs: uruchamia połączenie bezpośrednie
- src/rendezvous_mediator.rs: Komunikacja z rustdesk-server, czekanie na bezpośrednie (odpytywanie TCP) lub przekazywane połączenie
- src/platform: kod specyficzny dla danej platformy