210 lines
5.9 KiB
Bash
210 lines
5.9 KiB
Bash
#!/bin/bash
|
||
|
||
set -e # 出现任何错误立即退出
|
||
|
||
echo "🚀 RustDesk 服务器一键部署脚本"
|
||
echo "========================================"
|
||
|
||
# 检查 Docker 是否安装
|
||
if ! command -v docker &> /dev/null; then
|
||
echo "❌ Docker 未安装,请先安装 Docker"
|
||
exit 1
|
||
fi
|
||
|
||
# 检查 Docker Compose 是否可用
|
||
if ! command -v docker-compose &> /dev/null && ! docker compose version &> /dev/null; then
|
||
echo "❌ Docker Compose 不可用,请先安装 Docker Compose"
|
||
exit 1
|
||
fi
|
||
|
||
# 使用 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'
|
||
-----BEGIN PRIVATE KEY-----
|
||
MC4CAQAwBQYDK2VwBCIEIAE8qD6H5JkG9T5s8s7XaYz1UvP6wQ3rN2tLbKj1mG
|
||
-----END PRIVATE KEY-----
|
||
EOF
|
||
|
||
cat > server/id_ed25519.pub << 'EOF'
|
||
-----BEGIN PUBLIC KEY-----
|
||
MCowBQYDK2VwAyEA2Q1Dp4q8q5V7s9kLx2mBwT3zN8rR6vY1zUj5tKfE=
|
||
-----END PUBLIC KEY-----
|
||
EOF
|
||
|
||
# 备份密钥到 keys 目录
|
||
cp server/id_ed25519 keys/
|
||
cp server/id_ed25519.pub keys/
|
||
|
||
# 设置正确的权限
|
||
chmod 600 server/id_ed25519
|
||
chmod 644 server/id_ed25519.pub
|
||
|
||
# 检测公网 IP
|
||
echo "🌐 检测服务器公网 IP..."
|
||
RELAY_SERVER=""
|
||
IP_SERVICES=(
|
||
"http://ipinfo.io/ip"
|
||
"http://ifconfig.me"
|
||
"http://icanhazip.com"
|
||
"http://ident.me"
|
||
)
|
||
|
||
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
|
||
services:
|
||
rustdesk:
|
||
container_name: rustdesk-server
|
||
ports:
|
||
- "21114:21114" # API 服务器
|
||
- "21115:21115" # 网页客户端
|
||
- "21116:21116" # ID 服务器
|
||
- "21116:21116/udp"
|
||
- "21117:21117" # 中继服务器
|
||
- "21118:21118" # 备用端口
|
||
- "21119:21119" # 备用端口
|
||
image: lejianwen/rustdesk-server-s6:latest
|
||
environment:
|
||
- RELAY=\${RELAY_SERVER}
|
||
- ENCRYPTED_ONLY=1
|
||
- MUST_LOGIN=y
|
||
- TZ=\${TIMEZONE}
|
||
- RUSTDESK_API_RUSTDESK_ID_SERVER=\${RELAY_SERVER}:21116
|
||
- RUSTDESK_API_RUSTDESK_RELAY_SERVER=\${RELAY_SERVER}:21117
|
||
- RUSTDESK_API_RUSTDESK_API_SERVER=http://\${RELAY_SERVER}:21114
|
||
- RUSTDESK_API_RUSTDESK_KEY=\${FIXED_KEY}
|
||
- RUSTDESK_API_RUSTDESK_KEY_FILE=/root/id_ed25519.pub
|
||
- RUSTDESK_API_JWT_KEY=\${FIXED_KEY}
|
||
- RUSTDESK_API_LANG=zh-CN
|
||
- RUSTDESK_API_APP_WEB_CLIENT=1
|
||
- RUSTDESK_API_APP_REGISTER=false
|
||
- RUSTDESK_API_APP_CAPTCHA_THRESHOLD=-1
|
||
- RUSTDESK_API_APP_BAN_THRESHOLD=0
|
||
volumes:
|
||
- ./server:/root
|
||
- ./api-data:/app/data
|
||
restart: unless-stopped
|
||
healthcheck:
|
||
test: ["CMD", "netstat", "-ltn"]
|
||
interval: 30s
|
||
timeout: 10s
|
||
retries: 3
|
||
|
||
networks:
|
||
default:
|
||
name: rustdesk-network
|
||
EOF
|
||
|
||
echo "✅ 配置文件创建完成"
|
||
|
||
# 验证密钥文件
|
||
echo "🔍 验证密钥文件:"
|
||
ls -la server/
|
||
echo "📄 公钥内容:"
|
||
cat server/id_ed25519.pub
|
||
|
||
# 启动服务
|
||
echo "🔄 启动 RustDesk 服务..."
|
||
$DOCKER_COMPOSE_CMD up -d
|
||
|
||
# 等待服务启动
|
||
echo "⏳ 等待服务启动..."
|
||
for i in {1..30}; do
|
||
if $DOCKER_COMPOSE_CMD ps | grep -q "Up"; then
|
||
echo "✅ 服务启动成功"
|
||
break
|
||
fi
|
||
sleep 2
|
||
echo -n "."
|
||
done
|
||
|
||
sleep 5
|
||
|
||
# 显示服务状态
|
||
echo "📊 服务状态:"
|
||
$DOCKER_COMPOSE_CMD ps
|
||
|
||
# 重置管理员密码
|
||
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="
|
||
|
||
echo "=== 部署验证结果 ==="
|
||
echo "服务器使用密钥: $SERVER_KEY"
|
||
echo "期望固定密钥: $FIXED_KEY"
|
||
|
||
if [ "$SERVER_KEY" = "$FIXED_KEY" ]; then
|
||
echo "✅ 密钥匹配成功!"
|
||
else
|
||
echo "❌ 密钥不匹配!"
|
||
echo "调试信息:"
|
||
$DOCKER_COMPOSE_CMD logs --tail=20 | grep -i key 2>/dev/null || echo "未找到相关日志"
|
||
fi
|
||
|
||
# 显示最终配置信息
|
||
echo ""
|
||
echo "🎉 RustDesk 服务器部署完成!"
|
||
echo "========================================"
|
||
echo "📋 客户端配置信息:"
|
||
echo " ID 服务器: ${RELAY_SERVER}:21116"
|
||
echo " 中继服务器: ${RELAY_SERVER}:21117"
|
||
echo " API 服务器: http://${RELAY_SERVER}:21114"
|
||
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 "========================================"
|