当前位置: 首页 > article >正文

在CentOS上部署RustDesk私有中继服务器:从零搭建到安全配置

1. 环境准备搭建RustDesk私有中继服务器的基石在CentOS系统上部署RustDesk私有中继服务器首先需要确保基础环境配置正确。我遇到过不少因为环境问题导致的部署失败案例所以这部分我会详细说明每个环节的注意事项。1.1 系统更新与基础依赖建议在开始前先更新系统到最新状态避免因为旧版软件包导致兼容性问题。执行以下命令sudo yum update -y sudo yum install -y wget unzip firewalld这里特别提醒一下有些云服务商的CentOS镜像可能预装了较旧的软件包。我曾经遇到过因为glibc版本过低导致Node.js运行异常的情况。如果遇到类似问题可以考虑添加EPEL仓库sudo yum install -y epel-release1.2 Node.js环境配置RustDesk的服务器组件需要Node.js环境这里我推荐使用LTS版本。原始文章使用的是v16.18.1但根据我的实测v18.x系列稳定性更好。下面是具体安装步骤cd /usr/local sudo wget https://registry.npmmirror.com/-/binary/node/v18.16.1/node-v18.16.1-linux-x64.tar.gz sudo tar -zxvf node-v18.16.1-linux-x64.tar.gz -C ./配置环境变量时建议不要直接修改/etc/profile而是新建一个专用配置文件sudo tee /etc/profile.d/nodejs.sh EOF export NODE_HOME/usr/local/node-v18.16.1-linux-x64 export PATH\$PATH:\$NODE_HOME/bin EOF这样做的优点是隔离性更好不会影响系统其他用户的配置。加载配置后验证版本source /etc/profile node -v # 应该显示v18.16.1 npm -v # 应该显示9.x.x2. PM2进程管理器的安装与优化PM2是Node.js应用的进程管理器对于保证RustDesk服务稳定运行至关重要。原始文章中的安装方法虽然可行但在生产环境中还需要考虑更多因素。2.1 PM2的安装与基础配置首先安装PM2并设置国内镜像源npm install pm2latest -g pm2 install pm2-logrotate pm2 set pm2-logrotate:max_size 10M pm2 set pm2-logrotate:retain 7这里我添加了日志轮转配置避免日志文件无限增长占用磁盘空间。在实际运维中这个配置帮我解决过多次磁盘爆满的问题。2.2 PM2开机自启设置原始文章使用了pm2 startup命令但在不同系统环境下这个命令可能需要调整。更可靠的做法是pm2 startup systemd -u root --hp /root pm2 save特别注意如果你使用的是非root用户部署需要相应调整用户参数。我曾经遇到过因为用户权限问题导致服务无法自启的情况排查了很久才发现是这个问题。3. RustDesk服务器部署详解这是整个部署过程的核心部分我会分享一些官方文档中没有提到的实用技巧。3.1 服务器组件下载与安装建议下载最新稳定版的RustDesk服务器组件cd /usr/local wget https://github.com/rustdesk/rustdesk-server/releases/download/1.1.10-3/rustdesk-server-linux-amd64.zip unzip rustdesk-server-linux-amd64.zip -d rustdesk-server解压后目录结构应该是这样的/usr/local/rustdesk-server/ ├── hbbs ├── hbbr ├── id_ed25519 └── id_ed25519.pub3.2 服务启动与参数优化启动服务时原始文章使用了简单的-k _参数但在实际使用中我建议添加更多配置cd /usr/local/rustdesk-server pm2 start ./hbbs -- -k _ -r your_server_ip:21117 pm2 start ./hbbr -- -k _这里的-r参数指定了中继服务器地址可以显著提升连接稳定性。如果服务器有多个IP地址务必指定正确的外网IP。3.3 服务健康检查除了原始文章提到的pm2 list还可以使用以下命令检查服务状态netstat -tulnp | grep -E 21115|21116|21117这个命令可以确认服务是否真正在监听指定端口。我曾经遇到过PM2显示服务运行正常但实际上端口未监听的情况。4. 防火墙与安全组配置实战网络配置是部署过程中最容易出问题的环节这里我会详细说明各种场景下的配置方法。4.1 防火墙规则配置CentOS默认使用firewalld配置时需要注意TCP和UDP协议的区别sudo firewall-cmd --permanent --add-port21115-21119/tcp sudo firewall-cmd --permanent --add-port21116/udp sudo firewall-cmd --reload验证端口是否开放的正确方法应该是sudo firewall-cmd --list-ports | grep 2114.2 云服务器安全组配置不同云服务商的配置界面不同但核心规则是一致的TCP: 21115-21119UDP: 21116在阿里云上测试时我发现还需要额外注意安全组的优先级问题。有一次配置不生效就是因为存在更高优先级的拒绝规则。4.3 高级安全配置对于安全性要求较高的环境建议添加IP限制sudo firewall-cmd --permanent --add-rich-rulerule familyipv4 source address192.168.1.0/24 port port21115-21119 protocoltcp accept这样可以只允许特定IP段访问服务大幅提升安全性。5. 密钥管理与客户端配置这是最后一步但同样重要关系到整个系统的可用性。5.1 获取并备份密钥密钥文件位于安装目录下务必做好备份cat /usr/local/rustdesk-server/id_ed25519.pub我建议将密钥文件复制到安全位置并设置适当的权限sudo mkdir -p /etc/rustdesk sudo cp /usr/local/rustdesk-server/id_ed25519* /etc/rustdesk/ sudo chmod 600 /etc/rustdesk/id_ed255195.2 客户端连接配置在RustDesk客户端中需要配置以下参数ID服务器你的服务器公网IP或域名Key刚才获取的公钥内容如果使用域名建议配置DNS解析并启用HTTPS。我在实际使用中发现直接使用IP地址在某些网络环境下会被拦截。5.3 连接测试与故障排查测试连接时建议先在内网环境验证基本功能。常见问题排查方法检查服务进程是否运行ps aux | grep hbb检查端口是否监听ss -tulnp | grep 211检查防火墙规则sudo firewall-cmd --list-all查看服务日志pm2 logs hbbs6. 系统优化与维护建议部署完成后还需要考虑长期运行的稳定性和性能问题。6.1 资源监控与告警可以使用PM2内置的监控功能pm2 monit对于生产环境建议配置更完善的监控系统比如添加以下指标监控CPU和内存使用率网络带宽占用并发连接数6.2 定期维护计划建议设置以下维护任务每月检查更新RustDesk服务器版本每周清理旧日志文件每日备份密钥文件可以添加到crontab中自动化执行0 3 * * * /usr/bin/cp /usr/local/rustdesk-server/id_ed25519* /backup/6.3 性能调优技巧对于高并发场景可以调整以下参数增加文件描述符限制ulimit -n 65535优化内核参数调整net.core.somaxconn等值考虑使用多个hbbr实例负载均衡在实际项目中通过这些优化我成功将单台服务器的并发处理能力提升了3倍以上。

