{
  "timestamp": "2026-05-07T15:47:35.628481+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939",
  "profile": "__runtime_batch-20260507-153328-576939",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 3,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/01_恐龙抗狼_20260507",
        "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/02_我姓石_20260507",
        "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/05_一笑江湖 (DJ版)_20260507"
      ],
      "success_count": 3,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/01_恐龙抗狼_20260507",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/01_恐龙抗狼_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-153328-576939/01_恐龙抗狼_20260507",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/01_恐龙抗狼_20260507/step2_json_b.json",
              "agent_summary": "API direct: 蹦个痛快再说",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/02_我姓石_20260507",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/02_我姓石_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-153328-576939/02_我姓石_20260507",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/02_我姓石_20260507/step2_json_b.json",
              "agent_summary": "API direct: 没人能拦我",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/05_一笑江湖 (DJ版)_20260507",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/05_一笑江湖 (DJ版)_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-153328-576939/05_一笑江湖 (DJ版)_20260507",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260507-153328-576939/05_一笑江湖 (DJ版)_20260507/step2_json_b.json",
              "agent_summary": "API direct: 凭什么先放手的不是我",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "  [03_爱如火_20260507] Step 0.5: Only 60.0s preview (expected 234s)\n[15:49:43] 🔒 [03_爱如火_20260507] Step 0.5: source_id locked, skipping cross-platform fallback\n[15:49:43] ❌ [03_爱如火_20260507] Step 0.5: All platforms returned preview (60.0s), skipping song\n[15:49:43] ⬇️  [04_是妈妈是女儿_20260507] Step 0.5: Download from qishui...\n[15:49:43] ⚠️  [04_是妈妈是女儿_20260507] Step 0.5: Only 30.0s preview (expected 375s)\n[15:49:43] 🔒 [04_是妈妈是女儿_20260507] Step 0.5: source_id locked, skipping cross-platform fallback\n[15:49:43] ❌ [04_是妈妈是女儿_20260507] Step 0.5: All platforms returned preview (30.0s), skipping song\n  📝 [01_恐龙抗狼_20260507] lyrics stripped: 2533c → 2527c\n[15:49:43] 🎵 [01_恐龙抗狼_20260507] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[15:49:43] 🎨 [01_恐龙抗狼_20260507] Step 4: SeeDream cover (parallel)...\n  📝 [02_我姓石_20260507] lyrics stripped: 3400c → 3393c\n[15:49:43] 🎵 [02_我姓石_20260507] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[15:49:43] 🎨 [02_我姓石_20260507] Step 4: SeeDream cover (parallel)...\n  📝 [05_一笑江湖 (DJ版)_20260507] lyrics stripped: 3182c → 3175c\n[15:49:43] 🎵 [05_一笑江湖 (DJ版)_20260507] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[15:49:43] 🎨 [05_一笑江湖 (DJ版)_20260507] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['7a292973', '0b44fda7']\n  ✅ submitted: ['9a01da30', 'a351cb8e']\n  🎵 7a292973... → submitted\n  🎵 0b44fda7... → submitted\n  🎵 9a01da30... → submitted\n  🎵 a351cb8e... → submitted\n  ✅ submitted: ['02e47dc7', '95f04aab']\n  🎵 02e47dc7... → submitted\n  🎵 95f04aab... → submitted\n  🎵 9a01da30... → queued\n  🎵 a351cb8e... → queued\n  🎵 7a292973... → queued\n  🎵 0b44fda7... → queued\n  🎵 02e47dc7... → queued\n  🎵 95f04aab... → queued\n  🎵 9a01da30... → streaming\n  🎵 a351cb8e... → streaming\n  🎵 7a292973... → streaming\n  🎵 0b44fda7... → streaming\n  🎵 02e47dc7... → streaming\n  🎵 95f04aab... → streaming\n  ⚠️  poll http_429, retry...\n  ⚠️  poll http_429, retry...\n  ⚠️  poll http_429, retry...\n  ⚠️  poll http_429, retry...\n  🎵 0b44fda7... → complete\n  🎵 7a292973... → complete\n[15:51:55]    🎧 [01_恐龙抗狼_20260507] Song 1: https://cdn1.suno.ai/7a292973-1725-4576-ac91-db997219ef81.mp3\n[15:51:55]    🎧 [01_恐龙抗狼_20260507] Song 2: https://cdn1.suno.ai/0b44fda7-02e5-4cb3-8521-fc668c866fca.mp3\n[15:51:55] 🎛️ [01_恐龙抗狼_20260507] Step 3.5: 混音...\n[15:52:12]    🎚️ [01_恐龙抗狼_20260507] Song 1: edm | 低66/中29/高5%\n  🎵 9a01da30... → complete\n[15:52:23]    🎚️ [01_恐龙抗狼_20260507] Song 2: edm | 低71/中24/高4%\n[15:52:23] ✅ [01_恐龙抗狼_20260507] Step 3.5: 27.4s | 2 songs mixed\n[15:52:23] ⚠️  [01_恐龙抗狼_20260507] Step 4: http_403 (non-fatal)\n  🎵 95f04aab... → complete\n  🎵 a351cb8e... → complete\n[15:52:54]    🎧 [02_我姓石_20260507] Song 1: https://cdn1.suno.ai/9a01da30-5423-4937-9bf6-9a601694ad31.mp3\n[15:52:54]    🎧 [02_我姓石_20260507] Song 2: https://cdn1.suno.ai/a351cb8e-beb2-4cfe-b3b5-187af26cf10a.mp3\n[15:52:54] 🎛️ [02_我姓石_20260507] Step 3.5: 混音...\n[15:53:10]    🎚️ [02_我姓石_20260507] Song 1: edm | 低79/中16/高5%\n  🎵 02e47dc7... → complete\n[15:53:10]    🎧 [05_一笑江湖 (DJ版)_20260507] Song 1: https://cdn1.suno.ai/02e47dc7-3870-4c0d-9b53-1138beaac1c9.mp3\n[15:53:10]    🎧 [05_一笑江湖 (DJ版)_20260507] Song 2: https://cdn1.suno.ai/95f04aab-11fc-4b19-b595-00b23e67cef3.mp3\n[15:53:10] 🎛️ [05_一笑江湖 (DJ版)_20260507] Step 3.5: 混音...\n[15:53:26]    🎚️ [02_我姓石_20260507] Song 2: edm | 低64/中31/高5%\n[15:53:26] ✅ [02_我姓石_20260507] Step 3.5: 31.2s | 2 songs mixed\n[15:53:26] ⚠️  [02_我姓石_20260507] Step 4: http_403 (non-fatal)\n[15:53:41]    🎚️ [05_一笑江湖 (DJ版)_20260507] Song 1: pop | 低46/中49/高5%\n[15:53:58]    🎚️ [05_一笑江湖 (DJ版)_20260507] Song 2: pop | 低48/中45/高7%\n[15:53:58] ✅ [05_一笑江湖 (DJ版)_20260507] Step 3.5: 47.9s | 2 songs mixed\n[15:53:58] ⚠️  [05_一笑江湖 (DJ版)_20260507] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 255s (4.2min)\n======================================================================\n✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 2\n[MasterDB] ✅ 批次 batch-20260507-153328-576939 → +3 新增, ~0 更新 | 总计 651 首\n",
    "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260507-153328-576939' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260507-153328-576939.yaml\n[step05] cache hit: ede9586ce964 → song_pgc.mp3\n[step05] cache hit: 443331c38a53 → song_pgc.mp3\n",
    "summary": {
      "timestamp": "2026-05-07T15:53:58.254336+08:00",
      "wall_clock": 254.9,
      "total": 5,
      "success": 3,
      "awaiting_step2": 0,
      "failed": 2
    }
  },
  "status": "success"
}