deploy.sh 4.1 KB

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