Merge pull request #383 from xlionjuan/ubuntu-server-docker
Add docs for deploy in Ubuntu with docker
@ -0,0 +1,6 @@
|
||||
---
|
||||
title: Ubuntu Server
|
||||
weight: 30
|
||||
---
|
||||
In Ubuntu Server, you have two method to deplay RustDesk Server, Docker or nornal `.deb` installation, Docker is more recommend for unexperienced users, because you could just copy the `docker-compose.yml`, and do some modify and you good to go!
|
||||
{{% children depth="3" showhidden="true" %}}
|
@ -0,0 +1,295 @@
|
||||
---
|
||||
title: Ubuntu Server with Docker
|
||||
weight: 20
|
||||
---
|
||||
Following tutoral will use Ubuntu Server **22.04 minimal** as example. And especially command line procedures, because lowest price spec of VPS can't handle desktop environment.
|
||||
## Preparation
|
||||
|
||||
> First, you need:
|
||||
* [Visual Studio Code](https://code.visualstudio.com)
|
||||
* (Optional) Find and remember your [timezone](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones), or your system's timezone will be UTC+0
|
||||
|
||||
> If you want to install with your local machine, I assume you install your Ubuntu Server as a virtual machine.<br>
|
||||
> You will also need:
|
||||
* Public IP, dynamic IP is fine, but static IP would be better
|
||||
* [Ubuntu Server ISO](https://ubuntu.com/download/server)
|
||||
* Ability to setup port forwarding on your ISP modem or router, if you got these devices from your ISP and don't know how to enter the admin page, please ask your ISP
|
||||
|
||||
## VPS/VM specs choosing/setting
|
||||
If you plan to run only RustDesk Server, lowest spec should be fine, except AWS Lightsail, because its lowest spec is 512MB RAM which may too low and crash, any spec with **1GB RAM** should fine.
|
||||
|
||||
For self-hosted VMs, **1GB RAM and 32GB** of disk will suit your need, and UEFI BIOS is preferred.
|
||||
|
||||
For any other hypervisor that runs on Windows or Linux with GUI, such as VirtualBox or VMware Workstation, please set your virtual network card to **bridged** mode.
|
||||
|
||||
## 1. Installing Ubuntu Server
|
||||
#### [Skip](#2-setup-server) if you decide to rent a VPS.
|
||||
|
||||
{{% notice note %}}
|
||||
This tutorial assume you install your Ubuntu Server as a virtual machine. If you decide to install on a physical machine, doing wrong procedures, may cause **data loss**.
|
||||
{{% /notice %}}
|
||||
|
||||
{{% notice note %}}
|
||||
Use **Tab** to navigate different options, use **Space** to choose different options, use **Enter** when hitting Done.
|
||||
{{% /notice %}}
|
||||
|
||||
1. Choose language
|
||||
![](images/installation/ubt-serv-install-choose-lang.png)
|
||||
|
||||
2. Choose your keyboard layout
|
||||
![](images/installation/ubt-serv-install-set-kb.png)
|
||||
|
||||
3. Network Configuration, please keep it DHCP
|
||||
![](images/installation/ubt-serv-install-net-config.png)
|
||||
|
||||
{{% notice note %}}
|
||||
Now, you could go to your router's DHCP settings, find and add your VM's LAN IP address to DHCP reservation, if you want, you could also assign other IP address.
|
||||
{{% /notice %}}
|
||||
|
||||
|
||||
4. It should choose mirror automatically, if yes, next
|
||||
![](images/installation/ubt-serv-install-mirror-config.png)
|
||||
|
||||
5. Choose minimized to reduce memory and disk usage
|
||||
![](images/installation/ubt-serv-install-installation-type.png)
|
||||
|
||||
6. Use entire disk, next
|
||||
![](images/installation/ubt-serv-install-use-entire-disk.png)
|
||||
|
||||
7. Confirm your disk options
|
||||
![](images/installation/ubt-serv-install-use-entire-disk-confirm.png)
|
||||
|
||||
8. Set your server name, username, and password
|
||||
![](images/installation/ubt-serv-install-user-and-serv-name.png)
|
||||
|
||||
9. Skip [Ubuntu Pro](https://ubuntu.com/pro) register, or you could do it right now
|
||||
![](images/installation/ubt-serv-install-skip-pro.png)
|
||||
10. We need to install OpenSSH
|
||||
![](images/installation/ubt-serv-install-add-ssh-serv.png)
|
||||
|
||||
11. Skip anyting at this page, because it is snap package
|
||||
![](images/installation/ubt-serv-install-skip-snap.png)
|
||||
|
||||
12. After installed it may doing auto update, you could let it update, after it done, reboot.
|
||||
|
||||
## 2. Setup Server
|
||||
|
||||
1. Open VSCode, click button at left corner and select SSH
|
||||
![](images/setup/open_vscode.png)
|
||||
|
||||
2. Enter `username@IP`
|
||||
|
||||
For example: `demouser@192.168.2.98`, and then enter
|
||||
![](images/setup/connect_server_through_vscode.png)
|
||||
|
||||
3. Select your system, `Linux`
|
||||
4. Confirm the fingerprint of the server
|
||||
5. Enter the password of your user
|
||||
|
||||
6. Open your home folder
|
||||
![](images/setup/vscode_open_folder.png)
|
||||
|
||||
7. Click, **Yes, I trust the authors**
|
||||
8. Open terminal
|
||||
![](images/setup/vscode_open_terminal.png)
|
||||
9. Install packages
|
||||
```text
|
||||
sudo apt install docker.io docker-compose python3-pip curl git vim nano zram-config -y
|
||||
```
|
||||
10. Disable disk swap
|
||||
|
||||
Check if swapfile exists
|
||||
```
|
||||
sudo vim /etc/fstab
|
||||
```
|
||||
|
||||
If you find anything similar to:
|
||||
```
|
||||
/swap.img none swap sw 0 0
|
||||
```
|
||||
If not: Type `:qa!` then enter to exit. And go to Step. 12
|
||||
|
||||
If yes: Press `i` to activate edit mode, comment that line with `#` like this:
|
||||
```
|
||||
#/swap.img none swap sw 0 0
|
||||
```
|
||||
Press `Esc` and type `:wq` then enter to save the changes.
|
||||
|
||||
11. Adjust ZRAM size
|
||||
|
||||
ZRAM means **"compress ram"**, it is more efficient and won't occupy disk space.
|
||||
|
||||
```
|
||||
sudo vim /usr/bin/init-zram-swapping
|
||||
```
|
||||
|
||||
Find the line with
|
||||
```
|
||||
mem=$((totalmem / 2 * 1024))
|
||||
```
|
||||
|
||||
And adjust it to:
|
||||
```
|
||||
mem=$((totalmem * 2 * 1024))
|
||||
```
|
||||
Save and exit
|
||||
|
||||
12. Set your timezone
|
||||
|
||||
Find your timezone at [Wikipedia](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones)
|
||||
|
||||
```
|
||||
sudo timedatectl set-timezone "Asia/Taipei"
|
||||
```
|
||||
13. Reboot
|
||||
```
|
||||
sudo reboot
|
||||
```
|
||||
After reboot, reconnect with your VSCode and open terminal.
|
||||
|
||||
14. Delete `swap.img`
|
||||
|
||||
(Skip if you don't have it.)
|
||||
|
||||
We've replaced swapfile with ZRAM, now we can delete `swap.img` now, replace `swap.img` with others if your name is different.
|
||||
```
|
||||
sudo rm /swap.img
|
||||
```
|
||||
|
||||
## 3. Setup RustDesk Server
|
||||
1. Run this command to create required folders once:
|
||||
```
|
||||
cd ~ && mkdir -p docker/rustdesk-server/data
|
||||
```
|
||||
|
||||
2. Create `docker-compose.yml`
|
||||
|
||||
Right click `rustdesk-server` folder, create new file named `docker-compose.yml`
|
||||
|
||||
Paste this to `docker-compose.yml`.
|
||||
|
||||
After you copied, you should replace `rustdesk.example.com` (Which point to your hbbr) to the domain that will point to your server.
|
||||
|
||||
{{% notice note %}}
|
||||
You could modify the line with `hbbs` to your server's LAN IP temporarily (If you're deploying in your LAN) to ensure it is working. After you verify your server is working, you **should** change back.
|
||||
{{% /notice %}}
|
||||
{{% notice note %}}
|
||||
Having problem after you changed LAN IP to domain? You should check [this article](/docs/en/self-host/nat-loopback-issues/).
|
||||
{{% /notice %}}
|
||||
```yml
|
||||
version: '3'
|
||||
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:
|
||||
# 21114 TCP for web console, only available in Pro version
|
||||
# 21115 TCP for NAT type test
|
||||
# 21116 TCP TCP hole punching
|
||||
# 21116 UDP heartbeat/ID server
|
||||
# 21117 TCP relay
|
||||
# 21118/21119 TCP for web socket if you want to run web client
|
||||
```
|
||||
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.
|
||||
|
||||
3. Start the server
|
||||
```
|
||||
cd ~/docker/rustdesk-server
|
||||
sudo docker-compose up -d
|
||||
```
|
||||
4. Check it is working
|
||||
|
||||
In your VSCode, you should see `id_ed25519`, `id_ed25519.pub` on your `docker/rustdesk-server/data` folder. You could click `id_ed25519.pub`, this is the public key that you need for your RustDesk client.
|
||||
|
||||
The public key will looks like this:
|
||||
![](images/setup/vscode_see_public_key.png)
|
||||
|
||||
## 5. Set port forwarding on your router/VPS
|
||||
|
||||
Go to your router's admin webpage, find anything related to `Port forwarding`, it should appear in `WAN` or `Firewall` settings.
|
||||
|
||||
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.
|
||||
|
||||
If you're using VPS, Google search `{VPS vendor name} + firewall port` to find the specific procedure for your VPS.
|
||||
|
||||
Open these required ports:
|
||||
* `21114` TCP for web console, only available in Pro version
|
||||
* `21115` `TCP` For NAT type test
|
||||
* `21116` `TCP` TCP hole punching
|
||||
* `21116` `UDP` Heartbeat/ID server
|
||||
* `21117` `TCP` Relay
|
||||
* `21118/21119` TCP for web socket if you want to run web client
|
||||
|
||||
## 6. Some basics
|
||||
1. How to apply the settings after you modified `docker-compose.yml`?
|
||||
|
||||
Run this again:
|
||||
```
|
||||
sudo docker-compose up -d
|
||||
```
|
||||
|
||||
2. How to stop and delete the container?
|
||||
|
||||
(This won't clear your data)
|
||||
```
|
||||
sudo docker-compose down
|
||||
```
|
||||
|
||||
3. How to backup the server?
|
||||
|
||||
First, run `sudo docker-compose down`, than download it.
|
||||
![](images/setup/vscode_download_folder.png)
|
||||
|
||||
Drag and drop them to VSCode Explorer if you want to upload it.
|
||||
|
||||
4. How to update the container automatically?
|
||||
|
||||
Use [Watchtower](https://containrrr.dev/watchtower/).
|
||||
|
||||
|
||||
Create folder and put the `docker-compose.yml` in it.
|
||||
|
||||
```
|
||||
mkdir ~/docker/watchtower
|
||||
```
|
||||
Change your timezone with yours at `TZ`.
|
||||
|
||||
If you didn't specify any container name, it will update **all** of your containers.
|
||||
|
||||
At the following command, it will run everyday at 3 AM, for more details, check their [documentation](https://containrrr.dev/watchtower/arguments/#scheduling).
|
||||
```yml
|
||||
version: "3"
|
||||
services:
|
||||
watchtower:
|
||||
image: containrrr/watchtower:latest
|
||||
container_name: watchtower
|
||||
network_mode: bridge
|
||||
volumes:
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
environment:
|
||||
TZ: Asia/Taipei
|
||||
command: --cleanup --schedule "0 0 3 * * *" hbbr hbbs
|
||||
restart: always
|
||||
```
|
||||
|
||||
5. How to update Ubuntu system automatically?
|
||||
|
||||
By default, Ubuntu will installing security updates automatically, Google search: `ubuntu unattended-upgrades` or check the file at `/etc/apt/apt.conf.d/50unattended-upgrades` for more details.
|
After Width: | Height: | Size: 108 KiB |
After Width: | Height: | Size: 142 KiB |
After Width: | Height: | Size: 142 KiB |
After Width: | Height: | Size: 147 KiB |
After Width: | Height: | Size: 113 KiB |
After Width: | Height: | Size: 104 KiB |
After Width: | Height: | Size: 118 KiB |
After Width: | Height: | Size: 237 KiB |
After Width: | Height: | Size: 174 KiB |
After Width: | Height: | Size: 131 KiB |
After Width: | Height: | Size: 120 KiB |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 114 KiB |
After Width: | Height: | Size: 34 KiB |
After Width: | Height: | Size: 58 KiB |
After Width: | Height: | Size: 15 KiB |
After Width: | Height: | Size: 76 KiB |