Update ru

This commit is contained in:
2025-11-01 20:20:09 +08:00
committed by GitHub
parent e3fdf10289
commit bc72b7b486

366
ru
View File

@@ -1,252 +1,182 @@
set -e
echo "🚀 RustDesk 服务器一键部署脚本 (网络优化版)"
echo "🚀 RustDesk 服务器一键部署脚本 (加速源可选版)"
echo "🚀 RustDesk 服务器一键部署脚本 (优化版)"
echo "🚀 RustDesk 服务器一键部署脚本 (官方镜像版)"
echo "========================================"
# 检查 Docker
if ! command -v docker &> /dev/null; then
echo "❌ Docker 未安装,正在安装 Docker..."
curl -fsSL https://get.docker.com | sh
systemctl start docker
systemctl enable docker
fi
# 加速源选择函数
select_accelerator() {
echo "🌐 请选择加速源:"
echo "1) 使用默认 Docker 官方源 (可能较慢)"
echo "2) 使用国内镜像加速器"
echo "3) 使用自定义加速源 github.vps7k7k.xyz"
echo "4) 不使用加速器"
read -p "请输入选择 [1-4]: " choice
case $choice in
1)
echo "✅ 使用 Docker 官方源"
ACCELERATOR="official"
;;
2)
echo "✅ 使用国内镜像加速器"
ACCELERATOR="china"
;;
3)
echo "✅ 使用自定义加速源 github.vps7k7k.xyz"
ACCELERATOR="custom"
;;
4)
echo "✅ 不使用加速器"
ACCELERATOR="none"
;;
*)
echo "⚠️ 无效选择,使用国内镜像加速器"
ACCELERATOR="china"
;;
esac
}
# 设置 Docker 镜像加速器
echo "🔧 配置 Docker 镜像加速..."
mkdir -p /etc/docker
cat > /etc/docker/daemon.json << EOF
# 配置 Docker 加速器
setup_docker_accelerator() {
case $ACCELERATOR in
"china")
echo "🔧 配置国内镜像加速器..."
cat > /etc/docker/daemon.json << EOF
{
"registry-mirrors": [
"https://docker.mirrors.ustc.edu.cn",
@@ -25,14 +53,86 @@ cat > /etc/docker/daemon.json << EOF
]
}
EOF
systemctl daemon-reload
systemctl restart docker
;;
"custom")
echo "🔧 配置自定义加速源 github.vps7k7k.xyz..."
cat > /etc/docker/daemon.json << EOF
{
"registry-mirrors": [
"https://github.vps7k7k.xyz"
]
}
EOF
;;
"official"|"none")
echo " 使用默认 Docker 官方源"
rm -f /etc/docker/daemon.json
;;
esac
if [ "$ACCELERATOR" != "none" ]; then
systemctl daemon-reload
systemctl restart docker
echo "✅ Docker 加速器配置完成"
fi
}
# 检查 Docker
if ! command -v docker &> /dev/null; then
echo "❌ Docker 未安装,正在安装 Docker..."
# 选择加速源
select_accelerator
# 根据选择配置安装源
case $ACCELERATOR in
"china")
echo "📥 使用国内源安装 Docker..."
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
;;
"custom")
echo "📥 使用自定义加速源安装 Docker..."
curl -fsSL https://get.docker.com | bash
;;
*)
echo "📥 使用官方源安装 Docker..."
curl -fsSL https://get.docker.com | bash
;;
esac
systemctl start docker
systemctl enable docker
else
# 如果 Docker 已安装,选择加速源
select_accelerator
fi
# 配置 Docker 加速器
mkdir -p /etc/docker
setup_docker_accelerator
# 检查 Docker Compose
DOCKER_COMPOSE_CMD="docker compose"
if ! command -v docker &> /dev/null || ! docker compose version &> /dev/null; then
echo "📥 安装 Docker Compose..."
curl -L "https://github.com/docker/compose/releases/download/v2.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
# 根据加速源选择下载地址
case $ACCELERATOR in
"china")
# 使用国内镜像下载
COMPOSE_URL="https://ghproxy.com/https://github.com/docker/compose/releases/download/v2.24.0/docker-compose-$(uname -s)-$(uname -m)"
;;
"custom")
# 使用自定义加速源
COMPOSE_URL="https://github.vps7k7k.xyz/https://github.com/docker/compose/releases/download/v2.24.0/docker-compose-$(uname -s)-$(uname -m)"
;;
*)
# 使用官方源
COMPOSE_URL="https://github.com/docker/compose/releases/download/v2.24.0/docker-compose-$(uname -s)-$(uname -m)"
;;
esac
curl -L "$COMPOSE_URL" -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
DOCKER_COMPOSE_CMD="docker-compose"
fi
@@ -80,7 +180,7 @@ echo "✅ 服务器 IP: $PUBLIC_IP"
@@ -79,61 +79,75 @@ echo "✅ 服务器 IP: $PUBLIC_IP"
# 生成管理员密码
ADMIN_PASSWORD=$(openssl rand -base64 12 2>/dev/null || date +%s | sha256sum | base64 | head -c 12)
# 创建 Docker Compose 配置(基于您的参考)
# 创建 Docker Compose 配置
# 创建环境配置
cat > .env << EOF
PUBLIC_IP=$PUBLIC_IP
UNIFIED_KEY=$UNIFIED_KEY_FINGERPRINT
ADMIN_PASSWORD=$ADMIN_PASSWORD
TIMEZONE=Asia/Shanghai
ENCRYPTED_ONLY=1
MUST_LOGIN=y
EOF
# 创建 Docker Compose 配置(修复版本警告)
cat > docker-compose.yml << 'EOF'
# 创建 Docker Compose 配置(使用官方镜像)
cat > docker-compose.yml << EOF
networks:
rustdesk-net:
@@ -132,14 +232,26 @@ echo "✅ 配置文件创建完成"
# 显示配置信息
echo ""
echo "📋 配置信息:"
echo " 加速源: $ACCELERATOR"
echo " 服务器IP: $PUBLIC_IP"
echo " 统一密钥: $UNIFIED_KEY_FINGERPRINT"
echo " JWT密钥: $JWT_KEY"
echo " 管理员密码: $ADMIN_PASSWORD"
echo ""
services:
rustdesk-server:
container_name: rustdesk-server
image: lejianwen/rustdesk-server-s6:latest
hbbs:
container_name: rustdesk-hbbs
image: rustdesk/rustdesk-server:latest
command: hbbs -r ${PUBLIC_IP}:21117
ports:
- "21114:21114" # API 管理界面
- "21115:21115" # 网页客户端
- "21116:21116" # ID 服务器 (TCP)
- "21116:21116/udp"
- "21117:21117" # 中继服务器
- "21118:21118" # WebSocket
volumes:
- ./data/keys:/root
- ./data/db:/root
environment:
- RELAY_SERVER=${PUBLIC_IP}
- FIXED_KEY=${UNIFIED_KEY_FINGERPRINT}
- MUST_LOGIN=y
- ENCRYPTED_ONLY=1
restart: unless-stopped
# 拉取镜像
# 拉取镜像(根据加速源显示不同信息)
hbbr:
container_name: rustdesk-hbbr
image: rustdesk/rustdesk-server:latest
command: hbbr
ports:
- "21117:21117" # 中继服务器
- "21119:21119" # 备用端口
volumes:
- ./data/keys:/root
- ./data/db:/root
environment:
- RELAY_SERVER=${PUBLIC_IP}
- FIXED_KEY=${UNIFIED_KEY_FINGERPRINT}
- MUST_LOGIN=y
- ENCRYPTED_ONLY=1
restart: unless-stopped
api:
container_name: rustdesk-api
image: rustdesk/rustdesk-server:latest
command: ./apimain
ports:
- "21114:21114" # API 管理界面
volumes:
- ./data/keys:/root
- ./data/db:/root
environment:
- RELAY=${PUBLIC_IP}
- PUBLIC_IP=${PUBLIC_IP}
- ENCRYPTED_ONLY=${ENCRYPTED_ONLY}
- MUST_LOGIN=${MUST_LOGIN}
- FIXED_KEY=${UNIFIED_KEY}
- RUSTDESK_API_RUSTDESK_ID_SERVER=${PUBLIC_IP}:21116
- RUSTDESK_API_RUSTDESK_RELAY_SERVER=${PUBLIC_IP}:21117
- RUSTDESK_API_RUSTDESK_API_SERVER=http://${PUBLIC_IP}:21114
- RUSTDESK_API_RUSTDESK_KEY=${UNIFIED_KEY}
- RUSTDESK_API_RUSTDESK_KEY_FILE=/root/keys/id_ed25519.pub
- RUSTDESK_API_JWT_KEY=${UNIFIED_KEY}
- RUSTDESK_API_RUSTDESK_KEY=${UNIFIED_KEY_FINGERPRINT}
- RUSTDESK_API_JWT_KEY=${UNIFIED_KEY_FINGERPRINT}
- RUSTDESK_API_APP_WEB_CLIENT=1
- RUSTDESK_API_APP_REGISTER=false
- RUSTDESK_API_LANG=zh-CN
- TZ=${TIMEZONE}
volumes:
- ./data/keys:/root/keys
- ./data/db:/root/db
- RUSTDESK_API_APP_CAPTCHA_THRESHOLD=-1
- ADMIN_PASSWORD=${ADMIN_PASSWORD}
restart: unless-stopped
healthcheck:
test: ["CMD", "netstat", "-ltn"]
interval: 30s
timeout: 10s
retries: 3
depends_on:
- hbbs
- hbbr
EOF
echo "✅ 配置文件创建完成"
# 拉取镜像(显示进度)
echo "📥 拉取 Docker 镜像..."
case $ACCELERATOR in
"china")
echo " 使用国内镜像加速器拉取镜像..."
;;
"custom")
echo " 使用自定义加速源 github.vps7k7k.xyz 拉取镜像..."
;;
*)
echo " 使用默认源拉取镜像..."
;;
esac
# 拉取镜像
echo "📥 拉取官方 RustDesk 镜像..."
$DOCKER_COMPOSE_CMD pull
# 启动服务
@@ -168,22 +280,6 @@ else
echo " 手动设置命令: docker exec -it rustdesk-server ./apimain reset-admin-pwd 新密码"
fi
@@ -142,21 +156,52 @@ $DOCKER_COMPOSE_CMD up -d
# 验证密钥一致性
echo "🔍 验证密钥一致性..."
SERVER_KEY=$($DOCKER_COMPOSE_CMD logs 2>/dev/null | grep "Key:" | tail -1 | awk '{print $NF}' || echo "")
# 等待启动
echo "⏳ 等待服务启动..."
sleep 30
for i in {1..30}; do
if $DOCKER_COMPOSE_CMD ps | grep -q "Up"; then
echo "✅ 服务启动成功"
break
fi
sleep 2
echo -n "."
done
echo "=== 部署验证结果 ==="
echo "服务器使用密钥: $SERVER_KEY"
echo "统一固定密钥: $UNIFIED_KEY_FINGERPRINT"
# 设置管理员密码
echo "🔐 设置管理员密码..."
docker exec rustdesk-server ./apimain reset-admin-pwd "$ADMIN_PASSWORD" 2>/dev/null || echo "⚠️ 密码设置可能需要重试"
sleep 10
if [ "$SERVER_KEY" = "$UNIFIED_KEY_FINGERPRINT" ]; then
echo "✅ 密钥匹配成功跨VPS密钥统一"
else
echo "❌ 密钥不匹配!"
echo "调试信息:"
$DOCKER_COMPOSE_CMD logs --tail=10 | grep -i key 2>/dev/null || echo "未找到相关日志"
fi
# 显示最终配置信息
# 显示部署结果
echo ""
echo "🎉 RustDesk 服务器部署完成!"
@@ -194,28 +290,19 @@ echo " API 管理界面: http://$PUBLIC_IP:21114"
echo "========================================"
echo "🌐 网页远程登录: http://$PUBLIC_IP:21115"
echo "🔑 统一密钥: $UNIFIED_KEY_FINGERPRINT"
echo "🔐 管理员密码: $ADMIN_PASSWORD"
echo "📊 服务状态:"
$DOCKER_COMPOSE_CMD ps
echo ""
echo "🌐 访问地址:"
echo " 网页远程登录: http://${PUBLIC_IP}:21115"
echo " API 管理界面: http://${PUBLIC_IP}:21114"
echo ""
echo "🔑 统一密钥配置:"
echo " 密钥指纹: $UNIFIED_KEY_FINGERPRINT"
echo " 私钥路径: $WORK_DIR/server/id_ed25519"
echo " 公钥路径: $WORK_DIR/server/id_ed25519.pub"
echo " 密钥指纹: ${UNIFIED_KEY_FINGERPRINT}"
echo ""
echo "🔐 登录信息:"
echo " 管理员密码: $ADMIN_PASSWORD"
echo " (首次登录后请立即修改密码)"
echo " 管理员密码: ${ADMIN_PASSWORD}"
echo ""
echo "📡 客户端配置:"
echo " ID 服务器: $PUBLIC_IP:21116"
echo " 中继服务器: $PUBLIC_IP:21117"
echo " API 服务器: http://$PUBLIC_IP:21114"
echo " 密钥: $UNIFIED_KEY_FINGERPRINT"
echo " ID 服务器: ${PUBLIC_IP}:21116"
echo " 中继服务器: ${PUBLIC_IP}:21117"
echo " 密钥: ${UNIFIED_KEY_FINGERPRINT}"
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 " 进入容器: docker exec -it rustdesk-server /bin/bash"
echo ""
echo "💾 数据目录:"
echo " 服务器配置: $WORK_DIR/server/"
echo " 数据库文件: $WORK_DIR/api/"
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 "========================================"
# 测试端口连通性
@@ -227,10 +314,3 @@ for port in 21114 21115 21116 21117; do
echo "❌ 端口 $port 无法连接"
fi
echo "🔍 测试服务端口..."
for port in 21114 21115 21116 21117; do
if nc -z localhost $port 2>/dev/null; then
echo "✅ 端口 $port 监听正常"
else
echo "❌ 端口 $port 无法连接"
fi
done
# 显示网络信息
echo ""
echo "🌐 网络配置:"
echo " 使用自定义网络: rustdesk-net"
echo " 网络模式: bridge (内部通信)"
docker network ls | grep rustdesk-net