deploy.sh 5.4 KB

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