
=== 2026-04-19 13:02:49 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5 -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260419-130249-a7b0a5 --step1-only ===
[profile] ✅ Loaded profile '__runtime_batch-20260419-130249-a7b0a5' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260419-130249-a7b0a5.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')
[   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 | 3 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

[13:02:51] 🏥 Health check...
[13:02:52] ✅ qishui: OK
[13:02:52] ✅ netease: OK
[13:02:52] ✅ qq: OK

[13:02:52] 🔍 [01_20 Cigarettes_20260419] Step 0: Fetching...
[13:02:52] 🔍 [02_Be By You_20260419] Step 0: Fetching...
[13:02:52] 🔍 [03_My Way_20260419] Step 0: Fetching...
[13:02:55] ✅ [01_20 Cigarettes_20260419] Step 0: netease | 1256c
[13:02:55] ⬇️  [01_20 Cigarettes_20260419] Step 0.5: Download from netease...
[13:02:55] ✅ [02_Be By You_20260419] Step 0: netease | 1200c
[13:02:55] ⬇️  [02_Be By You_20260419] Step 0.5: Download from netease...
[13:02:55] ✅ [03_My Way_20260419] Step 0: netease | 1499c
[13:02:55] ⬇️  [03_My Way_20260419] Step 0.5: Download from netease...
[13:03:01] ✅ [02_Be By You_20260419] Step 0.5: 3866692 bytes | 197.7s
[13:03:01] 🔬 [02_Be By You_20260419] Step 0.75: Audio features...
[13:03:11] ✅ [01_20 Cigarettes_20260419] Step 0.5: 3118285 bytes | 160.9s
[13:03:11] 🔬 [01_20 Cigarettes_20260419] Step 0.75: Audio features...
[13:03:18] ✅ [03_My Way_20260419] Step 0.5: 4721680 bytes | 243.0s
[13:03:18] 🔬 [03_My Way_20260419] Step 0.75: Audio features...
[13:03:36] ✅ [01_20 Cigarettes_20260419] Step 0.75: BPM=98.03 Key=C# major (24.9s)
[13:03:36] 🧠 [01_20 Cigarettes_20260419] Step 1: Gemini (queuing)...
[13:03:47] ✅ [02_Be By You_20260419] Step 0.75: BPM=93.89 Key=C# major (45.6s)
[13:03:47] 🧠 [02_Be By You_20260419] Step 1: Gemini (queuing)...
[13:04:08] ✅ [03_My Way_20260419] Step 0.75: BPM=128.73 Key=C# major (31.4s)
[13:04:08] 🧠 [03_My Way_20260419] Step 1: Gemini (queuing)...
  📊 Gemini official: 46s | prompt_tokens=8613 completion=1778
[13:04:32] ⚠️  [01_20 Cigarettes_20260419] Step 1.5: prompt 1235c > 1000c, compressing...
  📏 [01_20 Cigarettes_20260419] prompt 1235c → 910c (smart truncate)
[13:04:32] ✅ [01_20 Cigarettes_20260419] Step 1.5: prompt compressed 1235c → 910c
[13:04:32] ✅ [01_20 Cigarettes_20260419] Step 1: 45.6s | prompt=910c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 37s | prompt_tokens=9778 completion=1618
[13:04:45] ⚠️  [02_Be By You_20260419] Step 1.5: prompt 1163c > 1000c, compressing...
  📏 [02_Be By You_20260419] prompt 1163c → 788c (smart truncate)
[13:04:45] ✅ [02_Be By You_20260419] Step 1.5: prompt compressed 1163c → 788c
[13:04:45] ✅ [02_Be By You_20260419] Step 1: 37.2s | prompt=788c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 47s | prompt_tokens=11332 completion=1524
[13:05:19] ⚠️  [03_My Way_20260419] Step 1.5: prompt 1111c > 1000c, compressing...
  📏 [03_My Way_20260419] prompt 1111c → 947c (smart truncate)
[13:05:19] ✅ [03_My Way_20260419] Step 1.5: prompt compressed 1111c → 947c
[13:05:19] ✅ [03_My Way_20260419] Step 1: 46.7s | prompt=947c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 147s (2.5min)
======================================================================
✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0
[MasterDB] ✅ 批次 batch-20260419-130249-a7b0a5 → +0 新增, ~0 更新 | 总计 474 首
[exit 0]

=== 2026-04-19 13:05:20 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5 --profile grammy --resume-mode each --skip-feishu ===
[phase2] batch=batch-20260419-130249-a7b0a5 pending=3 groups=1
[phase2] group 1/1 -> 01_20 Cigarettes_20260419, 02_Be By You_20260419, 03_My Way_20260419
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 01_20 Cigarettes_20260419: target_language=auto
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 02_Be By You_20260419: target_language=auto
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 03_My Way_20260419: target_language=auto
[phase2] resume -> /usr/bin/python3 /srv/repos/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5 --profile grammy --skip-feishu
[13:05:20] 🌐 [01_20 Cigarettes_20260419] Step 2: target_language=auto → lang_mode=EN
[13:05:20] 🤖 [01_20 Cigarettes_20260419] Step 2 API: 29363 chars ≈ 7340 tokens → claude-sonnet-4-6
[13:05:20] 🌐 [02_Be By You_20260419] Step 2: target_language=auto → lang_mode=EN
[13:05:20] 🤖 [02_Be By You_20260419] Step 2 API: 28732 chars ≈ 7183 tokens → claude-sonnet-4-6
[13:05:20] 🌐 [03_My Way_20260419] Step 2: target_language=auto → lang_mode=EN
[13:05:20] 🤖 [03_My Way_20260419] Step 2 API: 28676 chars ≈ 7169 tokens → claude-sonnet-4-6
[13:06:06] ⚠️  [01_20 Cigarettes_20260419] Step 2 API: originality 58% < 85% | 0 copied phrases
[13:06:06] 🔄 [01_20 Cigarettes_20260419] Step 2 API: originality retry 1/3...
[13:06:08] ⚠️  [02_Be By You_20260419] Step 2 API: originality 61% < 85% | 0 copied phrases
[13:06:08] 🔄 [02_Be By You_20260419] Step 2 API: originality retry 1/3...
[13:06:08] ⚠️  [03_My Way_20260419] Step 2 API: originality 57% < 85% | 0 copied phrases
[13:06:08] 🔄 [03_My Way_20260419] Step 2 API: originality retry 1/3...
[13:06:45] ⚠️  [03_My Way_20260419] Step 2 API retry 1: originality 58%
[13:06:45] 🔄 [03_My Way_20260419] Step 2 API: originality retry 2/3...
[13:06:53] ⚠️  [02_Be By You_20260419] Step 2 API retry 1: originality 59%
[13:06:53] 🔄 [02_Be By You_20260419] Step 2 API: originality retry 2/3...
[13:07:02] ⚠️  [01_20 Cigarettes_20260419] Step 2 API retry 1: originality 55%
[13:07:02] 🔄 [01_20 Cigarettes_20260419] Step 2 API: originality retry 2/3...
[13:07:25] ⚠️  [02_Be By You_20260419] Step 2 API retry 2: originality 61%
[13:07:25] 🔄 [02_Be By You_20260419] Step 2 API: originality retry 3/3...
[13:07:41] ⚠️  [03_My Way_20260419] Step 2 API originality retry 2 failed: Expecting value: line 1 column 1 (char 0)
[13:07:41] ⚠️  [03_My Way_20260419] Step 2 API: best originality 58% after 3 retries
[13:07:41] ✅ [03_My Way_20260419] Step 2 API: 《Twice the Quiet》 | 84.7s | in=32621 out=4602 | ~$0.167
[13:08:01] ⚠️  [01_20 Cigarettes_20260419] Step 2 API originality retry 2 failed: Expecting value: line 1 column 1 (char 0)
[13:08:01] ⚠️  [01_20 Cigarettes_20260419] Step 2 API: best originality 58% after 3 retries
[13:08:01] ✅ [01_20 Cigarettes_20260419] Step 2 API: 《Gravel & Grace》 | 101.3s | in=33450 out=5113 | ~$0.177
[13:08:17] ⚠️  [02_Be By You_20260419] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[13:08:17] ⚠️  [02_Be By You_20260419] Step 2 API: best originality 61% after 3 retries
[13:08:17] ✅ [02_Be By You_20260419] Step 2 API: 《Screen Door Summer》 | 125.0s | in=53166 out=6972 | ~$0.264
{"timestamp": "2026-04-19T13:05:20.613878+08:00", "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5", "profile": "grammy", "concurrency": 3, "resume_mode": "each", "pending_song_count": 3, "groups": [{"group_index": 1, "songs": ["/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419", "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419", "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419"], "success_count": 3, "failed_count": 0, "results": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419/step2_json_b.json", "agent_summary": "API direct: Gravel & Grace", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419/step2_json_b.json", "agent_summary": "API direct: Gravel & Grace", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419/step2_json_b.json", "agent_summary": "API direct: Screen Door Summer", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419/step2_json_b.json", "agent_summary": "API direct: Screen Door Summer", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419/step2_json_b.json", "agent_summary": "API direct: Twice the Quiet", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419/step2_json_b.json", "agent_summary": "API direct: Twice the Quiet", "returncode": 0, "stderr": "", "attempt": 1}]}]}], "resume": {"status": "success", "returncode": 0, "stdout_tail": " /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[13:08:19] 🏥 Health check...\n[13:08:22] ✅ qishui: OK\n[13:08:22] ✅ netease: OK\n[13:08:22] ✅ qq: OK\n\n  📝 [01_20 Cigarettes_20260419] lyrics stripped: 5466c → 5000c\n[13:08:22] 🎵 [01_20 Cigarettes_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[13:08:22] 🎨 [01_20 Cigarettes_20260419] Step 4: SeeDream cover (parallel)...\n  📝 [02_Be By You_20260419] lyrics stripped: 4715c → 4708c\n[13:08:22] 🎵 [02_Be By You_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[13:08:22] 🎨 [02_Be By You_20260419] Step 4: SeeDream cover (parallel)...\n  📝 [03_My Way_20260419] lyrics stripped: 4744c → 4738c\n[13:08:22] 🎵 [03_My Way_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[13:08:22] 🎨 [03_My Way_20260419] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['1cad94fb', 'fb93b607']\n  🎵 1cad94fb... → submitted\n  🎵 fb93b607... → submitted\n  ✅ submitted: ['8b49ca58', 'c83a22ac']\n  🎵 8b49ca58... → submitted\n  🎵 c83a22ac... → submitted\n  ✅ submitted: ['76c658bb', 'b73274fb']\n  🎵 76c658bb... → submitted\n  🎵 b73274fb... → submitted\n  🎵 1cad94fb... → queued\n  🎵 fb93b607... → queued\n  🎵 8b49ca58... → queued\n  🎵 c83a22ac... → queued\n  🎵 76c658bb... → queued\n  🎵 b73274fb... → queued\n  🎵 8b49ca58... → streaming\n  🎵 c83a22ac... → streaming\n  🎵 76c658bb... → streaming\n  🎵 b73274fb... → streaming\n  🎵 fb93b607... → streaming\n  🎵 1cad94fb... → streaming\n  🎵 fb93b607... → complete\n  🎵 c83a22ac... → complete\n  🎵 1cad94fb... → complete\n[13:11:26]    🎧 [03_My Way_20260419] Song 1: https://cdn1.suno.ai/1cad94fb-4170-4a57-a975-afa057622e95.mp3\n[13:11:26]    🎧 [03_My Way_20260419] Song 2: https://cdn1.suno.ai/fb93b607-1224-4a68-806a-9b1e8d7f1909.mp3\n[13:11:26] 🎛️ [03_My Way_20260419] Step 3.5: 混音...\n[13:11:54]    🎚️ [03_My Way_20260419] Song 1: edm | 低64/中34/高2%\n  🎵 8b49ca58... → complete\n[13:11:54]    🎧 [01_20 Cigarettes_20260419] Song 1: https://cdn1.suno.ai/8b49ca58-689c-478a-bfe1-952d3cd22ab0.mp3\n[13:11:54]    🎧 [01_20 Cigarettes_20260419] Song 2: https://cdn1.suno.ai/c83a22ac-10db-42d5-9d4c-eca5e9c477df.mp3\n[13:11:54] 🎛️ [01_20 Cigarettes_20260419] Step 3.5: 混音...\n[13:12:20]    🎚️ [03_My Way_20260419] Song 2: edm | 低60/中35/高4%\n[13:12:20] ✅ [03_My Way_20260419] Step 3.5: 53.8s | 2 songs mixed\n[13:12:43]    🎚️ [01_20 Cigarettes_20260419] Song 1: pop | 低39/中54/高7%\n  ⏱  poll timeout, retry...\n[13:12:44] ✅ [03_My Way_20260419] Step 4: 13.7s | /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/03_My Way_20260419/cover_seedream.jpg\n[13:13:07]    🎚️ [01_20 Cigarettes_20260419] Song 2: pop | 低43/中53/高4%\n[13:13:07] ✅ [01_20 Cigarettes_20260419] Step 3.5: 72.3s | 2 songs mixed\n[13:13:08] ✅ [01_20 Cigarettes_20260419] Step 4: 13.4s | /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/01_20 Cigarettes_20260419/cover_seedream.jpg\n  🎵 b73274fb... → complete\n  🎵 76c658bb... → complete\n[13:13:23]    🎧 [02_Be By You_20260419] Song 1: https://cdn1.suno.ai/76c658bb-a778-49f8-b61b-bd13f24ea402.mp3\n[13:13:23]    🎧 [02_Be By You_20260419] Song 2: https://cdn1.suno.ai/b73274fb-e5c2-41eb-a208-037bb1c49276.mp3\n[13:13:23] 🎛️ [02_Be By You_20260419] Step 3.5: 混音...\n[13:14:01]    🎚️ [02_Be By You_20260419] Song 1: pop | 低57/中38/高5%\n[13:14:40]    🎚️ [02_Be By You_20260419] Song 2: pop | 低63/中31/高6%\n[13:14:40] ✅ [02_Be By You_20260419] Step 3.5: 77.6s | 2 songs mixed\n[13:14:43] ✅ [02_Be By You_20260419] Step 4: 15.1s | /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5/02_Be By You_20260419/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 381s (6.4min)\n======================================================================\n✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260419-130249-a7b0a5 → +3 新增, ~0 更新 | 总计 479 首\n", "stderr_tail": "[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml\n", "summary": {"timestamp": "2026-04-19T13:14:43.389693+08:00", "wall_clock": 381.0, "total": 3, "success": 3, "awaiting_step2": 0, "failed": 0}}, "status": "success"}
[exit 0]

