deploy.sh 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. #!/bin/bash
  2. # 各服务对应的远程服务器配置
  3. declare -A SERVER_CONFIG=(
  4. # 服务名:IP地址
  5. ["fs-admin"]="162.14.71.71"
  6. ["fs-company"]="162.14.71.71"
  7. ["fs-user-app"]="129.28.111.46"
  8. ["fs-api"]="139.155.112.25"
  9. ["fs-live-socket"]="118.24.135.139"
  10. ["fs-sync"]="139.155.112.25"
  11. )
  12. # 通用配置(所有服务器相同)
  13. REMOTE_USER="root"
  14. REMOTE_BASE_DIR="/home/software"
  15. # 本地 JAR 包路径
  16. LOCAL_FS_ADMIN_JAR="./fs-admin/target/fs-admin.jar"
  17. LOCAL_FS_COMPANY_JAR="./fs-company/target/fs-company.jar"
  18. LOCAL_FS_USER_APP_JAR="./fs-user-app/target/fs-user-app.jar"
  19. LOCAL_FS_API_APP_JAR="./fs-api/target/fs-api.jar"
  20. LOCAL_FS_LIVE_SOCKET_JAR="./fs-live-socket/target/fs-live-socket.jar"
  21. LOCAL_FS_SYNC_APP_JAR="./fs-sync/target/fs-sync-0.0.1-SNAPSHOT.jar"
  22. # 函数:检查本地文件是否存在
  23. check_local_file() {
  24. if [ ! -f "$1" ]; then
  25. echo "错误: 本地文件 $1 不存在。"
  26. exit 1
  27. fi
  28. }
  29. # 停止远程服务器上可能正在运行的旧版本
  30. stop_remote_app() {
  31. local remote_user=$1
  32. local remote_host=$2
  33. local app_name=$3
  34. echo "正在停止 $remote_host 上的 $app_name 服务..."
  35. ssh "$remote_user@$remote_host" "pkill -f $app_name || echo '没有找到运行中的进程'"
  36. }
  37. # 检查服务器连通性
  38. check_server_connectivity() {
  39. local remote_user=$1
  40. local remote_host=$2
  41. if ! ssh -o ConnectTimeout=5 "$remote_user@$remote_host" "echo '连接成功'" &>/dev/null; then
  42. echo "错误: 无法连接到服务器 $remote_host"
  43. return 1
  44. fi
  45. return 0
  46. }
  47. # 部署单个 JAR 包到指定服务器
  48. deploy_jar() {
  49. local local_jar=$1
  50. local service_name=$2 # 服务名,用于确定目标服务器
  51. local remote_dir=$3 # 远程目录名
  52. # 获取服务对应的服务器IP
  53. local remote_host="${SERVER_CONFIG[$service_name]}"
  54. if [ -z "$remote_host" ]; then
  55. echo "错误: 未找到服务 $service_name 的服务器配置"
  56. return 1
  57. fi
  58. local app_name=$(basename "$local_jar" .jar)
  59. echo "========================================"
  60. echo "开始部署 $service_name 到服务器 $remote_host"
  61. echo "本地文件: $local_jar"
  62. echo "远程目录: $REMOTE_BASE_DIR/$remote_dir"
  63. echo "========================================"
  64. # 检查本地文件
  65. check_local_file "$local_jar"
  66. # 检查服务器连通性
  67. if ! check_server_connectivity "$REMOTE_USER" "$remote_host"; then
  68. return 1
  69. fi
  70. # 创建远程目录(如果不存在)
  71. echo "创建远程目录..."
  72. ssh "$REMOTE_USER@$remote_host" "mkdir -p $REMOTE_BASE_DIR/$remote_dir"
  73. # 停止旧版本
  74. stop_remote_app "$REMOTE_USER" "$remote_host" "$app_name"
  75. # 上传 JAR 包
  76. echo "上传 JAR 包..."
  77. scp "$local_jar" "$REMOTE_USER@$remote_host:$REMOTE_BASE_DIR/$remote_dir/"
  78. # 在后台启动 JAR 包
  79. echo "启动服务..."
  80. ssh -f "$REMOTE_USER@$remote_host" \
  81. "cd $REMOTE_BASE_DIR/$remote_dir && \
  82. nohup java -jar -Dfile.encoding=UTF-8 $app_name.jar \
  83. > $app_name.log 2>&1 &"
  84. # 检查进程是否启动成功
  85. if ssh "$REMOTE_USER@$remote_host" "pgrep -f $app_name" &>/dev/null; then
  86. echo "✓ $service_name 部署成功到 $remote_host"
  87. else
  88. echo "✗ $service_name 启动失败,请检查日志: $REMOTE_BASE_DIR/$remote_dir/$app_name.log"
  89. return 1
  90. fi
  91. echo ""
  92. }
  93. # 主要部署流程
  94. echo "开始多服务器分布式部署..."
  95. echo "部署配置:"
  96. for service in "${!SERVER_CONFIG[@]}"; do
  97. echo " $service -> ${SERVER_CONFIG[$service]}"
  98. done
  99. echo ""
  100. # 部署 fs-admin
  101. deploy_jar "$LOCAL_FS_ADMIN_JAR" "fs-admin" "fs-admin"
  102. # 部署 fs-company
  103. deploy_jar "$LOCAL_FS_COMPANY_JAR" "fs-company" "fs-company"
  104. # 部署 fs-user-app
  105. deploy_jar "$LOCAL_FS_USER_APP_JAR" "fs-user-app" "fs-user-app"
  106. # 部署 fs-api
  107. deploy_jar "$LOCAL_FS_API_APP_JAR" "fs-api" "fs-api"
  108. # 部署 fs-live-socket
  109. deploy_jar "$LOCAL_FS_LIVE_SOCKET_JAR" "fs-live-socket" "fs-live-socket"
  110. # 部署 fs-sync (注意:这里使用了不同的JAR命名方式)
  111. deploy_jar "$LOCAL_FS_SYNC_APP_JAR" "fs-sync" "fs-sync"
  112. echo "========================================"
  113. echo "分布式部署完成!"
  114. echo "各服务部署状态:"
  115. for service in "${!SERVER_CONFIG[@]}"; do
  116. remote_host="${SERVER_CONFIG[$service]}"
  117. echo " $service -> $remote_host"
  118. done
  119. echo "========================================"
  120. # 可选:显示各服务进程状态
  121. echo "服务进程状态检查:"
  122. for service in "${!SERVER_CONFIG[@]}"; do
  123. remote_host="${SERVER_CONFIG[$service]}"
  124. app_name="$service" # 简化处理,实际可能需要根据JAR文件名调整
  125. if ssh "$REMOTE_USER@$remote_host" "pgrep -f $app_name" &>/dev/null; then
  126. echo " ✓ $service 在 $remote_host 上运行正常"
  127. else
  128. echo " ✗ $service 在 $remote_host 上未运行"
  129. fi
  130. done