{
  "timestamp": "2026-05-07T15:12:51.058049+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e",
  "profile": "__runtime_batch-20260507-150822-cd4f4e",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 1,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507"
      ],
      "success_count": 1,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507/step2_json_b.json",
          "agent_summary": "API direct: 旧茧",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507/step2_json_b.json",
              "agent_summary": "API direct: 旧茧",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "\n======================================================================\nmusic-pipeline3000 v2 | 2 songs\n======================================================================\nGemini concurrency: 2 | Suno concurrency: 3\nOutput: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[15:13:36] 🏥 Health check...\n[15:13:38] ✅ qishui: OK\n[15:13:38] ✅ netease: OK\n[15:13:38] ✅ qq: OK\n\n[15:13:38] 🧠 [02_Bud Light The Way_20260507] Step 1: Gemini (queuing)...\n{\"__trace__\": true, \"ts\": \"2026-05-07T07:13:38.524Z\", \"trace_id\": \"batch-20260507-150822-cd4f4e\", \"song_key\": \"02_Bud Light The Way_20260507\", \"step\": \"step1\", \"type\": \"step_start\", \"inputs\": {\"audio\": \"/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/02_Bud Light The Way_20260507/song_pgc.mp3\", \"has_features\": true}}\n  📝 [01_Old Dirt Roads_20260507] lyrics stripped: 3957c → 3950c\n[15:13:38] 🎵 [01_Old Dirt Roads_20260507] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[15:13:38] 🎨 [01_Old Dirt Roads_20260507] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['d5c241f0', '39668268']\n  🎵 d5c241f0... → submitted\n  🎵 39668268... → submitted\n  ⚠️ Gemini official 503 on key #1/5, will retry...\n  🔄 Retry 1/4 in 3s...\n  🎵 d5c241f0... → queued\n  🎵 39668268... → queued\n  ⚠️ Gemini official 503 on key #2/5, will retry...\n  🔄 Retry 2/4 in 3s...\n  🎵 d5c241f0... → streaming\n  🎵 39668268... → streaming\n  ⚠️ Gemini official 503 on key #3/5, will retry...\n  🔄 Retry 3/4 in 3s...\n  ⚠️ Gemini official 503 on key #4/5, will retry...\n  🔄 Retry 4/4 in 3s...\n  ⚠️ Gemini official 503 on key #5/5, will retry...\n{\"__trace__\": true, \"ts\": \"2026-05-07T07:14:15.107Z\", \"trace_id\": \"batch-20260507-150822-cd4f4e\", \"song_key\": \"02_Bud Light The Way_20260507\", \"step\": \"step1\", \"type\": \"api_call\", \"provider\": \"gemini\", \"model\": \"gemini-2.5-pro\", \"duration_sec\": 4.7, \"cost_usd\": null, \"status\": \"http_503\"}\n{\"__trace__\": true, \"ts\": \"2026-05-07T07:14:15.108Z\", \"trace_id\": \"batch-20260507-150822-cd4f4e\", \"song_key\": \"02_Bud Light The Way_20260507\", \"step\": \"step1\", \"type\": \"step_end\", \"status\": \"success\", \"duration_sec\": 36.583}\n[15:14:15] ❌ [02_Bud Light The Way_20260507] Step 1: http_503 (4.7s)\n  🎵 d5c241f0... → complete\n  🎵 39668268... → complete\n[15:17:02]    🎧 [01_Old Dirt Roads_20260507] Song 1: https://cdn1.suno.ai/d5c241f0-36cf-4367-a429-2d09f8d13346.mp3\n[15:17:02]    🎧 [01_Old Dirt Roads_20260507] Song 2: https://cdn1.suno.ai/39668268-9493-4f87-8a6f-5b927f2fdbaf.mp3\n[15:17:02] 🎛️ [01_Old Dirt Roads_20260507] Step 3.5: 混音...\n[15:17:27]    🎚️ [01_Old Dirt Roads_20260507] Song 1: rock | 低48/中47/高6%\n[15:17:49]    🎚️ [01_Old Dirt Roads_20260507] Song 2: jazz | 低58/中38/高4%\n[15:17:49] ✅ [01_Old Dirt Roads_20260507] Step 3.5: 47.2s | 2 songs mixed\n[15:17:49] ⚠️  [01_Old Dirt Roads_20260507] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 251s (4.2min)\n======================================================================\n✅ Done: 1 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1\n[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +1 新增, ~0 更新 | 总计 641 首\n",
    "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260507-150822-cd4f4e' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260507-150822-cd4f4e.yaml\n",
    "summary": {
      "timestamp": "2026-05-07T15:17:49.711079+08:00",
      "wall_clock": 251.2,
      "total": 2,
      "success": 1,
      "awaiting_step2": 0,
      "failed": 1
    }
  },
  "status": "success"
}