build-win-h5-only.yml 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. name: CI 自动构建win h5,并上传到服务器
  2. on:
  3. push:
  4. branches:
  5. - master
  6. repository_dispatch:
  7. types:
  8. - webhook_trigger
  9. # 并发控制:自动取消旧的运行
  10. concurrency:
  11. group: build-win-h5-only-${{ github.ref }}
  12. cancel-in-progress: true
  13. jobs:
  14. build-h5-production:
  15. runs-on: [win-h5-only]
  16. steps:
  17. - name: Test SSH key
  18. run: |
  19. echo "${{ secrets.DEPLOY_KEY }}" > /tmp/test_key
  20. chmod 600 /tmp/test_key
  21. ssh -i /tmp/test_key -o StrictHostKeyChecking=no deploy@${{ secrets.DEPLOY_HOST }} "echo 'SSH key works!'"
  22. rm /tmp/test_key
  23. - name: 检出代码
  24. uses: actions/checkout@v4
  25. - name: 设置 Node.js 环境
  26. uses: actions/setup-node@v4
  27. with:
  28. node-version: '20'
  29. - name: 安装依赖
  30. run: npm install --force
  31. - name: 构建 H5 (生产环境)
  32. env:
  33. GH_TOKEN: ${{ secrets.GH_TOKEN }}
  34. TARO_API_URL: 'http://localhost:6001'
  35. TARO_MQTT_URL: 'ws://localhost:8083/mqtt'
  36. run: |
  37. echo "当前操作系统平台: $(uname -s)"
  38. echo "当前CPU架构: $(uname -m)"
  39. if [ "$(uname -s)" = "Linux" ] && [ "$(uname -m)" = "aarch64" ]; then
  40. echo "复制arm平台必须构建文件taro.linux-arm64-gnu.node到目标位置"
  41. cp .build/taro.linux-arm64-gnu.node node_modules/@tarojs/binding/taro.linux-arm64-gnu.node
  42. echo "复制完成"
  43. fi
  44. node .build/h5_for_production.js
  45. - name: Set timestamp version
  46. run: echo "VERSION=$(date +%Y%m%d-%H%M%S)" >> $GITHUB_ENV
  47. - name: Upload dist/h5/ to server
  48. run: |
  49. # 1. 将私钥写入临时文件
  50. echo "${{ secrets.DEPLOY_KEY }}" > /tmp/deploy_key
  51. chmod 600 /tmp/deploy_key
  52. # 2. 创建远程目录
  53. ssh -i /tmp/deploy_key -o StrictHostKeyChecking=no \
  54. "${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}" \
  55. "mkdir -p ${{ secrets.DEPLOY_PATH }}/${{ env.VERSION }}/"
  56. # 3. 上传文件(不删除本地)
  57. rsync -avz -e "ssh -i /tmp/deploy_key -o StrictHostKeyChecking=no" \
  58. dist/h5/ \
  59. "${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}:${{ secrets.DEPLOY_PATH }}/${{ env.VERSION }}/"
  60. # 4. 清理密钥文件
  61. rm -f /tmp/deploy_key
  62. - name: Update latest symlink
  63. run: |
  64. echo "${{ secrets.DEPLOY_KEY }}" > /tmp/deploy_key
  65. chmod 600 /tmp/deploy_key
  66. ssh -i /tmp/deploy_key -o StrictHostKeyChecking=no \
  67. "${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}" \
  68. "cd ${{ secrets.DEPLOY_PATH }} && ln -sfn ${{ env.VERSION }} latest"
  69. rm -f /tmp/deploy_key