Update ru

This commit is contained in:
2025-11-01 21:44:31 +08:00
committed by GitHub
parent f8ba1082d9
commit 711a583b5b

325
ru
View File

@@ -1,210 +1,177 @@
#!/bin/bash #!/bin/bash
# RustDesk Server 一键部署脚本 - 完全修复密钥问题 # RustDesk Server 一键部署脚本
set -e set -e
echo "========================================" echo "========================================"
echo " RustDesk Server 一键部署脚本" echo " RustDesk Server 一键部署脚本"
echo "========================================" echo "========================================"
# 获取服务器公网 IP # 创建项目目录
SERVER_IP=$(curl -s http://checkip.amazonaws.com || curl -s http://ipinfo.io/ip || echo "127.0.0.1") mkdir -p rustdesk-server
echo "检测到服务器 IP: $SERVER_IP" cd rustdesk-server
# 设置固定密 # 生成固定密钥对
FIXED_PASSWORD="3459635287" echo "1. 生成密钥对..."
echo "设置管理密码: $FIXED_PASSWORD" mkdir -p keys
openssl genpkey -algorithm ed25519 -out keys/id_ed25519 2>/dev/null || {
# 创建必要的目录 echo "生成密钥对失败,创建示例密钥..."
echo "创建数据目录..." # 如果 openssl 不可用,创建示例密钥文件
mkdir -p /data/rustdesk/server cat > keys/id_ed25519 << 'EOF'
mkdir -p /data/rustdesk/api -----BEGIN PRIVATE KEY-----
MC4CAQAwBQYDK2VwBCIEIAE8qD6H5JkG9T5s8s7XaYz1UvP6wQ3rN2tLbKj1mG
# 停止并删除可能存在的旧容器 -----END PRIVATE KEY-----
echo "清理旧容器..." EOF
docker rm -f rustdesk 2>/dev/null || true cat > keys/id_ed25519.pub << 'EOF'
# 彻底清理旧的密钥文件
echo "清理旧密钥文件..."
rm -rf /data/rustdesk/server/id_ed25519*
# 生成有效的 JWT 密钥
JWT_KEY=$(openssl rand -base64 32 | tr -d '\n' | tr -d '/+' | cut -c1-32)
echo "生成 JWT 密钥: $JWT_KEY"
# 生成有效的 Ed25519 密钥对
echo "生成有效的密钥对..."
if command -v rustdesk &> /dev/null; then
# 如果系统安装了 rustdesk
rustdesk --gen-keypair --out /data/rustdesk/server/
else
# 使用 openssl 生成 Ed25519 密钥
openssl genpkey -algorithm Ed25519 -out /data/rustdesk/server/id_ed25519 2>/dev/null || \
docker run --rm -v /data/rustdesk/server:/data alpine/openssl genpkey -algorithm Ed25519 -out /data/id_ed25519
# 提取公钥
openssl pkey -in /data/rustdesk/server/id_ed25519 -pubout -out /data/rustdesk/server/id_ed25519.pub 2>/dev/null || \
docker run --rm -v /data/rustdesk/server:/data alpine/openssl pkey -in /data/id_ed25519 -pubout -out /data/id_ed25519.pub
fi
# 检查密钥是否生成成功
if [ -f "/data/rustdesk/server/id_ed25519.pub" ]; then
PUBLIC_KEY=$(cat /data/rustdesk/server/id_ed25519.pub | base64 -w 0)
echo "✓ 公钥生成成功"
echo "公钥 (base64): $PUBLIC_KEY"
else
# 如果上面的方法都失败,使用一个已知有效的 base64 编码密钥
echo "使用备选密钥生成方法..."
cat > /data/rustdesk/server/id_ed25519.pub << EOF
-----BEGIN PUBLIC KEY----- -----BEGIN PUBLIC KEY-----
MCowBQYDK2VwAyEAr0cDMF1eJa9zNqnUPB8ylbEJJWZqj6OdJnOrNhmWSLU= MCowBQYDK2VwAyEA2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=
-----END PUBLIC KEY----- -----END PUBLIC KEY-----
EOF EOF
PUBLIC_KEY="r0cDMF1eJa9zNqnUPB8ylbEJJWZqj6OdJnOrNhmWSLU=" }
echo "使用预设公钥: $PUBLIC_KEY"
# 编码密钥为base64
KEY_PRIV=$(cat keys/id_ed25519 | base64 -w 0)
KEY_PUB=$(cat keys/id_ed25519.pub | base64 -w 0)
# 自动检测服务器IP
echo "2. 检测服务器IP地址..."
RELAY_SERVER=$(curl -s --connect-timeout 5 http://ipinfo.io/ip || curl -s --connect-timeout 5 http://ifconfig.me || hostname -I | awk '{print $1}')
if [ -z "$RELAY_SERVER" ]; then
echo "错误: 无法自动获取服务器IP请手动输入:"
read RELAY_SERVER
else
echo "检测到服务器IP: $RELAY_SERVER"
fi fi
# 生成新版 Docker Compose 文件(去掉 version # 创建docker-compose.yml
echo "3. 创建Docker Compose配置..."
cat > docker-compose.yml << EOF cat > docker-compose.yml << EOF
networks: version: '3'
rustdesk-net:
external: false
services: services:
rustdesk: hbbs:
container_name: rustdesk container_name: hbbs
ports: ports:
- "21114:21114"
- "21115:21115" - "21115:21115"
- "21116:21116" - "21116:21116"
- "21116:21116/udp" - "21116:21116/udp"
- "21117:21117"
- "21118:21118" - "21118:21118"
- "21119:21119" image: lejianwen/rustdesk-server:latest
image: lejianwen/rustdesk-server-s6:latest command: hbbs -r $RELAY_SERVER:21117
environment:
# 基础配置
- RELAY=${SERVER_IP}:21117
- ENCRYPTED_ONLY=0 # 先禁用加密,确保服务能启动
- MUST_LOGIN=y
- TZ=Asia/Shanghai
- KEY=${PUBLIC_KEY}
# RustDesk API 配置
- RUSTDESK_API_RUSTDESK_ID_SERVER=${SERVER_IP}:21116
- RUSTDESK_API_RUSTDESK_RELAY_SERVER=${SERVER_IP}:21117
- RUSTDESK_API_RUSTDESK_API_SERVER=http://${SERVER_IP}:21114
- RUSTDESK_API_RUSTDESK_KEY=${PUBLIC_KEY}
- RUSTDESK_API_JWT_KEY=${JWT_KEY}
# 其他配置
- RUSTDESK_API_APP_REGISTER=false
- RUSTDESK_API_APP_DISABLE_PWD_LOGIN=false
- RUSTDESK_API_APP_CAPTCHA_THRESHOLD=3
- RUSTDESK_API_APP_BAN_THRESHOLD=5
- RUSTDESK_API_GORM_TYPE=sqlite
- RUSTDESK_API_LANG=zh-CN
- RUSTDESK_API_APP_WEB_CLIENT=1
- RUSTDESK_API_APP_SHOW_SWAGGER=0
volumes: volumes:
- /data/rustdesk/server:/data - ./data:/root
- /data/rustdesk/api:/app/data environment:
networks: - RELAY=$RELAY_SERVER
- rustdesk-net - KEY_PUB=$KEY_PUB
- KEY_PRIV=$KEY_PRIV
restart: unless-stopped
hbbr:
container_name: hbbr
ports:
- "21117:21117"
- "21119:21119"
image: lejianwen/rustdesk-server:latest
volumes:
- ./data:/root
environment:
- KEY_PUB=$KEY_PUB
- KEY_PRIV=$KEY_PRIV
restart: unless-stopped restart: unless-stopped
EOF EOF
echo "Docker Compose 文件已生成" # 创建环境变量文件
cat > .env << EOF
RELAY_SERVER=$RELAY_SERVER
KEY_PUB=$KEY_PUB
KEY_PRIV=$KEY_PRIV
EOF
# 创建启动脚本
cat > start.sh << 'EOF'
#!/bin/bash
cd "$(dirname "$0")"
docker-compose up -d
echo "RustDesk服务器启动完成"
EOF
# 创建停止脚本
cat > stop.sh << 'EOF'
#!/bin/bash
cd "$(dirname "$0")"
docker-compose down
echo "RustDesk服务器已停止"
EOF
# 创建客户端配置说明
cat > client-config.md << EOF
# RustDesk 客户端配置
## 服务器信息
- ID服务器: $RELAY_SERVER:21116
- 中继服务器: $RELAY_SERVER:21117
- Key:
\`\`\`
$(cat keys/id_ed25519.pub)
\`\`\`
## 配置步骤
1. 打开RustDesk客户端
2. 点击右下角设置按钮
3. 选择"网络"标签
4. 填写以下信息:
- ID服务器: $RELAY_SERVER:21116
- 中继服务器: $RELAY_SERVER:21117
- Key: 粘贴上面的公钥内容
5. 点击"应用"保存设置
## 端口说明
- 21115: HTTP API端口
- 21116: ID服务器端口 (TCP)
- 21117: 中继服务器端口 (TCP)
- 21118: 网页客户端端口
- 21119: 中继服务器端口 (备用)
EOF
# 设置脚本权限
chmod +x start.sh stop.sh
# 检查Docker环境
echo "4. 检查Docker环境..."
if ! command -v docker &> /dev/null; then
echo "错误: Docker未安装请先安装Docker"
exit 1
fi
if ! command -v docker-compose &> /dev/null; then
echo "错误: Docker Compose未安装请先安装Docker Compose"
exit 1
fi
# 拉取镜像
echo "5. 拉取Docker镜像..."
docker pull lejianwen/rustdesk-server:latest
# 启动服务 # 启动服务
echo "启动 RustDesk 服务..." echo "6. 启动RustDesk服务..."
if command -v docker &> /dev/null && docker compose version &> /dev/null; then docker-compose up -d
docker compose up -d
else
docker-compose up -d
fi
echo "等待服务启动..." # 显示部署结果
sleep 40
# 检查服务状态
echo "检查服务状态..."
if [ "$(docker inspect -f '{{.State.Running}}' rustdesk 2>/dev/null)" = "true" ]; then
echo "✓ RustDesk 服务运行正常"
# 等待一段时间后尝试启用加密
echo "等待服务完全启动..."
sleep 30
# 重新启用加密
echo "重新启用加密..."
docker stop rustdesk
sed -i 's/ENCRYPTED_ONLY=0/ENCRYPTED_ONLY=1/' docker-compose.yml
if command -v docker &> /dev/null && docker compose version &> /dev/null; then
docker compose up -d
else
docker-compose up -d
fi
sleep 20
else
echo "✗ 服务启动异常,查看日志..."
docker logs rustdesk --tail 50
echo ""
echo "尝试使用简化配置..."
# 使用简化配置重试
deploy_simple
fi
# 最终状态检查
if [ "$(docker inspect -f '{{.State.Running}}' rustdesk 2>/dev/null)" = "true" ]; then
echo "✓ RustDesk 部署成功!"
else
echo "⚠ 服务可能仍在启动中,请稍后检查..."
fi
# 显示部署信息
echo ""
echo "========================================" echo "========================================"
echo " RustDesk 部署完成" echo " 部署完成"
echo "========================================"
echo "服务器 IP: $SERVER_IP"
echo "公钥密钥: $PUBLIC_KEY"
echo "JWT 密钥: $JWT_KEY"
echo "管理密码: $FIXED_PASSWORD"
echo ""
echo "客户端连接信息:"
echo " ID 服务器: $SERVER_IP:21116"
echo " 中继服务器: $SERVER_IP:21117"
echo " 密钥: $PUBLIC_KEY"
echo ""
echo "Web 管理界面: http://${SERVER_IP}:21114"
echo "用户名: admin"
echo "密码: $FIXED_PASSWORD"
echo "========================================" echo "========================================"
echo "服务状态:"
docker-compose ps
# 简化部署函数(备用) echo -e "\n客户端配置信息已保存到: client-config.md"
deploy_simple() { echo -e "\n管理命令:"
echo "使用简化配置部署..." echo "启动服务: ./start.sh"
cat > docker-compose-simple.yml << EOF echo "停止服务: ./stop.sh"
services: echo "查看日志: docker-compose logs -f"
rustdesk: echo "查看状态: docker-compose ps"
container_name: rustdesk
ports: echo -e "\n重要信息:"
- "21116:21116" echo "ID服务器: $RELAY_SERVER:21116"
- "21116:21116/udp" echo "中继服务器: $RELAY_SERVER:21117"
- "21117:21117" echo "密钥文件位置: ./keys/"
image: lejianwen/rustdesk-server-s6:latest
environment:
- SERVER_IP=${SERVER_IP}
- RELAY_IP=${SERVER_IP}
- KEY=${PUBLIC_KEY}
- TZ=Asia/Shanghai
volumes:
- /data/rustdesk/server:/data
restart: unless-stopped
EOF
if command -v docker &> /dev/null && docker compose version &> /dev/null; then
docker compose -f docker-compose-simple.yml up -d
else
docker-compose -f docker-compose-simple.yml up -d
fi
}