相关文章:

在CentOS上部署RustDesk私有中继服务器:从零搭建到安全配置

1. 环境准备:搭建RustDesk私有中继服务器的基石 在CentOS系统上部署RustDesk私有中继服务器,首先需要确保基础环境配置正确。我遇到过不少因为环境问题导致的部署失败案例,所以这部分我会详细说明每个环节的注意事项。 1.1 系统更新与基础依赖…...

iPhone USB网络共享驱动终极解决方案:从诊断到优化的全方位指南

iPhone USB网络共享驱动终极解决方案:从诊断到优化的全方位指南 【免费下载链接】Apple-Mobile-Drivers-Installer Powershell script to easily install Apple USB and Mobile Device Ethernet (USB Tethering) drivers on Windows! 项目地址: https://gitcode.c…...

01_第一篇:到底什么是嵌入式芯片?与通用CPU_GPU_DSP的核心区别

嵌入式芯片入门:到底什么是嵌入式芯片?与通用CPU/GPU/DSP的核心区别 引言:智能时代的核心基石,嵌入式芯片的无处不在 在万物互联的智能时代,我们的生活早已被无数“隐形大脑”环绕:清晨唤醒你的智能手环、出…...

STM32开发中的C语言核心技巧与实战

1. STM32开发中的C语言核心技巧解析从事嵌入式开发十多年来,我深刻体会到C语言在STM32单片机开发中的核心地位。与通用计算机编程不同,嵌入式C语言需要直接操作硬件寄存器,对代码的精确性和效率要求极高。下面我将分享几个在STM32开发中最实用…...

30个核心概念一次讲明白,小白也能轻松入门大模型(收藏版)

这几年,AI 几乎成了人人都在谈的话题。 有人在聊大模型,有人在说智能体,有人担心算力不够,也有人被“参数”、“微调”、“多模态”、“RAG”这些词绕得头晕。 结果就是:听了很多,越听越乱。 这篇文章是用尽…...

嵌入式系统代码执行时间测量方法与优化

1. 嵌入式程序运行时间测量的必要性在嵌入式系统开发中,精确测量代码执行时间是每个工程师必备的技能。无论是优化算法效率、调试实时系统,还是验证硬件性能,时间测量都扮演着关键角色。以STM32为例,当我们需要确认一个延时函数是…...

intv_ai_mk11生成效果:对‘提高工作效率’需求输出结构清晰、可执行的5条建议

