deploy.sh 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #!/bin/bash
  2. # 设置远程服务器信息
  3. REMOTE_USER="root" # 远程服务器用户名,根据你的实际情况修改
  4. REMOTE_HOST="111.230.193.88" # 远程服务器地址
  5. REMOTE_BASE_DIR="/home/software" # 远程服务器上的部署目录,根据你的目录结构修改
  6. # 本地 JAR 包路径 -- 根据你提供的目录结构修改
  7. LOCAL_FS_ADMIN_JAR="./fs-admin/target/fs-admin.jar" # 假设target目录和你提供的 tree 命令显示的目录同级
  8. LOCAL_FS_COMPANY_JAR="./fs-company/target/fs-company.jar"
  9. LOCAL_FS_USER_APP_JAR="./fs-user-app/target/fs-user-app.jar"
  10. # 函数:检查本地文件是否存在
  11. check_local_file() {
  12. if [ ! -f "$1" ]; then
  13. echo "Error: Local file $1 not found."
  14. exit 1
  15. fi
  16. }
  17. # 检查本地 JAR 文件是否存在
  18. check_local_file "$LOCAL_FS_ADMIN_JAR"
  19. check_local_file "$LOCAL_FS_COMPANY_JAR"
  20. check_local_file "$LOCAL_FS_USER_APP_JAR"
  21. # 停止远程服务器上可能正在运行的旧版本(假设进程名与 JAR 包名相同)
  22. stop_remote_app() {
  23. local app_name=$1
  24. ssh "$REMOTE_USER@$REMOTE_HOST" "pkill -f $app_name || true"
  25. }
  26. # 部署单个 JAR 包
  27. deploy_jar() {
  28. local local_jar=$1
  29. local remote_dir=$2
  30. local app_name=$(basename "$local_jar" .jar)
  31. # 创建远程目录(如果不存在)
  32. ssh "$REMOTE_USER@$REMOTE_HOST" "mkdir -p $REMOTE_BASE_DIR/$remote_dir"
  33. # 停止旧版本
  34. stop_remote_app $app_name
  35. # 上传 JAR 包
  36. scp "$local_jar" "$REMOTE_USER@$REMOTE_HOST:$REMOTE_BASE_DIR/$remote_dir/"
  37. # 在后台启动 JAR 包, 并将输出重定向到 /dev/null
  38. ssh "$REMOTE_USER@$REMOTE_HOST" "nohup java -jar $REMOTE_BASE_DIR/$remote_dir/$app_name.jar > $REMOTE_BASE_DIR/$remote_dir/$app_name.log 2>&1 &"
  39. echo "Deployed $app_name to $REMOTE_HOST:$REMOTE_BASE_DIR/$remote_dir"
  40. }
  41. # 主要部署流程
  42. # 部署 fs-admin
  43. deploy_jar "$LOCAL_FS_ADMIN_JAR" "fs-admin"
  44. # 部署 fs-company
  45. deploy_jar "$LOCAL_FS_COMPANY_JAR" "fs-company"
  46. # 部署 fs-user-app
  47. deploy_jar "$LOCAL_FS_USER_APP_JAR" "fs-user-app"
  48. echo "Deployment completed."