11 KiB
title | weight |
---|---|
Installation | 10 |
Installez votre propre serveur à l'aide d'un script d'installation simple d'exécution
Le script est hébergé sur https://github.com/dinger1986/rustdeskinstall, et voici notre support Discord.
Actuellement, le script téléchargera et configurera les serveurs de relais et de signal (HBBR et HBBS), générera des configurations mises à disposition sur une page Web protégée par mot de passe pour un déploiement simple sur les clients.
Exigences
Vous devez avoir installé Linux, le script est testé avec Centos Linux 7/8, Ubuntu 18/20 et Debian. Un serveur avec 1 CPU, 1 Go de RAM et 10 Go d'espace disque est suffisant pour exécuter Rustdesk.
Comment installer le serveur
Veuillez configurer le pare-feu sur votre serveur avant d'exécuter le script.
Assurez-vous d'avoir un accès SSH, et assurez vous que votre part feu autorise cet accès.
Exemple: UFW (basé sur Debian) afin d'autoriser une connexion ssh
ufw allow 22:22/tcp
Si vous avez installé UFW, utilisez les commandes suivantes pour configurer le pare-feu:
ufw allow 21115:21119/tcp
ufw allow 8000/tcp
ufw allow 21116/udp
sudo ufw enable
Exécutez les commandes suivantes:
wget https://raw.githubusercontent.com/dinger1986/rustdeskinstall/master/install.sh
chmod +x install.sh
./install.sh
Installez votre propre serveur avec Docker(-compose)
Exigences
Vous devez avoir installer Docker/Podman afin d'exécuter un serveur Rustdesk en tant que conteneur Docker
Exemples avec Docker
Linux/amd64
sudo docker image pull rustdesk/rustdesk-server
sudo docker run --name hbbs -p 21115:21115 -p 21116:21116 -p 21116:21116/udp -p 21118:21118 -v `pwd`:/root -td --net=host rustdesk/rustdesk-server hbbs -r <relay-server-ip[:port]>
sudo docker run --name hbbr -p 21117:21117 -p 21119:21119 -v `pwd`:/root -td --net=host rustdesk/rustdesk-server hbbr
Linux/arm64v8
sudo docker image pull rustdesk/rustdesk-server:latest-arm64v8
sudo docker run --name hbbs -p 21115:21115 -p 21116:21116 -p 21116:21116/udp -p 21118:21118 -v `pwd`:/root -td --net=host rustdesk/rustdesk-server:latest-arm64v8 hbbs -r <relay-server-ip[:port]>
sudo docker run --name hbbr -p 21117:21117 -p 21119:21119 -v `pwd`:/root -td --net=host rustdesk/rustdesk-server:latest-arm64v8 hbbr
{{% notice note %}}
--net=host
ne fonctionne que pour Linux, ce qui permet à HBBS
/ HBBR
de voir l'adresse IP public entrante plutôt que l'IP privé du conteneur (ex. 172.17.0.1).
Si --net=host
fonctionne , l'option -p
ne sera pas utile. Pour windows, omettez sudo
et --net=host
.
Veuillez supprimer --net = host
si vous rencontrez des problèmes de connexion sur votre configuration.
{{% /notice %}}
Exemples avec Docker-Compose
Pour exécuter les fichiers docker avec docker-compose.yml comme ci dessous, vous devez avoir [docker-compose] (https://docs.docker.com/compose/) d'installé.
Linux/amd64
version: '3'
networks:
rustdesk-net:
external: false
services:
hbbs:
container_name: hbbs
ports:
- 21115:21115
- 21116:21116
- 21116:21116/udp
- 21118:21118
image: rustdesk/rustdesk-server:latest
command: hbbs -r example.com:21117
volumes:
- ./hbbs:/root
networks:
- rustdesk-net
depends_on:
- hbbr
restart: unless-stopped
hbbr:
container_name: hbbr
ports:
- 21117:21117
- 21119:21119
image: rustdesk/rustdesk-server:latest
command: hbbr
volumes:
- ./hbbr:/root
networks:
- rustdesk-net
restart: unless-stopped
Linux/arm64v8
version: '3'
networks:
rustdesk-net:
external: false
services:
hbbs:
container_name: hbbs
ports:
- 21115:21115
- 21116:21116
- 21116:21116/udp
- 21118:21118
image: rustdesk/rustdesk-server:latest-arm64v8
command: hbbs -r example.com:21117
volumes:
- ./hbbs:/root
networks:
- rustdesk-net
depends_on:
- hbbr
restart: unless-stopped
hbbr:
container_name: hbbr
ports:
- 21117:21117
- 21119:21119
image: rustdesk/rustdesk-server:latest-arm64v8
command: hbbr
volumes:
- ./hbbr:/root
networks:
- rustdesk-net
restart: unless-stopped
Configurez votre propre instance de serveur sans utiliser Docker
ÉTAPE 1: Télécharger les logiciels côté serveur
OS Supportés:
- Linux
- Windows
Le tutoriel ci-dessous concerne Linux.
Il y a deux exécutables et un dossier:
hbbs
- Le serveur Rendezvous / RustDesk ID/Rendezvous serverhbbr
- Le serveur Relais / RustDesk relay server
Ils sont testés sous Centos Linux 7/8 et Ubuntu 18/20.
Exigences pour le serveur
Les exigences matérielles sont très faibles; La configuration minimale d'un serveur cloud de base est suffisante et les exigences du CPU et de la mémoire sont minimes. Vous pouvez également utiliser un Raspberry Pi ou quelque chose de similaire. En ce qui concerne le dimensionnement du réseau, si la connexion TCP hole punching directe échoue, du trafic de relais sera consommé. Le trafic d'une connexion de relais se situe entre 30k et 3m/s (écran 1920x1080) en fonction des paramètres de résolution et de la mise à jour de l'écran. Si ce n'est que pour un usage bureautique, le trafic est d'environ 100k/s.
ÉTAPE 2 : Exécutez hbbs/hbbr sur votre serveur
Option 1
Exécutez hbbs/hbbr sur votre serveur (CentOS ou Ubuntu). Nous vous suggérons d'utiliser pm2 pour gérer votre service.
./hbbs -r <relay-server-ip[:port]>
./hbbr
Option 2 - pm2
Exécutez hbbs/hbbr avec pm2
pm2 start hbbs -- -r <relay-server-ip[:port]>
pm2 start hbbr
{{% notice note %}}
pm2 nécessite NodeJS v16+, si vous ne parvenez pas à exécuter pm2 (par exemple, vous ne pouvez pas voir hbbs
/hbbr
dans pm2 list
), veuillez télécharger et installer la version NodeJS LTS à partir de https://nodejs.org. Si vous souhaitez que hbbs
/hbbr
s'exécute automatiquement après le redémarrage, veuillez vous référer à pm2 save
et pm2 startup
. En savoir plus sur pm2. Un autre bon outil pour vos journaux est pm2-logrotate.
Le paramètre -r
de hbbs
n'est pas obligatoire, il est juste plus pratique pour vous de ne pas spécifier de serveur relais côté client contrôlé. Vous n'avez pas besoin de spécifier le port si vous utilisez le port 21117 par défaut. Le serveur relais spécifié par le client a une priorité plus élevée que celle-ci.
{{% /notice %}}
Par défaut, hbbs
écoute sur 21115 (TCP) et 21116 (TCP/UDP), 21118 (TCP), et hbbr
écoute sur 21117 (TCP), 21119 (TCP). Assurez-vous d'ouvrir ces ports dans le pare-feu. Veuillez noter que 21116 doit être activé à la fois pour TCP et UDP. 21115 est utilisé pour le test de type NAT, 21116/UDP est utilisé pour l'enregistrement d'ID et le service heartbeat
, 21116/TCP est utilisé pour le service TCP hole punching
, 21117 est utilisé pour le service de relais, et 21118 et 21119 sont utilisés pour prendre en charge les clients Web. Si vous n'avez pas besoin de la prise en charge du client Web (21118, 21119), les ports correspondants peuvent être désactivés.
- TCP (21115, 21116, 21117, 21118, 21119)
- UDP (21116)
Si vous voulez choisir un port personnalisé, vous pouvez utiliser l'option -h
pour accéder à l'aide.
ÉTAPE 3 : Définir l'adresse IP hbbs/hbbr côté client
Cliquez sur le bouton Menu [ ⋮ ] à droite de ID comme indiqué ci-dessous, et choisissez "ID/Relay Server".
Entrez le nom ou l'adresse IP du serveur hbbs
dans la zone de saisie ID Server. Les deux autres adresses peuvent être laissées vides, RustDesk les déduira automatiquement, le serveur relais fera alors référence à hbbr
(port 21117).
e.g.
hbbs.exemple.fr
ou
hbbs.exemple.fr:21116
Spécifier la configuration par le nom du fichier rustdesk.exe (Windows uniquement)
Remplacez rustdesk.exe
par rustdesk-host=<host-ip-or-name>,key=<public-key-string>
.exe, par ex. rustdesk-host=192.168.1.137,key=xfdsfsd32=32
.exe. Vous pouvez voir le résultat de la configuration dans la fenêtre À propos ci-dessous.
Menu | Page A propos |
---|---|
{{% notice note %}}
S'il y a des caractères dans la clé qui ne peuvent pas être utilisés dans un nom de fichier Windows, veuillez supprimer le fichier id_ed25519
côté serveur et redémarrez hbbs
/hbbr
. Cela entraînera la régénération d'un fichier id_ed25519.pub
. Vous devrez peut-être répétez ce processus jusqu'à ce que vous obteniez des caractères valides.
{{% /notice %}}
Clé
Contrairement à l'ancienne version, la clé pour cette version est obligatoire, mais vous n'avez pas besoin de la définir vous-même. Lorsque hbbs
s'exécute pour la première fois, il génère automatiquement une paire de clés privées et publiques cryptées (respectivement situées dans les fichiers id_ed25519
et id_ed25519.pub
du répertoire d'exécution), dont le but principal est le cryptage des communications.
Si vous n'avez pas rempli la clé Key:
(avec le contenu du fichier clé publique id_ed25519.pub
) à l'étape précédente, cela n'affecte pas la connexion, mais la connexion ne peut pas être chiffrée.
cat ./id_ed25519.pub
Si vous souhaitez interdire aux utilisateurs sans clé d'établir des connexions non chiffrées, veuillez ajouter le paramètre -k _
lors de l'exécution de
hbbs
et hbbr
, par exemple :
./hbbs -r <relay-server-ip[:port]> -k _
./hbbr -k _
Si vous voulez changer de clé, supprimez les fichiers id_ed25519
et id_ed25519.pub
et redémarrez hbbs
/hbbr
,hbbs
générera une nouvelle paire de clés.
{{% notice note %}} Si vous utilisez docker-compose et que les clés n'existent pas, le démarrage des conteneurs créera des clés différentes dans les dossiers hbbs et hbbr.
Vous pouvez créer des clés manuellement dans hbbs et les copier dans hbbr avant de démarrer les conteneurs. Ou vous pouvez arrêter le conteneur hbbr et copier les clés de hbbs dans le dossier hbbr, puis redémarrer le conteneur. {{% /notice %}}