intv_ai_mk11生成效果:对"提高工作效率"需求输出结构清晰、可执行的5条建议 1. 模型介绍与使用场景 intv_ai_mk11是一个基于Llama架构的中等规模文本生成模型,特别适合处理通用问答、文本改写、解释说明等任务。这个模型已经完成本地部署&am…...

Qwen3-14B镜像实操:自定义Tokenizer适配垂直领域专业术语

Qwen3-14B镜像实操:自定义Tokenizer适配垂直领域专业术语 1. 镜像概述与核心优势 Qwen3-14B私有部署镜像是专为RTX 4090D 24GB显存环境优化的完整解决方案,开箱即用无需复杂配置。这个镜像最显著的特点是针对垂直领域专业术语进行了Tokenizer的深度优化…...

5分钟搞懂FGSM:用Python手把手教你生成第一个对抗样本(附代码)

5分钟搞懂FGSM:用Python手把手教你生成第一个对抗样本(附代码) 对抗样本生成听起来像是黑客的专属技能,但今天我要告诉你:用不到10行Python代码就能实现。去年我在一个图像识别项目中第一次遭遇对抗样本攻击——系统将…...

Kandinsky-5.0-I2V-Lite-5s代码实例:Python调用API与前端交互实操解析

Kandinsky-5.0-I2V-Lite-5s代码实例:Python调用API与前端交互实操解析 1. 模型简介与核心能力 Kandinsky-5.0-I2V-Lite-5s是一款轻量级图生视频模型,它能够将静态图片转化为动态视频内容。只需提供一张首帧图片和简单的运动描述,模型就能生…...

3步实现GitHub资源精准提取:开发者必备的效率工具

3步实现GitHub资源精准提取:开发者必备的效率工具 【免费下载链接】DownGit github 资源打包下载工具 项目地址: https://gitcode.com/gh_mirrors/dow/DownGit 你是否曾遇到这样的困境:急需从GitHub仓库中获取一个特定文件夹,却不得不…...

IDEA插件MyBatisX实战:3分钟搞定SpringBoot项目CRUD代码生成

MyBatisX插件全流程实战:SpringBoot项目CRUD代码生成效率革命 在快节奏的企业级开发中,重复编写基础CRUD代码就像在键盘上跳机械舞——动作标准却毫无新意。当项目包含20张以上数据表时,手动创建Entity、Mapper、Service等层级代码会消耗开发…...

Polars 2.0插件生态爆发(2024唯一官方认证清洗套件清单)

第一章:Polars 2.0插件生态爆发(2024唯一官方认证清洗套件清单) 随着 Polars 2.0 的正式发布,其插件系统完成重大重构,首次开放官方插件注册与签名认证机制。截至 2024 年第三季度,Polars 核心团队已通过 …...

【Java外部函数性能优化黄金法则】:20年JVM专家亲授JNI/FFM调优的7大致命误区与3步极速修复方案

第一章:Java外部函数优化的演进脉络与性能本质Java平台对外部函数调用(Foreign Function & Memory API,即JEP 454/464/471/472)的演进,标志着JVM从“纯Java世界”迈向系统级互操作的新纪元。其性能本质并非单纯降低…...

ThingsBoard源码本地部署实战:从环境准备到成功启动的避坑指南

