Update ru

This commit is contained in:
2025-11-01 11:18:15 +08:00
committed by GitHub
parent c3a735f243
commit 3eea7f3b04

182
ru
View File

@@ -1,17 +1,44 @@
#!/bin/bash #!/bin/bash
echo "强制修复密钥问题..." set -e # 出现任何错误立即退出
cd rustdesk-unified-keys echo "🚀 RustDesk 服务器一键部署脚本"
echo "========================================"
# 完全重置 # 检查 Docker 是否安装
docker-compose down 2>/dev/null || true if ! command -v docker &> /dev/null; then
rm -rf server/* echo "❌ Docker 未安装,请先安装 Docker"
exit 1
fi
# 重新生成密钥到正确位置 # 检查 Docker Compose 是否可用
mkdir -p server keys if ! command -v docker-compose &> /dev/null && ! docker compose version &> /dev/null; then
echo "❌ Docker Compose 不可用,请先安装 Docker Compose"
exit 1
fi
# 在server目录生成固定密钥容器内的/root目录 # 使用 docker compose新版本或 docker-compose旧版本
DOCKER_COMPOSE_CMD="docker-compose"
if command -v docker &> /dev/null && docker compose version &> /dev/null; then
DOCKER_COMPOSE_CMD="docker compose"
fi
# 创建工作目录
WORK_DIR="rustdesk-unified-keys"
cd "$WORK_DIR" 2>/dev/null || mkdir -p "$WORK_DIR" && cd "$WORK_DIR"
echo "📁 工作目录: $(pwd)"
# 完全重置现有服务
echo "🔄 清理现有服务..."
$DOCKER_COMPOSE_CMD down --remove-orphans 2>/dev/null || true
rm -rf server/* keys/* api-data/* 2>/dev/null || true
# 创建必要的目录结构
mkdir -p server keys api-data
# 生成固定密钥到 server 目录(容器内的 /root 目录)
echo "🔑 生成加密密钥..."
cat > server/id_ed25519 << 'EOF' cat > server/id_ed25519 << 'EOF'
-----BEGIN PRIVATE KEY----- -----BEGIN PRIVATE KEY-----
MC4CAQAwBQYDK2VwBCIEIAE8qD6H5JkG9T5s8s7XaYz1UvP6wQ3rN2tLbKj1mG MC4CAQAwBQYDK2VwBCIEIAE8qD6H5JkG9T5s8s7XaYz1UvP6wQ3rN2tLbKj1mG
@@ -24,7 +51,7 @@ MCowBQYDK2VwAyEA2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=
-----END PUBLIC KEY----- -----END PUBLIC KEY-----
EOF EOF
# 复制到keys目录备份 # 备份密钥到 keys 目录
cp server/id_ed25519 keys/ cp server/id_ed25519 keys/
cp server/id_ed25519.pub keys/ cp server/id_ed25519.pub keys/
@@ -32,35 +59,64 @@ cp server/id_ed25519.pub keys/
chmod 600 server/id_ed25519 chmod 600 server/id_ed25519
chmod 644 server/id_ed25519.pub chmod 644 server/id_ed25519.pub
# 检测IP # 检测公网 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}') echo "🌐 检测服务器公网 IP..."
echo "RELAY_SERVER=$RELAY_SERVER" > .env RELAY_SERVER=""
IP_SERVICES=(
"http://ipinfo.io/ip"
"http://ifconfig.me"
"http://icanhazip.com"
"http://ident.me"
)
# 使用完整的docker-compose配置 for service in "${IP_SERVICES[@]}"; do
if RELAY_SERVER=$(curl -s --connect-timeout 3 "$service"); then
if [[ "$RELAY_SERVER" =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "✅ 从 $service 获取到 IP: $RELAY_SERVER"
break
fi
fi
done
# 如果通过服务获取失败使用本地IP
if [[ -z "$RELAY_SERVER" || ! "$RELAY_SERVER" =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
RELAY_SERVER=$(hostname -I | awk '{print $1}')
echo "⚠️ 使用本地 IP: $RELAY_SERVER"
fi
# 保存环境变量
cat > .env << EOF
# RustDesk 服务器配置
RELAY_SERVER=$RELAY_SERVER
FIXED_KEY=2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=
TIMEZONE=Asia/Shanghai
EOF
# 创建完整的 docker-compose 配置
cat > docker-compose.yml << EOF cat > docker-compose.yml << EOF
services: services:
rustdesk: rustdesk:
container_name: rustdesk-server container_name: rustdesk-server
ports: ports:
- "21114:21114" - "21114:21114" # API 服务器
- "21115:21115" - "21115:21115" # 网页客户端
- "21116:21116" - "21116:21116" # ID 服务器
- "21116:21116/udp" - "21116:21116/udp"
- "21117:21117" - "21117:21117" # 中继服务器
- "21118:21118" - "21118:21118" # 备用端口
- "21119:21119" - "21119:21119" # 备用端口
image: lejianwen/rustdesk-server-s6:latest image: lejianwen/rustdesk-server-s6:latest
environment: environment:
- RELAY=${RELAY_SERVER} - RELAY=\${RELAY_SERVER}
- ENCRYPTED_ONLY=1 - ENCRYPTED_ONLY=1
- MUST_LOGIN=N - MUST_LOGIN=y
- TZ=Asia/Shanghai - TZ=\${TIMEZONE}
- RUSTDESK_API_RUSTDESK_ID_SERVER=${RELAY_SERVER}:21116 - RUSTDESK_API_RUSTDESK_ID_SERVER=\${RELAY_SERVER}:21116
- RUSTDESK_API_RUSTDESK_RELAY_SERVER=${RELAY_SERVER}:21117 - RUSTDESK_API_RUSTDESK_RELAY_SERVER=\${RELAY_SERVER}:21117
- RUSTDESK_API_RUSTDESK_API_SERVER=http://${RELAY_SERVER}:21114 - RUSTDESK_API_RUSTDESK_API_SERVER=http://\${RELAY_SERVER}:21114
- RUSTDESK_API_RUSTDESK_KEY=2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE= - RUSTDESK_API_RUSTDESK_KEY=\${FIXED_KEY}
- RUSTDESK_API_RUSTDESK_KEY_FILE=/root/id_ed25519.pub - RUSTDESK_API_RUSTDESK_KEY_FILE=/root/id_ed25519.pub
- RUSTDESK_API_JWT_KEY=2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE= - RUSTDESK_API_JWT_KEY=\${FIXED_KEY}
- RUSTDESK_API_LANG=zh-CN - RUSTDESK_API_LANG=zh-CN
- RUSTDESK_API_APP_WEB_CLIENT=1 - RUSTDESK_API_APP_WEB_CLIENT=1
- RUSTDESK_API_APP_REGISTER=false - RUSTDESK_API_APP_REGISTER=false
@@ -70,48 +126,84 @@ services:
- ./server:/root - ./server:/root
- ./api-data:/app/data - ./api-data:/app/data
restart: unless-stopped restart: unless-stopped
healthcheck:
test: ["CMD", "netstat", "-ltn"]
interval: 30s
timeout: 10s
retries: 3
networks: networks:
rustdesk-net: default:
driver: bridge name: rustdesk-network
EOF EOF
echo "验证密钥文件:" echo "✅ 配置文件创建完成"
# 验证密钥文件
echo "🔍 验证密钥文件:"
ls -la server/ ls -la server/
echo "公钥内容:" echo "📄 公钥内容:"
cat server/id_ed25519.pub cat server/id_ed25519.pub
echo "启动服务..." # 启动服务
docker-compose up -d echo "🔄 启动 RustDesk 服务..."
$DOCKER_COMPOSE_CMD up -d
sleep 15 # 等待服务启动
echo "服务状态:" echo "⏳ 等待服务启动..."
docker-compose ps for i in {1..30}; do
if $DOCKER_COMPOSE_CMD ps | grep -q "Up"; then
echo "✅ 服务启动成功"
break
fi
sleep 2
echo -n "."
done
echo "查看密钥相关日志:" sleep 5
docker-compose logs --tail=50 | grep -i "key\|Key"
echo "重置管理员密码: 3459635287" # 显示服务状态
docker exec -it rustdesk-server ./apimain reset-admin-pwd 3459635287 echo "📊 服务状态:"
$DOCKER_COMPOSE_CMD ps
echo "=== 最终验证 ===" # 重置管理员密码
SERVER_KEY=$(docker-compose logs | grep "Key:" | tail -1 | awk '{print $NF}') echo "🔐 重置管理员密码..."
if docker exec -it rustdesk-server ./apimain reset-admin-pwd 3459635287 2>/dev/null; then
echo "✅ 管理员密码已重置: 3459635287"
else
echo "⚠️ 密码重置可能失败,请手动检查"
fi
# 验证部署
echo "🔍 验证部署结果..."
SERVER_KEY=$($DOCKER_COMPOSE_CMD logs 2>/dev/null | grep "Key:" | tail -1 | awk '{print $NF}' || echo "")
FIXED_KEY="2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=" FIXED_KEY="2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE="
echo "=== 部署验证结果 ==="
echo "服务器使用密钥: $SERVER_KEY" echo "服务器使用密钥: $SERVER_KEY"
echo "期望固定密钥: $FIXED_KEY" echo "期望固定密钥: $FIXED_KEY"
if [ "$SERVER_KEY" = "$FIXED_KEY" ]; then if [ "$SERVER_KEY" = "$FIXED_KEY" ]; then
echo "✅ 密钥匹配成功!" echo "✅ 密钥匹配成功!"
echo "客户端连接密钥: $FIXED_KEY"
else else
echo "❌ 密钥不匹配!" echo "❌ 密钥不匹配!"
echo "调试信息:" echo "调试信息:"
docker-compose logs --tail=20 | grep -i key $DOCKER_COMPOSE_CMD logs --tail=20 | grep -i key 2>/dev/null || echo "未找到相关日志"
fi fi
echo "=== 客户端配置 ===" # 显示最终配置信息
echo ""
echo "🎉 RustDesk 服务器部署完成!"
echo "========================================"
echo "📋 客户端配置信息:"
echo " ID 服务器: ${RELAY_SERVER}:21116" echo " ID 服务器: ${RELAY_SERVER}:21116"
echo " 中继服务器: ${RELAY_SERVER}:21117" echo " 中继服务器: ${RELAY_SERVER}:21117"
echo " API 服务器: http://${RELAY_SERVER}:21114" echo " API 服务器: http://${RELAY_SERVER}:21114"
echo " 密钥: 2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=" echo " 密钥: 2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE="
echo " 管理员密码: 3459635287"
echo ""
echo "🔧 管理命令:"
echo " 查看日志: cd $WORK_DIR && $DOCKER_COMPOSE_CMD logs -f"
echo " 重启服务: cd $WORK_DIR && $DOCKER_COMPOSE_CMD restart"
echo " 停止服务: cd $WORK_DIR && $DOCKER_COMPOSE_CMD down"
echo "========================================"