=== 2026-04-19 13:14:44 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5 ===
[Feishu] ✅ Exported 3 songs to: https://ccnu62373cgc.feishu.cn/sheets/BmfLs9dLYhaJP4tbnwEcjC5ennb
[Feishu] 📐 Expanded master sheet from 483 to 586 rows
[Feishu] ✅ Appended 3 new songs to master sheet (rows 484-486)
[MasterDB] ✅ 批次 batch-20260419-130249-a7b0a5 → +3 新增, ~0 更新 | 总计 486 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/BmfLs9dLYhaJ
[13:14:52] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [Gravel & Grace] cover sent
[Feishu IM] ✅ [Gravel & Grace] Gravel & Grace_V1_raw.mp3 sent
[Feishu IM] ✅ [Gravel & Grace] Gravel & Grace_V1_mixed.mp3 sent
[Feishu IM] ✅ [Gravel & Grace] Gravel & Grace_V2_raw.mp3 sent
[Feishu IM] ✅ [Gravel & Grace] Gravel & Grace_V2_mixed.mp3 sent
[Feishu IM] ✅ [Screen Door Summer] cover sent
[Feishu IM] ✅ [Screen Door Summer] Screen Door Summer_V1_raw.mp3 sent
[Feishu IM] ✅ [Screen Door Summer] Screen Door Summer_V1_mixed.mp3 sent
[Feishu IM] ✅ [Screen Door Summer] Screen Door Summer_V2_raw.mp3 sent
[Feishu IM] ✅ [Screen Door Summer] Screen Door Summer_V2_mixed.mp3 sent
[Feishu IM] ✅ [Twice the Quiet] cover sent
[Feishu IM] ✅ [Twice the Quiet] Twice the Quiet_V1_raw.mp3 sent
[Feishu IM] ✅ [Twice the Quiet] Twice the Quiet_V1_mixed.mp3 sent
[Feishu IM] ✅ [Twice the Quiet] Twice the Quiet_V2_raw.mp3 sent
[Feishu IM] ✅ [Twice the Quiet] Twice the Quiet_V2_mixed.mp3 sent
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260419-130249-a7b0a5
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260419-130249-a7b0a5

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