
=== 2026-05-07 15:10:43 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260507-150822-cd4f4e --target-language zh --step1-only ===
[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
[   INFO   ] MusicExtractorSVM: no classifier models were configured by default
[   INFO   ] On connection Flux::flux → IIR::signal:
[   INFO   ] BUFFER SIZE MISMATCH: max=0 - asked for read size 4096
[   INFO   ] resizing buffer to 36040/4505
[   INFO   ] FrameCutter: dropping incomplete frame
[   INFO   ] On connection Flux::flux → IIR::signal:
[   INFO   ] BUFFER SIZE MISMATCH: max=0 - asked for read size 4096
[   INFO   ] resizing buffer to 36040/4505
[   INFO   ] FrameCutter: dropping incomplete frame
/usr/local/lib/python3.13/dist-packages/scipy/cluster/hierarchy.py:810: ClusterWarning: The symmetric non-negative hollow observation matrix looks suspiciously like an uncondensed distance matrix
  return linkage(y, method='ward', metric='euclidean')
/usr/local/lib/python3.13/dist-packages/scipy/cluster/hierarchy.py:810: ClusterWarning: The symmetric non-negative hollow observation matrix looks suspiciously like an uncondensed distance matrix
  return linkage(y, method='ward', metric='euclidean')

======================================================================
music-pipeline3000 v2 | 2 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

[15:10:45] 🏥 Health check...
[15:10:46] ✅ qishui: OK
[15:10:46] ✅ netease: OK
[15:10:46] ✅ qq: OK

[15:10:46] 🔍 [01_Old Dirt Roads_20260507] Step 0: Fetching...
[15:10:46] 🔍 [02_Bud Light The Way_20260507] Step 0: Fetching...
[15:10:49] ✅ [02_Bud Light The Way_20260507] Step 0: netease | 63c lyrics
[15:10:49] ⬇️  [02_Bud Light The Way_20260507] Step 0.5: Download from netease...
[15:10:50] ✅ [01_Old Dirt Roads_20260507] Step 0: netease | 63c lyrics
[15:10:50] ⬇️  [01_Old Dirt Roads_20260507] Step 0.5: Download from netease...
[15:10:57] ✅ [02_Bud Light The Way_20260507] Step 0.5: 4297307 bytes | 190.4s
[15:10:57] 🔬 [02_Bud Light The Way_20260507] Step 0.75: Audio features...
[15:10:58] ✅ [01_Old Dirt Roads_20260507] Step 0.5: 5091940 bytes | 227.9s
[15:10:58] 🔬 [01_Old Dirt Roads_20260507] Step 0.75: Audio features...
[15:11:31] ✅ [02_Bud Light The Way_20260507] Step 0.75: BPM=165.52 Key=E major (33.9s)
[15:11:31] 🧠 [02_Bud Light The Way_20260507] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-07T07:11:31.601Z", "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}}
[15:11:31] 🌐 Step 1: target_language=zh (injecting override directive)
[15:11:31] ✅ [01_Old Dirt Roads_20260507] Step 0.75: BPM=165.55 Key=C# major (32.9s)
[15:11:31] 🧠 [01_Old Dirt Roads_20260507] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-07T07:11:31.837Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "01_Old Dirt Roads_20260507", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/01_Old Dirt Roads_20260507/song_pgc.mp3", "has_features": true}}
[15:11:31] 🌐 Step 1: target_language=zh (injecting override directive)
  ⚠️ Gemini official 503 on key #1/5, will retry...
  🔄 Retry 1/4 in 3s...
  ⚠️ Gemini official 503 on key #1/5, will retry...
  🔄 Retry 1/4 in 3s...
  ⚠️ Gemini official 503 on key #2/5, will retry...
  🔄 Retry 2/4 in 3s...
  ⚠️ Gemini official 503 on key #3/5, will retry...
  🔄 Retry 3/4 in 3s...
  ⚠️ Gemini official 503 on key #4/5, will retry...
  🔄 Retry 4/4 in 3s...
  ⚠️ Gemini official 503 on key #5/5, will retry...
{"__trace__": true, "ts": "2026-05-07T07:12:32.412Z", "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.1, "cost_usd": null, "status": "http_503"}
{"__trace__": true, "ts": "2026-05-07T07:12:32.412Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "02_Bud Light The Way_20260507", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 60.811}
[15:12:32] ❌ [02_Bud Light The Way_20260507] Step 1: http_503 (4.1s)
  📊 Gemini official: 72s | prompt_tokens=10535 completion=1684
{"__trace__": true, "ts": "2026-05-07T07:12:50.068Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "01_Old Dirt Roads_20260507", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 71.6, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-07T07:12:50.068Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "01_Old Dirt Roads_20260507", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 78.231}
[15:12:50] ⚠️  [01_Old Dirt Roads_20260507] Step 1.5: prompt 1066c > 1000c, compressing...
  📏 [01_Old Dirt Roads_20260507] prompt 1066c → 922c (smart truncate)
[15:12:50] ✅ [01_Old Dirt Roads_20260507] Step 1.5: prompt compressed 1066c → 922c
[15:12:50] ✅ [01_Old Dirt Roads_20260507] Step 1: 71.6s | prompt=922c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 123s (2.1min)
======================================================================
✅ Done: 1 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +0 新增, ~0 更新 | 总计 638 首
[exit 0]

=== 2026-05-07 15:12:50 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e --profile __runtime_batch-20260507-150822-cd4f4e --resume-mode each --skip-feishu --target-language zh ===
[phase2] batch=batch-20260507-150822-cd4f4e pending=1 groups=1
[phase2] group 1/1 -> 01_Old Dirt Roads_20260507
[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
[phase2] 🌐 01_Old Dirt Roads_20260507: target_language=zh
[phase2] resume -> /usr/bin/python3 /srv/repos/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e --profile __runtime_batch-20260507-150822-cd4f4e --skip-feishu

=== 2026-05-07 15:15:00 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260507-150822-cd4f4e --resume /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e --target-language zh ===
[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

======================================================================
music-pipeline3000 v2 | 2 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
Skip Suno: False | Step1 only: False | Version: v4
======================================================================

[15:15:02] 🏥 Health check...
[15:15:04] ✅ qishui: OK
[15:15:04] ✅ netease: OK
[15:15:04] ✅ qq: OK

[15:15:04] 🧠 [02_Bud Light The Way_20260507] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-07T07:15:04.037Z", "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}}
[15:15:04] 🌐 Step 1: target_language=zh (injecting override directive)
  📝 [01_Old Dirt Roads_20260507] lyrics stripped: 3957c → 3950c
[15:15:04] 🎵 [01_Old Dirt Roads_20260507] Step 3: Suno generation (weirdness=50, style_influence=50)...
[15:15:04] 🎨 [01_Old Dirt Roads_20260507] Step 4: SeeDream cover (parallel)...
  ✅ submitted: ['ce421997', '242666c1']
  🎵 ce421997... → submitted
  🎵 242666c1... → submitted
  🎵 ce421997... → queued
  🎵 242666c1... → queued
  ⚠️ Gemini official 503 on key #1/5, will retry...
  🔄 Retry 1/4 in 3s...
  🎵 ce421997... → streaming
  🎵 242666c1... → streaming
  ⚠️ Gemini official 503 on key #2/5, will retry...
  🔄 Retry 2/4 in 3s...
  ⚠️ Gemini official 503 on key #3/5, will retry...
  🔄 Retry 3/4 in 3s...
  ⚠️ Gemini official 503 on key #4/5, will retry...
  🔄 Retry 4/4 in 3s...
  ⚠️ Gemini official 503 on key #5/5, will retry...
{"__trace__": true, "ts": "2026-05-07T07:15:42.684Z", "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": 2.6, "cost_usd": null, "status": "http_503"}
{"__trace__": true, "ts": "2026-05-07T07:15:42.684Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "02_Bud Light The Way_20260507", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 38.647}
[15:12:51] 🌐 [01_Old Dirt Roads_20260507] Step 2: target_language=zh → lang_mode=ZH
[15:12:51] 🤖 [01_Old Dirt Roads_20260507] Step 2 API: 35506 chars ≈ 8876 tokens → claude-sonnet-4-6
[15:13:35] ✅ [01_Old Dirt Roads_20260507] Step 2 API: 《旧茧》 | 43.9s | in=18534 out=2666 | ~$0.096
{"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"}
[exit 0]

=== 2026-05-07 15:17:50 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e ===
[Feishu] ✅ Exported 1 songs to: https://ccnu62373cgc.feishu.cn/sheets/OokksnKT7hZ2nKtbbVycNZQKnlc
[Feishu] 📐 Expanded master sheet from 581 to 682 rows
[Feishu] ✅ Appended 1 new songs to master sheet (rows 582-582)
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +1 新增, ~0 更新 | 总计 582 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/OokksnKT7hZ2
[15:17:59] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [旧茧] topic head sent (message_id=om_x100b50f784b148b0b4a4ceadf7ac08e)
[Feishu IM] ✅ [旧茧] 旧茧_V1_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V1_mixed.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_mixed.mp3 replied
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260507-150822-cd4f4e
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e

📊 https://ccnu62373cgc.feishu.cn/sheets/OokksnKT7hZ2nKtbbVycNZQKnlc
[exit 0]
[15:15:42] ❌ [02_Bud Light The Way_20260507] Step 1: http_503 (2.6s)
  🎵 242666c1... → complete
  🎵 ce421997... → complete
[15:18:57]    🎧 [01_Old Dirt Roads_20260507] Song 1: https://cdn1.suno.ai/ce421997-ba41-4963-b319-10a7a4ec229e.mp3
[15:18:57]    🎧 [01_Old Dirt Roads_20260507] Song 2: https://cdn1.suno.ai/242666c1-f6c7-4b91-a181-6339ee016918.mp3
[15:18:57] 🎛️ [01_Old Dirt Roads_20260507] Step 3.5: 混音...
[15:19:20]    🎚️ [01_Old Dirt Roads_20260507] Song 1: rock | 低48/中47/高6%
[15:19:41]    🎚️ [01_Old Dirt Roads_20260507] Song 2: jazz | 低58/中38/高4%
[15:19:41] ✅ [01_Old Dirt Roads_20260507] Step 3.5: 43.8s | 2 songs mixed
[15:19:41] ⚠️  [01_Old Dirt Roads_20260507] Step 4: http_403 (non-fatal)

======================================================================
SUMMARY | 277s (4.6min)
======================================================================
✅ Done: 1 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +0 新增, ~1 更新 | 总计 641 首
[exit 0]

=== 2026-05-07 15:19:42 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e ===
[Feishu] ✅ Exported 1 songs to: https://ccnu62373cgc.feishu.cn/sheets/XfkdsChaSh8yPIt6n4Kcs6zvnWd
[Feishu] ⏭️  Skip duplicate (complete): Old Dirt Roads (https://fileserver.yuchenhu.com/pipeline/batch-20260507-150822-cd4f4e/01_Old%20Dirt%20Roads_20260507/song_pgc.mp3)
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +0 新增, ~0 更新 | 总计 582 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/XfkdsChaSh8y
[15:19:49] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [旧茧] topic head sent (message_id=om_x100b50f79fa870a4b2be23836028966)
[Feishu IM] ✅ [旧茧] 旧茧_V1_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V1_mixed.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_mixed.mp3 replied
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260507-150822-cd4f4e
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e

📊 https://ccnu62373cgc.feishu.cn/sheets/XfkdsChaSh8yPIt6n4Kcs6zvnWd
[exit 0]

=== 2026-05-07 15:22:01 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260507-150822-cd4f4e --resume /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e --target-language zh ===
[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

======================================================================
music-pipeline3000 v2 | 2 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
Skip Suno: False | Step1 only: False | Version: v4
======================================================================

[15:22:03] 🏥 Health check...
[15:22:04] ✅ qishui: OK
[15:22:04] ✅ netease: OK
[15:22:04] ✅ qq: OK

[15:22:04] ⏭️  [01_Old Dirt Roads_20260507] Already complete, skipping
[15:22:04] 🧠 [02_Bud Light The Way_20260507] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-07T07:22:04.664Z", "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}}
[15:22:04] 🌐 Step 1: target_language=zh (injecting override directive)
  ⚠️ Gemini official 503 on key #1/5, will retry...
  🔄 Retry 1/4 in 3s...
  ⚠️ Gemini official 503 on key #2/5, will retry...
  🔄 Retry 2/4 in 3s...
  ⚠️ Gemini official 503 on key #3/5, will retry...
  🔄 Retry 3/4 in 3s...
  ⚠️ Gemini official 503 on key #4/5, will retry...
  🔄 Retry 4/4 in 3s...
  ⚠️ Gemini official 503 on key #5/5, will retry...
{"__trace__": true, "ts": "2026-05-07T07:22:42.390Z", "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": 8.8, "cost_usd": null, "status": "http_503"}
{"__trace__": true, "ts": "2026-05-07T07:22:42.390Z", "trace_id": "batch-20260507-150822-cd4f4e", "song_key": "02_Bud Light The Way_20260507", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 37.726}
[15:22:42] ❌ [02_Bud Light The Way_20260507] Step 1: http_503 (8.8s)

======================================================================
SUMMARY | 38s (0.6min)
======================================================================
✅ Done: 1 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +0 新增, ~1 更新 | 总计 641 首
[exit 0]

=== 2026-05-07 15:22:42 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e ===
[Feishu] ✅ Exported 1 songs to: https://ccnu62373cgc.feishu.cn/sheets/N0owsh4KKh9b1gtDcGncmVpcnxb
[Feishu] ⏭️  Skip duplicate (complete): Old Dirt Roads (https://fileserver.yuchenhu.com/pipeline/batch-20260507-150822-cd4f4e/01_Old%20Dirt%20Roads_20260507/song_pgc.mp3)
[MasterDB] ✅ 批次 batch-20260507-150822-cd4f4e → +0 新增, ~0 更新 | 总计 582 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/N0owsh4KKh9b
[15:22:50] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [旧茧] topic head sent (message_id=om_x100b50f792678ca0b4caca0fc0e8c1a)
[Feishu IM] ✅ [旧茧] 旧茧_V1_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V1_mixed.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_raw.mp3 replied
[Feishu IM] ✅ [旧茧] 旧茧_V2_mixed.mp3 replied
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260507-150822-cd4f4e
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260507-150822-cd4f4e

📊 https://ccnu62373cgc.feishu.cn/sheets/N0owsh4KKh9b1gtDcGncmVpcnxb
[exit 0]