1. 环境准备:打好地基才能盖高楼 第一次在本地部署ThingsBoard源码时,我像大多数开发者一样直接clone代码就往IDE里导,结果被各种依赖问题折腾得够呛。后来才发现,源码部署就像装修房子,水电改造(环境配置&…...

手把手教你用llama.cpp在树莓派上跑大模型(附完整配置流程)

在树莓派上部署llama.cpp的完整实践指南 树莓派作为一款价格亲民且功能强大的微型计算机,近年来在边缘计算和嵌入式AI领域崭露头角。本文将详细介绍如何在树莓派上部署llama.cpp这一轻量级大语言模型推理框架,让开发者能够在资源受限的环境中体验前沿AI技…...

ChatBI怎么在BI试点中用?3个低门槛落地场景亲测有效

ChatBI试点的前置门槛:先搞定最小可行数据集,不用全量建设 ChatBI是观远数据推出的自然语言分析产品,用户可以通过口语化的提问直接获取数据结果、可视化图表甚至分析结论,无需掌握复杂的报表制作或SQL查询技能。在BI试点阶段引入…...

集团型企业BI试点,为什么一定要先做多域资源隔离?

艾瑞咨询《2025年中国BI市场报告》显示,超7成集团型企业的首次BI试点项目因跨业务单元权限冲突、数据口径混乱延期或终止(统计样本覆盖120家年营收超50亿的国内集团企业,统计窗口为2022-2024年试点项目全生命周期)。这个数据和大部…...

避坑指南:Maya LiveLink插件安装常见报错解决方案(附FBX传输优化技巧)

Maya LiveLink插件避坑实战:从安装报错到FBX传输优化的全流程指南 每次打开Maya准备大干一场时,那个熟悉的.mll加载失败弹窗就像个不速之客——特别是当你需要在截止日期前完成虚幻引擎的动画对接时。作为连接Maya与虚幻引擎的神经中枢,LiveL…...

新手福音:用快马生成你的第一个c盘自动清理python脚本

今天想和大家分享一个特别实用的Python小工具——C盘自动清理脚本。作为一个刚接触编程的新手,我发现清理C盘空间是个常见需求,但手动操作既麻烦又容易误删重要文件。于是我用InsCode(快马)平台生成了一个简单实用的脚本,整个过程特别适合编程…...

根据以上内容,可拟定的标题为:“MATLAB仿真复现光纤激光器中耗散孤子共振DSR的演化过程:...

MATLAB仿真复现耗散孤子共振DSR 根据谱方法求解复立方五次方金兹堡朗道方程 获得光纤激光器中耗散孤子的演化过程耗散孤子共振光纤激光器仿真平台:从 Ginzburg-Landau 方程到多维度脉冲演化分析—— 一套可扩展、可配置、可动画的 MATLAB 谱方法框架一、背景与需求高…...

电池包结构仿真与力学分析指南

电池包结构仿真,电池包力学仿真,电池包CAE分析,新能源电池电池CAE分析,结构仿真,力学分析附带相对应的模型文件,指导书,可直接自己跟着做分析另外附赠完整电池包模型一、概述随着新能源汽车的飞速发展&…...

Modbus协议详解:从原理到工业应用实践

1. Modbus协议概述Modbus是一种应用层报文传输协议,由Modicon公司(现为施耐德电气旗下品牌)于1979年开发。作为工业自动化领域最广泛采用的通信协议之一,它定义了控制器设备之间交换信息的通用语言。关键特性:协议标准…...

Windows平台用CMake+VS2019编译NLopt的完整流程(附环境变量配置)

Windows平台用CMakeVS2019编译NLopt的完整流程(附环境变量配置) 在科学计算和优化算法开发领域,NLopt作为一个功能强大的开源库,提供了多种非线性优化算法的实现。对于Windows平台的C开发者而言,掌握从源码构建NLopt的…...

建筑物缺陷分割图像识别

建筑物缺陷分割图像识别 README 项目概述 建筑物缺陷分割数据集分析数据概览关键信息总数量5213张图像,涵盖类别:裂缝、剥落、锈蚀、污渍数据集数量5200数据集格式YoloVOC;应用价值:支持建筑物缺陷自动分割与识别,用于…...

告别模糊:手把手教你用LAMBDA算法搞定GNSS整周模糊度(附Python代码示例)

告别模糊:手把手教你用LAMBDA算法搞定GNSS整周模糊度(附Python代码示例) 当你在开发高精度定位系统时,是否曾被整周模糊度问题困扰?这个看似简单的整数解问题,实际上影响着厘米级定位的成败。作为GNSS领域的…...

C++ 地址空间随机化(ASLR):探讨 C++ 动态链接库在内存布局上的安全特性

尊敬的各位同仁,各位对系统安全和C编程充满热情的开发者们,大家下午好!今天,我们齐聚一堂,共同探讨一个在现代软件安全领域至关重要的主题——地址空间布局随机化(ASLR),特别是它如何…...

重构求职效率:boss_batch_push批量投递工具的颠覆性价值

重构求职效率:boss_batch_push批量投递工具的颠覆性价值 【免费下载链接】boss_batch_push Boss直聘批量投简历,解放双手 项目地址: https://gitcode.com/gh_mirrors/bo/boss_batch_push boss_batch_push是一款专为Boss直聘平台设计的开源自动化投…...

永磁同步电机矢量控制仿真避坑指南:从PI参数整定到SVPWM模块优化

永磁同步电机矢量控制仿真避坑指南:从PI参数整定到SVPWM模块优化 在工业自动化和电力驱动领域,永磁同步电机(PMSM)凭借其高效率、高功率密度和优异的动态性能,已成为众多应用场景的首选。然而,要实现PMSM的…...

社媒爆款流水线:手把手教你用Runway Gen-4.5的A/B测试功能,批量生产TikTok热门视频

社媒爆款流水线:用Runway Gen-4.5打造数据驱动的短视频生产引擎 在短视频内容爆炸式增长的今天,一个残酷的现实是:99%的内容在发布后的24小时内就会沉入算法深渊。那些能突破重围的爆款视频,往往不是偶然灵感的产物,而…...