docker-compose自建RustDesk远程控制服务器

 

 

 

所有操作均在root权限进行,需要先切换用户

sudo -i

 

 

1、新建文件夹【/root/rustdesk_data】

mkdir /root/rustdesk_data

 

2、进入文件夹

cd /root/rustdesk_data

 

3、新建yml文件,并写入保存配置

vi docker-compose.yml

 

yml文件配置内容如下:

 1 version: '3'
 2 
 3 networks:
 4   rustdesk-net:
 5     external: false
 6 
 7 services:
 8   hbbs:
 9     container_name: hbbs
10     ports:
11       - 21115:21115
12       - 21116:21116
13       - 21116:21116/udp
14       - 21118:21118
15     image: rustdesk/rustdesk-server:latest
16     command: hbbs -r rustdesk.example.com:21117
17     volumes:
18       - ./data:/root
19     networks:
20       - rustdesk-net
21     depends_on:
22       - hbbr
23     restart: unless-stopped
24 
25   hbbr:
26     container_name: hbbr
27     ports:
28       - 21117:21117
29       - 21119:21119
30     image: rustdesk/rustdesk-server:latest
31     command: hbbr
32     volumes:
33       - ./data:/root
34     networks:
35       - rustdesk-net
36     restart: unless-stopped

注意:

①其中第16行【rustdesk.example.com】更改为本机centos服务器公网ip地址,或已正确解析并可访问的域名。

②设置云服务器网卡安全组放行相关端口。

③设置centos系统防火墙放行相关端口,或直接把墙关停。

#临时关停防火墙
systemctl stop firewalld.service

#永久关停防火墙
systemctl disable firewalld.service

#查看防火墙状态
systemctl status firewalld.service

 

 

4、给yml文件开权限

chmod 755 docker-compose.yml

 

5、执行下载镜像和启动docker容器

docker-compose up -d

因为yml文件第15行和30行已经填写rustdesk官方的docker hub在线路径,所以执行时候会自动pull运行。

 

6、查看docker运行情况

docker ps

 

 

7、把yml文件里改好的IP或域名,填写到使用端中【ID服务器】

 

 

-----------------------------------------------------

至此,测试远程控制使用应该已经没有问题了,即使centos重启,docker容器也会自启动。

但是,有一个风险点:如果其他人知道了该IP或域名部署了rustdesk服务器,那么他人也可以直接填写ID服务器,使用服务。

这样的话,流量就给别人白嫖了。

所以接下来,需要强制开启填写key才能连接服务器。

 

 

8、修改并保存第3步配置的yml文件【/root/rustdesk_data/docker-compose.yml】

vi /root/rustdesk_data/docker-compose.yml

在16行和31行末尾加上【-k _ 】,以强制开启验证key,即:

#第16行
command: hbbs -r rustdesk.example.com:21117 -k _ 

#第31行
command: hbbr -k _ 

注意16行填写自己的IP或域名

 

9、重新加载容器

1 #进入容器文件夹
2 cd /root/rustdesk_data
3 
4 #执行命令
5 docker-compose pull
6 docker-compose up -d

此时,重新测试用户端控制,没有填写KEY的情况下,会报错无法连上。

 

10、找到KEY,并复制出来

 1 #进入容器文件夹里【data文件夹】
 2 cd /root/rusrdesk_data/data
 3 
 4 #显示文件,可以看到3个db文件,2个id文件
 5 #如:db_v2.sqlite3  db_v2.sqlite3-shm  db_v2.sqlite3-wal id_ed25519  id_ed25519.pub
 6 ls
 7 
 8 
 9 #查看公钥文件【id_ed25519.pub】,如:aMXQFBM+NpRIDqh0KZ7CUAXuQFxHqykAn5Fm0YqSQKM= 
10 cat ./id_ed25519.pub

 

 

11、把KEY粘贴到用户端

 

12、重启centos服务器

reboot

 注意进行重启,否则可能即使填写KEY仍连不上。

 

 

--------------------------------------------------------------

至此,已全部完成rustdesk远程控制服务器自建,可以快乐的玩耍

 

posted on 2022-09-01 22:25  痴心妄想  阅读(8391)  评论(0编辑  收藏  举报

导航