{
  "timestamp": "2026-05-12T16:58:32.804763+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b",
  "profile": "__runtime_batch-20260512-165641-70714b",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 2,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/01_唯一（Cover G.E.M. 邓紫棋）_20260512",
        "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/02_恋人_20260512"
      ],
      "success_count": 2,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/01_唯一（Cover G.E.M. 邓紫棋）_20260512",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/01_唯一（Cover G.E.M. 邓紫棋）_20260512/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-20260512-165641-70714b/01_唯一（Cover G.E.M. 邓紫棋）_20260512",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/01_唯一（Cover G.E.M. 邓紫棋）_20260512/step2_json_b.json",
              "agent_summary": "API direct: 回潮线",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/02_恋人_20260512",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/02_恋人_20260512/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-20260512-165641-70714b/02_恋人_20260512",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260512-165641-70714b/02_恋人_20260512/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-20260512-165641-70714b\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[17:01:39] 🏥 Health check...\n[17:01:41] ✅ qishui: OK\n[17:01:41] ✅ netease: OK\n[17:01:41] ✅ qq: OK\n\n  📝 [01_唯一（Cover G.E.M. 邓紫棋）_20260512] lyrics stripped: 4872c → 4865c\n[17:01:42] 🎵 [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[17:01:42] 🎨 [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Step 4: SeeDream cover (parallel)...\n  📝 [02_恋人_20260512] lyrics stripped: 3907c → 3901c\n[17:01:42] 🎵 [02_恋人_20260512] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[17:01:42] 🎨 [02_恋人_20260512] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['31121d21', '0012de37']\n  🎵 31121d21... → submitted\n  🎵 0012de37... → submitted\n  ✅ submitted: ['6a60d046', '509578d3']\n  🎵 6a60d046... → submitted\n  🎵 509578d3... → submitted\n  🎵 31121d21... → queued\n  🎵 0012de37... → queued\n  🎵 6a60d046... → queued\n  🎵 509578d3... → queued\n  🎵 31121d21... → streaming\n  🎵 0012de37... → streaming\n  🎵 6a60d046... → streaming\n  🎵 509578d3... → streaming\n  🎵 31121d21... → complete\n  🎵 0012de37... → complete\n[17:02:51]    🎧 [02_恋人_20260512] Song 1: https://cdn1.suno.ai/31121d21-f909-48a7-a0af-4db090985195.mp3\n[17:02:51]    🎧 [02_恋人_20260512] Song 2: https://cdn1.suno.ai/0012de37-c8dc-415b-a707-6abc26d4316b.mp3\n[17:02:51] 🎛️ [02_恋人_20260512] Step 3.5: 混音...\n  🎵 509578d3... → complete\n[17:03:11]    🎚️ [02_恋人_20260512] Song 1: hip_hop | 低56/中42/高2%\n  🎵 6a60d046... → complete\n[17:03:12]    🎧 [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Song 1: https://cdn1.suno.ai/6a60d046-695a-4480-9e9d-9ab05e6bf7d5.mp3\n[17:03:12]    🎧 [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Song 2: https://cdn1.suno.ai/509578d3-d6a3-4c78-a8e6-9f31c7005fcf.mp3\n[17:03:12] 🎛️ [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Step 3.5: 混音...\n[17:03:29]    🎚️ [02_恋人_20260512] Song 2: jazz | 低48/中49/高2%\n[17:03:29] ✅ [02_恋人_20260512] Step 3.5: 37.6s | 2 songs mixed\n[17:03:29] ⚠️  [02_恋人_20260512] Step 4: http_403 (non-fatal)\n[17:03:47]    🎚️ [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Song 1: pop | 低47/中51/高3%\n[17:04:06]    🎚️ [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Song 2: pop | 低47/中51/高2%\n[17:04:06] ✅ [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Step 3.5: 53.7s | 2 songs mixed\n[17:04:06] ⚠️  [01_唯一（Cover G.E.M. 邓紫棋）_20260512] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 144s (2.4min)\n======================================================================\n✅ Done: 2 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260512-165641-70714b → +2 新增, ~0 更新 | 总计 687 首\n",
    "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260512-165641-70714b' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260512-165641-70714b.yaml\n",
    "summary": {
      "timestamp": "2026-05-12T17:04:06.151699+08:00",
      "wall_clock": 144.2,
      "total": 2,
      "success": 2,
      "awaiting_step2": 0,
      "failed": 0
    }
  },
  "status": "success"
}