
=== 2026-05-13 14:42:28 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3 -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260513-144228-b1d0b3 --target-language zh --step1-only ===
[profile] ✅ Loaded profile '__runtime_batch-20260513-144228-b1d0b3' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-144228-b1d0b3.yaml
[step075] cache hit: song_pgc.mp3 → e1ffb9acea25

======================================================================
music-pipeline3000 v2 | 3 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

[14:42:30] 🏥 Health check...
[14:42:32] ✅ qishui: OK
[14:42:32] ✅ netease: OK
[14:42:32] ✅ qq: OK

[14:42:32] 🔍 [01_我怀念的_20260513] Step 0: Fetching...
[14:42:32] 🔍 [02_给你一瓶魔法药水_20260513] Step 0: Fetching...
[14:42:32] 🔍 [03_编号89757_20260513] Step 0: Fetching...
[14:42:50] ✅ [02_给你一瓶魔法药水_20260513] Step 0: qq | 1206c lyrics
[14:42:50] ⬇️  [02_给你一瓶魔法药水_20260513] Step 0.5: Download from qq...
[14:42:50] ✅ [01_我怀念的_20260513] Step 0: qq | 685c lyrics
[14:42:50] ⬇️  [01_我怀念的_20260513] Step 0.5: Download from qq...
[14:42:51] ✅ [03_编号89757_20260513] Step 0: qq | 624c lyrics
[14:42:51] ⬇️  [03_编号89757_20260513] Step 0.5: Download from qq...
[14:42:58] ✅ [03_编号89757_20260513] Step 0.5: 6027984 bytes | 251.0s
[14:42:58] 🔬 [03_编号89757_20260513] Step 0.75: Audio features...
[14:42:58] ✅ [03_编号89757_20260513] Step 0.75: BPM=163.0 Key=E minor (40.4s)
[14:42:58] 🧠 [03_编号89757_20260513] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-13T06:42:58.044Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "03_编号89757_20260513", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/03_编号89757_20260513/song_pgc.mp3", "has_features": true}}
[step1] cache hit: song_pgc.mp3 → ef9a443d6aaf (saving 1 Gemini call)
[14:42:58] 🌐 Step 1: target_language=zh (injecting override directive)
{"__trace__": true, "ts": "2026-05-13T06:42:58.106Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "03_编号89757_20260513", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 41.9, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-13T06:42:58.106Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "03_编号89757_20260513", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 0.061}
[step075] cache hit: song_pgc.mp3 → 07b34c261db7
[14:42:58] ⚠️  [03_编号89757_20260513] Step 1.5: prompt 1304c > 1000c, compressing...
  📏 [03_编号89757_20260513] prompt 1304c → 918c (smart truncate)
[14:42:58] ✅ [03_编号89757_20260513] Step 1.5: prompt compressed 1304c → 918c
[14:42:58] ✅ [03_编号89757_20260513] Step 1: 41.9s | prompt=918c | prompt_ok=True lyrics_ok=True
[14:42:58] ✅ [02_给你一瓶魔法药水_20260513] Step 0.5: 6272854 bytes | 258.8s
[14:42:58] 🔬 [02_给你一瓶魔法药水_20260513] Step 0.75: Audio features...
[14:42:58] ✅ [02_给你一瓶魔法药水_20260513] Step 0.75: BPM=99.03 Key=E major (31.9s)
[14:42:58] 🧠 [02_给你一瓶魔法药水_20260513] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-13T06:42:58.661Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "02_给你一瓶魔法药水_20260513", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/02_给你一瓶魔法药水_20260513/song_pgc.mp3", "has_features": true}}
[step1] cache hit: song_pgc.mp3 → ea908077ee9b (saving 1 Gemini call)
[14:42:58] 🌐 Step 1: target_language=zh (injecting override directive)
{"__trace__": true, "ts": "2026-05-13T06:42:58.709Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "02_给你一瓶魔法药水_20260513", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 35.0, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-13T06:42:58.709Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "02_给你一瓶魔法药水_20260513", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 0.047}
[step075] cache hit: song_pgc.mp3 → f0fe41baee44
[14:42:58] ⚠️  [02_给你一瓶魔法药水_20260513] Step 1.5: prompt 1049c > 1000c, compressing...
  📏 [02_给你一瓶魔法药水_20260513] prompt 1049c → 927c (smart truncate)
[14:42:58] ✅ [02_给你一瓶魔法药水_20260513] Step 1.5: prompt compressed 1049c → 927c
[14:42:58] ✅ [02_给你一瓶魔法药水_20260513] Step 1: 35.0s | prompt=927c | prompt_ok=True lyrics_ok=True
[14:42:58] ✅ [01_我怀念的_20260513] Step 0.5: 6633378 bytes | 289.1s
[14:42:58] 🔬 [01_我怀念的_20260513] Step 0.75: Audio features...
[14:42:58] ✅ [01_我怀念的_20260513] Step 0.75: BPM=139.69 Key=E major (51.8s)
[14:42:58] 🧠 [01_我怀念的_20260513] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-13T06:42:58.737Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "01_我怀念的_20260513", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/01_我怀念的_20260513/song_pgc.mp3", "has_features": true}}
[step1] cache hit: song_pgc.mp3 → 6136875966de (saving 1 Gemini call)
[14:42:58] 🌐 Step 1: target_language=zh (injecting override directive)
{"__trace__": true, "ts": "2026-05-13T06:42:58.792Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "01_我怀念的_20260513", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 37.0, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-13T06:42:58.793Z", "trace_id": "batch-20260513-144228-b1d0b3", "song_key": "01_我怀念的_20260513", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 0.055}
[14:42:58] ⚠️  [01_我怀念的_20260513] Step 1.5: prompt 1007c > 1000c, compressing...
  📏 [01_我怀念的_20260513] prompt 1007c → 940c (aggressive)
[14:42:58] ✅ [01_我怀念的_20260513] Step 1.5: prompt compressed 1007c → 940c
[14:42:58] ✅ [01_我怀念的_20260513] Step 1: 37.0s | prompt=940c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 27s (0.4min)
======================================================================
✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0
[MasterDB] ✅ 批次 batch-20260513-144228-b1d0b3 → +0 新增, ~0 更新 | 总计 742 首
[exit 0]

=== 2026-05-13 14:42:59 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3 --profile __runtime_batch-20260513-144228-b1d0b3 --resume-mode each --skip-feishu --target-language zh ===
[phase2] batch=batch-20260513-144228-b1d0b3 pending=3 groups=1
[phase2] group 1/1 -> 01_我怀念的_20260513, 02_给你一瓶魔法药水_20260513, 03_编号89757_20260513
[profile] ✅ Loaded profile '__runtime_batch-20260513-144228-b1d0b3' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-144228-b1d0b3.yaml
[phase2] 🌐 01_我怀念的_20260513: target_language=zh
[profile] ✅ Loaded profile '__runtime_batch-20260513-144228-b1d0b3' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-144228-b1d0b3.yaml
[phase2] 🌐 02_给你一瓶魔法药水_20260513: target_language=zh
[profile] ✅ Loaded profile '__runtime_batch-20260513-144228-b1d0b3' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-144228-b1d0b3.yaml
[phase2] 🌐 03_编号89757_20260513: 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-20260513-144228-b1d0b3/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3 --profile __runtime_batch-20260513-144228-b1d0b3 --skip-feishu
[14:42:59] 🌐 [01_我怀念的_20260513] Step 2: target_language=zh → lang_mode=ZH | single-turn
[14:42:59] 🤖 [01_我怀念的_20260513] Step 2 Turn 2: 14977 chars ≈ 3744 tokens → claude-sonnet-4-6
[14:42:59] 🌐 [02_给你一瓶魔法药水_20260513] Step 2: target_language=zh → lang_mode=ZH | single-turn
[14:42:59] 🤖 [02_给你一瓶魔法药水_20260513] Step 2 Turn 2: 14492 chars ≈ 3623 tokens → claude-sonnet-4-6
[14:42:59] 🌐 [03_编号89757_20260513] Step 2: target_language=zh → lang_mode=ZH | single-turn
[14:42:59] 🤖 [03_编号89757_20260513] Step 2 Turn 2: 14728 chars ≈ 3682 tokens → claude-sonnet-4-6
[14:43:30] ⚠️  [01_我怀念的_20260513] Step 2 API: originality 75% < 85% | 0 copied phrases
[14:43:30] 🔄 [01_我怀念的_20260513] Step 2 API: originality retry 1/3...
[14:43:34] ⚠️  [03_编号89757_20260513] Step 2 API: originality 80% < 85% | 0 copied phrases
[14:43:34] 🔄 [03_编号89757_20260513] Step 2 API: originality retry 1/3...
[14:43:42] ⚠️  [02_给你一瓶魔法药水_20260513] Step 2 API: originality 77% < 85% | 0 copied phrases
[14:43:42] 🔄 [02_给你一瓶魔法药水_20260513] Step 2 API: originality retry 1/3...
[14:44:01] ⚠️  [01_我怀念的_20260513] Step 2 API retry 1: originality 75%
[14:44:01] 🔄 [01_我怀念的_20260513] Step 2 API: originality retry 2/3...
[14:44:05] ⚠️  [03_编号89757_20260513] Step 2 API retry 1: originality 82%
[14:44:05] 🔄 [03_编号89757_20260513] Step 2 API: originality retry 2/3...
[14:44:20] ⚠️  [02_给你一瓶魔法药水_20260513] Step 2 API retry 1: originality 82%
[14:44:20] 🔄 [02_给你一瓶魔法药水_20260513] Step 2 API: originality retry 2/3...
[14:44:32] ⚠️  [01_我怀念的_20260513] Step 2 API retry 2: originality 82%
[14:44:32] 🔄 [01_我怀念的_20260513] Step 2 API: originality retry 3/3...
[14:44:38] ⚠️  [03_编号89757_20260513] Step 2 API retry 2: originality 82%
[14:44:38] 🔄 [03_编号89757_20260513] Step 2 API: originality retry 3/3...
[14:45:04] ⚠️  [02_给你一瓶魔法药水_20260513] Step 2 API retry 2: originality 80%
[14:45:04] 🔄 [02_给你一瓶魔法药水_20260513] Step 2 API: originality retry 3/3...
[14:45:05] ⚠️  [01_我怀念的_20260513] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[14:45:05] ⚠️  [01_我怀念的_20260513] Step 2 API: best originality 82% after 3 retries
[14:45:05] ✅ [01_我怀念的_20260513] Step 2 API: 《还欠着》 engine=? | 93.2s | in=40375 out=6290 | ~$0.215
[14:45:28] ⚠️  [03_编号89757_20260513] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[14:45:28] ⚠️  [03_编号89757_20260513] Step 2 API: best originality 82% after 3 retries
[14:45:28] ✅ [03_编号89757_20260513] Step 2 API: 《沸点偏移》 engine=? | 98.8s | in=40682 out=6345 | ~$0.217
[14:45:47] ⚠️  [02_给你一瓶魔法药水_20260513] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[14:45:47] ⚠️  [02_给你一瓶魔法药水_20260513] Step 2 API: best originality 82% after 3 retries
[14:45:47] ✅ [02_给你一瓶魔法药水_20260513] Step 2 API: 《折纸候风》 engine=? | 124.5s | in=40081 out=5896 | ~$0.209
{"timestamp": "2026-05-13T14:42:59.352272+08:00", "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3", "profile": "__runtime_batch-20260513-144228-b1d0b3", "concurrency": 3, "resume_mode": "each", "pending_song_count": 3, "groups": [{"group_index": 1, "songs": ["/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/01_我怀念的_20260513", "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/02_给你一瓶魔法药水_20260513", "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/03_编号89757_20260513"], "success_count": 3, "failed_count": 0, "results": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/01_我怀念的_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/01_我怀念的_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-144228-b1d0b3/01_我怀念的_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/01_我怀念的_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-144228-b1d0b3/02_给你一瓶魔法药水_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/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-144228-b1d0b3/02_给你一瓶魔法药水_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/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-144228-b1d0b3/03_编号89757_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/03_编号89757_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-144228-b1d0b3/03_编号89757_20260513", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3/03_编号89757_20260513/step2_json_b.json", "agent_summary": "API direct: 沸点偏移", "returncode": 0, "stderr": "", "attempt": 1}]}]}], "resume": {"status": "success", "returncode": 0, "stdout_tail": "\n======================================================================\nmusic-pipeline3000 v2 | 3 songs\n======================================================================\nGemini concurrency: 2 | Suno concurrency: 3\nOutput: /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[14:45:49] 🏥 Health check...\n[14:45:50] ✅ qishui: OK\n[14:45:50] ✅ netease: OK\n[14:45:50] ✅ qq: OK\n\n  📝 [01_我怀念的_20260513] lyrics stripped: 2829c → 2824c\n[14:45:50] 🎵 [01_我怀念的_20260513] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[14:45:50] 🎨 [01_我怀念的_20260513] Step 4: SeeDream cover (parallel)...\n  📝 [02_给你一瓶魔法药水_20260513] lyrics stripped: 2125c → 2117c\n[14:45:50] 🎵 [02_给你一瓶魔法药水_20260513] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[14:45:50] 🎨 [02_给你一瓶魔法药水_20260513] Step 4: SeeDream cover (parallel)...\n  📝 [03_编号89757_20260513] lyrics stripped: 2517c → 2510c\n[14:45:50] 🎵 [03_编号89757_20260513] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[14:45:50] 🎨 [03_编号89757_20260513] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['797a671c', '09481a56']\n  🎵 797a671c... → submitted\n  🎵 09481a56... → submitted\n  ✅ submitted: ['7f05d3be', 'f2226f04']\n  🎵 7f05d3be... → submitted\n  🎵 f2226f04... → submitted\n  ✅ submitted: ['3a3e346b', 'a59be45f']\n  🎵 3a3e346b... → submitted\n  🎵 a59be45f... → submitted\n  🎵 797a671c... → queued\n  🎵 09481a56... → queued\n  🎵 7f05d3be... → queued\n  🎵 f2226f04... → queued\n  🎵 3a3e346b... → queued\n  🎵 a59be45f... → queued\n  🎵 797a671c... → streaming\n  🎵 7f05d3be... → streaming\n  🎵 f2226f04... → streaming\n  🎵 3a3e346b... → streaming\n  🎵 a59be45f... → streaming\n  🎵 09481a56... → streaming\n  🎵 7f05d3be... → complete\n  🎵 3a3e346b... → complete\n  🎵 797a671c... → complete\n  🎵 f2226f04... → complete\n[14:49:24]    🎧 [02_给你一瓶魔法药水_20260513] Song 1: https://cdn1.suno.ai/7f05d3be-ada0-4507-b9ea-a7b135339600.mp3\n[14:49:24]    🎧 [02_给你一瓶魔法药水_20260513] Song 2: https://cdn1.suno.ai/f2226f04-4cc0-4067-8881-96bde6289770.mp3\n[14:49:24] 🎛️ [02_给你一瓶魔法药水_20260513] Step 3.5: 混音...\n[14:49:45]    🎚️ [02_给你一瓶魔法药水_20260513] Song 1: pop | 低44/中52/高4%\n[14:50:01]    🎚️ [02_给你一瓶魔法药水_20260513] Song 2: pop | 低48/中48/高4%\n[14:50:01] ✅ [02_给你一瓶魔法药水_20260513] Step 3.5: 36.2s | 2 songs mixed\n[14:50:01] ⚠️  [02_给你一瓶魔法药水_20260513] Step 4: http_403 (non-fatal)\n  🎵 a59be45f... → complete\n[14:50:17]    🎧 [03_编号89757_20260513] Song 1: https://cdn1.suno.ai/3a3e346b-6eb0-4c7b-98dd-605cb8993f50.mp3\n[14:50:17]    🎧 [03_编号89757_20260513] Song 2: https://cdn1.suno.ai/a59be45f-17b9-4525-8885-d80b3423fd34.mp3\n[14:50:17] 🎛️ [03_编号89757_20260513] Step 3.5: 混音...\n[14:50:33]    🎚️ [03_编号89757_20260513] Song 1: edm | 低57/中38/高5%\n[14:50:49]    🎚️ [03_编号89757_20260513] Song 2: edm | 低49/中44/高7%\n[14:50:49] ✅ [03_编号89757_20260513] Step 3.5: 31.4s | 2 songs mixed\n[14:50:49] ⚠️  [03_编号89757_20260513] Step 4: http_403 (non-fatal)\n  🎵 09481a56... → complete\n[14:51:00]    🎧 [01_我怀念的_20260513] Song 1: https://cdn1.suno.ai/797a671c-1658-4ac6-b7f6-517b4faf6f8e.mp3\n[14:51:00]    🎧 [01_我怀念的_20260513] Song 2: https://cdn1.suno.ai/09481a56-7147-4573-9d0a-97b494df5e17.mp3\n[14:51:00] 🎛️ [01_我怀念的_20260513] Step 3.5: 混音...\n[14:51:21]    🎚️ [01_我怀念的_20260513] Song 1: hip_hop | 低52/中44/高4%\n[14:51:40]    🎚️ [01_我怀念的_20260513] Song 2: pop | 低60/中37/高2%\n[14:51:40] ✅ [01_我怀念的_20260513] Step 3.5: 40.1s | 2 songs mixed\n[14:51:40] ⚠️  [01_我怀念的_20260513] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 350s (5.8min)\n======================================================================\n✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260513-144228-b1d0b3 → +3 新增, ~0 更新 | 总计 745 首\n", "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260513-144228-b1d0b3' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260513-144228-b1d0b3.yaml\n", "summary": {"timestamp": "2026-05-13T14:51:40.291099+08:00", "wall_clock": 350.0, "total": 3, "success": 3, "awaiting_step2": 0, "failed": 0}}, "status": "success"}
[exit 0]

=== 2026-05-13 14:51:41 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3 ===
[Feishu] ✅ Exported 3 songs to: https://ccnu62373cgc.feishu.cn/sheets/EO2Msc7Hvh5yIVtgCSHcIaZznWg
[Feishu] 📐 Expanded master sheet from 681 to 784 rows
[Feishu] ✅ Appended 3 new songs to master sheet (rows 682-684)
[MasterDB] ✅ 批次 batch-20260513-144228-b1d0b3 → +3 新增, ~0 更新 | 总计 684 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/EO2Msc7Hvh5y
[14:51:50] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [还欠着] topic head sent (message_id=om_x100b6f75b6a088a8b22b7501d44398b)
[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 IM] ✅ [折纸候风] topic head sent (message_id=om_x100b6f75b7566ca4b328f6a9bb18f4d)
[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 IM] ✅ [沸点偏移] topic head sent (message_id=om_x100b6f75b446c8e8b321867901145cb)
[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-20260513-144228-b1d0b3
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260513-144228-b1d0b3
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260513-144228-b1d0b3

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