{
  "timestamp": "2026-05-13T00:37:25.484046+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e",
  "profile": "__runtime_batch-20260513-002930-f95b1e",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 7,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/02_我怀念的_20260513",
        "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/03_Always Online_20260513",
        "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/04_多远都要在一起_20260513"
      ],
      "success_count": 3,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/02_我怀念的_20260513",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/02_我怀念的_20260513/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-20260513-002930-f95b1e/02_我怀念的_20260513",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/02_我怀念的_20260513/step2_json_b.json",
              "agent_summary": "API direct: 数空格",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/03_Always Online_20260513",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/03_Always Online_20260513/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-20260513-002930-f95b1e/03_Always Online_20260513",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/03_Always Online_20260513/step2_json_b.json",
              "agent_summary": "API direct: 别的字",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/04_多远都要在一起_20260513",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/04_多远都要在一起_20260513/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-20260513-002930-f95b1e/04_多远都要在一起_20260513",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-002930-f95b1e/04_多远都要在一起_20260513/step2_json_b.json",
              "agent_summary": "API direct: 折角那页",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "804 out=2819 | ~$0.078\n[00:44:27] ✅ [01_爱错_20260513] Step 2.5: originality 75% ✓\n[00:44:27] ✅ [01_爱错_20260513] Step 2: 《快进不回》\n[00:44:27] 📁 [01_爱错_20260513] Renamed → 01_爱错_快进不回_20260513\n  📝 [01_爱错_快进不回_20260513] lyrics stripped: 5416c → 5000c\n[00:44:27] 🎵 [01_爱错_快进不回_20260513] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[00:44:27] 🎨 [01_爱错_快进不回_20260513] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['49c233ed', 'cded94dc']\n  🎵 49c233ed... → submitted\n  🎵 cded94dc... → submitted\n  🎵 49c233ed... → queued\n  🎵 cded94dc... → queued\n  🎵 4744d17c... → complete\n  🎵 2469f87c... → complete\n[00:45:10]    🎧 [02_我怀念的_20260513] Song 1: https://cdn1.suno.ai/2469f87c-dac6-4d6c-a3a7-0428fb66b44e.mp3\n[00:45:10]    🎧 [02_我怀念的_20260513] Song 2: https://cdn1.suno.ai/bdccf4a1-e868-412d-b4eb-350ca7a2556e.mp3\n[00:45:10] 🎛️ [02_我怀念的_20260513] Step 3.5: 混音...\n[00:45:31]    🎚️ [02_我怀念的_20260513] Song 1: pop | 低38/中58/高4%\n  ✅ submitted: ['320c41e6', '8fc30d80']\n  🎵 320c41e6... → queued\n  🎵 8fc30d80... → streaming\n  🎵 49c233ed... → streaming\n  🎵 cded94dc... → streaming\n[00:45:49]    🎚️ [02_我怀念的_20260513] Song 2: hip_hop | 低44/中52/高4%\n[00:45:49] ✅ [02_我怀念的_20260513] Step 3.5: 39.2s | 2 songs mixed\n[00:45:49] ⚠️  [02_我怀念的_20260513] Step 4: http_403 (non-fatal)\n  🎵 320c41e6... → streaming\n  🎵 3a07ce4c... → complete\n[00:45:50]    🎧 [04_多远都要在一起_20260513] Song 1: https://cdn1.suno.ai/4744d17c-a48c-4e5d-b5ed-b694e34e76bb.mp3\n[00:45:50]    🎧 [04_多远都要在一起_20260513] Song 2: https://cdn1.suno.ai/3a07ce4c-6cc2-42bf-855c-508f08e6e712.mp3\n[00:45:50] 🎛️ [04_多远都要在一起_20260513] Step 3.5: 混音...\n[00:46:12]    🎚️ [04_多远都要在一起_20260513] Song 1: hip_hop | 低50/中42/高8%\n  ✅ submitted: ['14a88562', '884d4398']\n  🎵 14a88562... → streaming\n  🎵 884d4398... → streaming\n[00:46:32]    🎚️ [04_多远都要在一起_20260513] Song 2: pop | 低47/中46/高6%\n[00:46:32] ✅ [04_多远都要在一起_20260513] Step 3.5: 42.4s | 2 songs mixed\n[00:46:32] ⚠️  [04_多远都要在一起_20260513] Step 4: http_403 (non-fatal)\n  🎵 8fc30d80... → complete\n  🎵 14a88562... → complete\n  🎵 320c41e6... → complete\n[00:48:29]    🎧 [07_枪火_掰开它_20260513] Song 1: https://cdn1.suno.ai/320c41e6-cde3-42b8-be8b-9d0af19bd2f1.mp3\n[00:48:29]    🎧 [07_枪火_掰开它_20260513] Song 2: https://cdn1.suno.ai/8fc30d80-50b7-4110-b6a4-e42eead21c6c.mp3\n[00:48:29] 🎛️ [07_枪火_掰开它_20260513] Step 3.5: 混音...\n[00:48:46]    🎚️ [07_枪火_掰开它_20260513] Song 1: rock | 低66/中28/高6%\n  🎵 cded94dc... → complete\n[00:49:02]    🎚️ [07_枪火_掰开它_20260513] Song 2: rock | 低56/中38/高6%\n[00:49:02] ✅ [07_枪火_掰开它_20260513] Step 3.5: 32.6s | 2 songs mixed\n[00:49:02] ⚠️  [07_枪火_掰开它_20260513] Step 4: http_403 (non-fatal)\n  🎵 884d4398... → complete\n[00:49:23]    🎧 [01_爱错_快进不回_20260513] Song 1: https://cdn1.suno.ai/14a88562-89a9-4a05-91d9-0ed5b794bcd5.mp3\n[00:49:23]    🎧 [01_爱错_快进不回_20260513] Song 2: https://cdn1.suno.ai/884d4398-b016-4f7d-bbed-fbe435e69ea7.mp3\n[00:49:23] 🎛️ [01_爱错_快进不回_20260513] Step 3.5: 混音...\n[00:49:38]    🎚️ [01_爱错_快进不回_20260513] Song 1: edm | 低41/中53/高6%\n[00:49:57]    🎚️ [01_爱错_快进不回_20260513] Song 2: hip_hop | 低41/中53/高6%\n[00:49:57] ✅ [01_爱错_快进不回_20260513] Step 3.5: 33.7s | 2 songs mixed\n[00:49:57] ⚠️  [01_爱错_快进不回_20260513] Step 4: http_403 (non-fatal)\n  🎵 49c233ed... → complete\n[00:50:03]    🎧 [05_半壶纱_手心烫_20260513] Song 1: https://cdn1.suno.ai/49c233ed-b4dd-4147-b1cd-d9da59d8c9d8.mp3\n[00:50:03]    🎧 [05_半壶纱_手心烫_20260513] Song 2: https://cdn1.suno.ai/cded94dc-0bf2-4a41-9cb3-414236b0e2fd.mp3\n[00:50:03] 🎛️ [05_半壶纱_手心烫_20260513] Step 3.5: 混音...\n[00:50:23]    🎚️ [05_半壶纱_手心烫_20260513] Song 1: pop | 低30/中66/高4%\n[00:50:43]    🎚️ [05_半壶纱_手心烫_20260513] Song 2: rnb | 低52/中47/高1%\n[00:50:43] ✅ [05_半壶纱_手心烫_20260513] Step 3.5: 39.8s | 2 songs mixed\n[00:50:43] ⚠️  [05_半壶纱_手心烫_20260513] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 591s (9.8min)\n======================================================================\n✅ Done: 6 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260513-002930-f95b1e → +6 新增, ~0 更新 | 总计 731 首\n",
    "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260513-002930-f95b1e' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-002930-f95b1e.yaml\n",
    "summary": {
      "timestamp": "2026-05-13T00:50:43.092519+08:00",
      "wall_clock": 590.8,
      "total": 8,
      "success": 6,
      "awaiting_step2": 0,
      "failed": 0
    }
  },
  "status": "success"
}