doc.rustdesk.com/content/self-host/rustdesk-server-oss/synology/dsm-7/_index.en.md

114 lines
4.7 KiB
Markdown
Raw Normal View History

2024-02-29 11:15:47 +01:00
---
title: Synology DSM 7.2
weight: 20
---
2024-03-09 22:46:43 +01:00
<!-- For translators: When translating elements like "buttons", don't just translate, please refer actual naming in their interface. -->
After DSM 7.2 update, Synology renamed their "Docker" package to "Container Manager". It brings a new GUI, and comes with "docker-compose" within its GUI, which make you create Docker more easily.
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
### Supported models and requirements
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Container Manager brings ARM64 support for some low-end models, such as J series, for detail list of supported model, please check [Synology website](https://www.synology.com/en-us/dsm/packages/ContainerManager).
2024-02-29 11:15:47 +01:00
Most of time you won't need to install extra RAM for install Docker and RustDesk Server.
2024-03-09 22:46:43 +01:00
### 1. Install Container Manager (Docker)
2024-02-29 11:15:47 +01:00
Open "Package Center", search and install "Container Manager".
![](images/dsm7_install_container_manager_though_package_center.png)
2024-03-09 22:46:43 +01:00
### 2. Create folder
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
After you installed "Container Manager", it will create a Shared Folder called `docker`, let's put our server's data here.
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Open your File Station, create a folder named `rustdesk-server`(or whatever you like). Then create a folder named `data` in it just like the picture.
2024-02-29 11:15:47 +01:00
![](images/dsm7_create_required_folders.png)
2024-03-09 22:46:43 +01:00
### 3. Create container
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Open your Container Manager, go to Project and click Create.
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Enter the project name `rustdesk-server` and change Source from "Upload docker-compose.yml" to "Create docker-compose.yml", and copy following contents to the box. After you copied, you should replace `rustdesk.example.com` (Which point to your `hbbr`) to the domain that will point to your NAS.
2024-02-29 11:15:47 +01:00
{{% notice note %}}
2024-03-09 22:46:43 +01:00
You could modify the line with `hbbs` to your NAS's LAN IP temporarily just like the picture. After you verify your server is working, you **should** change back.
2024-02-29 11:15:47 +01:00
{{% /notice %}}
![](images/dsm7_creating_project_init.png)
2024-03-09 22:46:43 +01:00
```yaml
2024-02-29 11:15:47 +01:00
services:
hbbs:
container_name: hbbs
image: rustdesk/rustdesk-server:latest
command: hbbs -r rustdesk.example.com:21117 -k _
volumes:
- ./data:/root
network_mode: host
depends_on:
- hbbr
restart: always
hbbr:
container_name: hbbr
image: rustdesk/rustdesk-server:latest
command: hbbr -k _
volumes:
- ./data:/root
network_mode: host
restart: always
# Because using docker host mode
# Just in case you forgot the ports:
2024-05-05 06:17:40 +02:00
# 21114 TCP for web console, only available in Pro version
# 21115 TCP for NAT type test
2024-02-29 11:15:47 +01:00
# 21116 TCP TCP hole punching
2024-05-05 06:17:40 +02:00
# 21116 UDP heartbeat/ID server
# 21117 TCP relay
# 21118/21119 TCP for web socket if you want to run web client
2024-03-09 22:46:43 +01:00
```
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Please skip `Web portal settings` then done.
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
### 4. Check it is working
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
Open your File Station, you should see `id_ed25519`, `id_ed25519.pub` on your `docker/rustdesk-server/data` folder. You could download it and open it though any text editor or use [Synology Text Editor](https://www.synology.com/en-us/dsm/packages/TextEditor). This is the public key that you need for your RustDesk client.
2024-02-29 11:15:47 +01:00
The public key will looks like this:
![](images/dsm7_viewing_public_key_though_syno_text_editor.png)
Check [here](/docs/en/client) to set up your client. Only `ID server` and `Key` is needed. `Relay server` isn't needed because we've set it in `hbbs`, hbbs will provide this information automatically.
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
### 5. Set your hbbs to point to your domain
2024-02-29 11:15:47 +01:00
If you have set your `hbbs` command to point to your LAN IP, and verified it is working, it is time to change to the domain, as it will not work when attempting to use it outside of your LAN.
2024-02-29 11:15:47 +01:00
<hr>
2024-03-09 22:46:43 +01:00
5.1. Go to Container Manager → Project → Click "rustdesk-server" → Action → Stop
2024-02-29 11:15:47 +01:00
2024-03-09 22:46:43 +01:00
5.2. After stopped, click "YAML Configurations", modify the line start with `command: hbbs` to your domain, then click "Save". Make sure you choose "Build and start the project (rebuild the image)".
2024-02-29 11:15:47 +01:00
![](images/dsm7_recreate_project_after_modified_args.png)
2024-03-09 22:46:43 +01:00
5.3. Your RustDesk Server should ready for connections from the Internet, next, you should setup port forwarding.
2024-02-29 11:15:47 +01:00
{{% notice note %}}
Having problem after you done this step? You should check [this article](/docs/en/self-host/nat-loopback-issues/).
{{% /notice %}}
2024-03-09 22:46:43 +01:00
### 6. Set port forwarding on your router
2024-02-29 11:15:47 +01:00
Go to your router's admin webpage, find anything related to `Port forwarding`, it should appear in `WAN` or `Firewall` settings.
2024-03-09 22:46:43 +01:00
If you still can't find the setting, Google search `{Router brand} + port forwarding` or `{Router model} + port forwarding`. If this device is from your ISP, ask them.
2024-02-29 11:15:47 +01:00
Open these required ports:
2024-05-05 06:17:40 +02:00
* `21114` TCP for web console, only available in Pro version
2024-02-29 11:15:47 +01:00
* `21115` `TCP` For NAT type test
* `21116` `TCP` TCP hole punching
* `21116` `UDP` Heartbeat/ID server
2024-03-09 22:46:43 +01:00
* `21117` `TCP` Relay
2024-05-05 06:17:40 +02:00
* `21118/21119` TCP for web socket if you want to run web client