
=== 2026-04-22 15:04:36 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80 -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260422-150436-869a80 --step1-only ===
[profile] ✅ Loaded profile '__runtime_batch-20260422-150436-869a80' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260422-150436-869a80.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 | 7 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

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

[15:04:40] 🔍 [01_大鱼_20260422] Step 0: Fetching...
[15:04:40] 🔍 [02_牵丝戏_20260422] Step 0: Fetching...
[15:04:40] 🔍 [03_红昭愿_20260422] Step 0: Fetching...
[15:04:40] 🔍 [04_青花瓷_20260422] Step 0: Fetching...
[15:04:40] 🔍 [05_画心_20260422] Step 0: Fetching...
[15:04:40] 🔍 [06_不染_20260422] Step 0: Fetching...
[15:04:40] 🔍 [07_东风破_20260422] Step 0: Fetching...
[15:04:43] ✅ [02_牵丝戏_20260422] Step 0: netease | 408c
[15:04:43] ⬇️  [02_牵丝戏_20260422] Step 0.5: Download from netease...
[15:04:43] ✅ [03_红昭愿_20260422] Step 0: netease | 547c
[15:04:43] ⬇️  [03_红昭愿_20260422] Step 0.5: Download from netease...
[15:04:44] ✅ [01_大鱼_20260422] Step 0: qishui | 257c
[15:04:44] ⬇️  [01_大鱼_20260422] Step 0.5: Download from qishui...
[15:04:45] ⚠️  [netease] '青花瓷' too short (92s < 120s), likely a cover/clip, skipping
[15:04:45] 🔄 [04_青花瓷_20260422] Step 0: retry 1/2 in 5s...
[15:04:48] ✅ [06_不染_20260422] Step 0: qishui | 416c
[15:04:48] ⬇️  [06_不染_20260422] Step 0.5: Download from qishui...
[15:04:48] ⚠️  [netease] '东风破' too short (44s < 120s), likely a cover/clip, skipping
[15:04:48] 🔄 [07_东风破_20260422] Step 0: retry 1/2 in 5s...
[15:04:49] ⚠️  [01_大鱼_20260422] Step 0.5: Only 60.0s preview (expected 317597s)
[15:04:49] 🔒 [01_大鱼_20260422] Step 0.5: source_id locked, skipping cross-platform fallback
[15:04:49] ❌ [01_大鱼_20260422] Step 0.5: All platforms returned preview (60.0s), skipping song
[15:04:49] ✅ [02_牵丝戏_20260422] Step 0.5: 4726327 bytes | 239.3s
[15:04:49] 🔬 [02_牵丝戏_20260422] Step 0.75: Audio features...
[15:04:50] ✅ [03_红昭愿_20260422] Step 0.5: 3791525 bytes | 173.2s
[15:04:50] 🔬 [03_红昭愿_20260422] Step 0.75: Audio features...
[15:04:50] ⚠️  [06_不染_20260422] Step 0.5: Only 59.4s preview (expected 325895s)
[15:04:50] 🔒 [06_不染_20260422] Step 0.5: source_id locked, skipping cross-platform fallback
[15:04:50] ❌ [06_不染_20260422] Step 0.5: All platforms returned preview (59.4s), skipping song
[15:04:52] ✅ [05_画心_20260422] Step 0: qq | 636c
[15:04:52] ⬇️  [05_画心_20260422] Step 0.5: Download from qq...
[15:04:53] ⚠️  [netease] '青花瓷' too short (92s < 120s), likely a cover/clip, skipping
[15:04:53] 🔄 [04_青花瓷_20260422] Step 0: retry 2/2 in 10s...
[15:05:06] ⚠️  [netease] '东风破' too short (44s < 120s), likely a cover/clip, skipping
[15:05:06] 🔄 [07_东风破_20260422] Step 0: retry 2/2 in 10s...
[15:05:09] ⚠️  [netease] '青花瓷' too short (92s < 120s), likely a cover/clip, skipping
[15:05:09] ❌ [04_青花瓷_20260422] Step 0: No audio URL
[15:05:17] ✅ [05_画心_20260422] Step 0.5: 10246796 bytes | 432.3s
[15:05:17] 🔬 [05_画心_20260422] Step 0.75: Audio features...
[15:05:18] ⚠️  [netease] '东风破' too short (44s < 120s), likely a cover/clip, skipping
[15:05:18] ❌ [07_东风破_20260422] Step 0: No audio URL
[15:05:27] ✅ [03_红昭愿_20260422] Step 0.75: BPM=114.88 Key=E major (37.6s)
[15:05:27] 🧠 [03_红昭愿_20260422] Step 1: Gemini (queuing)...
[15:05:46] ✅ [02_牵丝戏_20260422] Step 0.75: BPM=86.0 Key=D minor (56.7s)
[15:05:46] 🧠 [02_牵丝戏_20260422] Step 1: Gemini (queuing)...
[15:06:12] ✅ [05_画心_20260422] Step 0.75: BPM=139.89 Key=E major (44.3s)
[15:06:12] 🧠 [05_画心_20260422] Step 1: Gemini (queuing)...
  📊 Gemini official: 44s | prompt_tokens=9094 completion=1442
[15:06:30] ⚠️  [03_红昭愿_20260422] Step 1.5: prompt 1278c > 1000c, compressing...
  📏 [03_红昭愿_20260422] prompt 1278c → 907c (smart truncate)
[15:06:30] ✅ [03_红昭愿_20260422] Step 1.5: prompt compressed 1278c → 907c
[15:06:30] ✅ [03_红昭愿_20260422] Step 1: 43.7s | prompt=907c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 45s | prompt_tokens=11098 completion=1423
[15:06:57] ⚠️  [02_牵丝戏_20260422] Step 1.5: prompt 1121c > 1000c, compressing...
  📏 [02_牵丝戏_20260422] prompt 1121c → 916c (smart truncate)
[15:06:57] ✅ [02_牵丝戏_20260422] Step 1.5: prompt compressed 1121c → 916c
[15:06:57] ✅ [02_牵丝戏_20260422] Step 1: 44.9s | prompt=916c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 42s | prompt_tokens=17424 completion=1314
[15:07:12] ⚠️  [05_画心_20260422] Step 1.5: prompt 1150c > 1000c, compressing...
  📏 [05_画心_20260422] prompt 1150c → 860c (smart truncate)
[15:07:12] ✅ [05_画心_20260422] Step 1.5: prompt compressed 1150c → 860c
[15:07:12] ✅ [05_画心_20260422] Step 1: 42.1s | prompt=860c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 152s (2.5min)
======================================================================
✅ Done: 3 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 4
[MasterDB] ✅ 批次 batch-20260422-150436-869a80 → +0 新增, ~0 更新 | 总计 563 首
[exit 0]

=== 2026-04-22 15:07:13 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80 --profile guofeng --resume-mode each --skip-feishu ===
[phase2] batch=batch-20260422-150436-869a80 pending=3 groups=1
[phase2] group 1/1 -> 02_牵丝戏_20260422, 03_红昭愿_20260422, 05_画心_20260422
[profile] ✅ Loaded profile 'guofeng' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/guofeng.yaml
[phase2] 🌐 02_牵丝戏_20260422: target_language=auto
[profile] ✅ Loaded profile 'guofeng' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/guofeng.yaml
[phase2] 🌐 03_红昭愿_20260422: target_language=auto
[profile] ✅ Loaded profile 'guofeng' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/guofeng.yaml
[phase2] 🌐 05_画心_20260422: 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-20260422-150436-869a80/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80 --profile guofeng --skip-feishu
[15:07:13] 🌐 [02_牵丝戏_20260422] Step 2: target_language=auto → lang_mode=AUTO
[15:07:13] 🤖 [02_牵丝戏_20260422] Step 2 API: 10978 chars ≈ 2744 tokens → claude-sonnet-4-6
[15:07:14] 🌐 [03_红昭愿_20260422] Step 2: target_language=auto → lang_mode=AUTO
[15:07:14] 🤖 [03_红昭愿_20260422] Step 2 API: 10839 chars ≈ 2709 tokens → claude-sonnet-4-6
[15:07:14] 🌐 [05_画心_20260422] Step 2: target_language=auto → lang_mode=AUTO
[15:07:14] 🤖 [05_画心_20260422] Step 2 API: 10350 chars ≈ 2587 tokens → claude-sonnet-4-6
[15:07:43] ✅ [03_红昭愿_20260422] Step 2 API: 《烟渡无归处》 | 29.3s | in=7583 out=1981 | ~$0.052
[15:07:51] ⚠️  [02_牵丝戏_20260422] Step 2 API: originality 83% < 85% | 0 copied phrases
[15:07:51] 🔄 [02_牵丝戏_20260422] Step 2 API: originality retry 1/3...
[15:07:59] ⚠️  [05_画心_20260422] Step 2 API: originality 58% < 85% | 9 copied phrases
          ❗ "啦啦啦啦啦啦啦啦啦" ~ "啦啦啦啦啦啦啦啦啦" (100%)
          ❗ "啦啦啦啦啦啦啦啦啦" ~ "啦啦啦啦啦啦啦啦啦" (100%)
          ❗ "啦啦啦啦啦啦" ~ "啦啦啦啦啦啦" (100%)
          ❗ "啦啦啦啦啦啦啦" ~ "啦啦啦啦啦啦啦" (100%)
          ❗ "啦啦啦啦啦啦啦啦啦啦" ~ "啦啦啦啦啦啦啦啦啦啦" (100%)
[15:07:59] 🔄 [05_画心_20260422] Step 2 API: originality retry 1/3...
[15:08:25] ⚠️  [02_牵丝戏_20260422] Step 2 API retry 1: originality 83%
[15:08:25] 🔄 [02_牵丝戏_20260422] Step 2 API: originality retry 2/3...
[15:08:35] ⚠️  [05_画心_20260422] Step 2 API originality retry 1 failed: Expecting value: line 1 column 1 (char 0)
[15:08:35] ⚠️  [05_画心_20260422] Step 2 API: best originality 58% after 3 retries
[15:08:35] ✅ [05_画心_20260422] Step 2 API: 《雁渡寒枝》 | 45.0s | in=7542 out=2261 | ~$0.057
[15:09:00] ⚠️  [02_牵丝戏_20260422] Step 2 API retry 2: originality 81%
[15:09:00] 🔄 [02_牵丝戏_20260422] Step 2 API: originality retry 3/3...
[15:09:40] ⚠️  [02_牵丝戏_20260422] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[15:09:40] ⚠️  [02_牵丝戏_20260422] Step 2 API: best originality 83% after 3 retries
[15:09:40] ✅ [02_牵丝戏_20260422] Step 2 API: 《雁回霜白处》 | 106.6s | in=30452 out=6504 | ~$0.189
{"timestamp": "2026-04-22T15:07:13.748975+08:00", "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80", "profile": "guofeng", "concurrency": 3, "resume_mode": "each", "pending_song_count": 3, "groups": [{"group_index": 1, "songs": ["/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/02_牵丝戏_20260422", "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/03_红昭愿_20260422", "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/05_画心_20260422"], "success_count": 3, "failed_count": 0, "results": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/02_牵丝戏_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/02_牵丝戏_20260422/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-20260422-150436-869a80/02_牵丝戏_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/02_牵丝戏_20260422/step2_json_b.json", "agent_summary": "API direct: 雁回霜白处", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/03_红昭愿_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/03_红昭愿_20260422/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-20260422-150436-869a80/03_红昭愿_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/03_红昭愿_20260422/step2_json_b.json", "agent_summary": "API direct: 烟渡无归处", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/05_画心_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/05_画心_20260422/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-20260422-150436-869a80/05_画心_20260422", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/05_画心_20260422/step2_json_b.json", "agent_summary": "API direct: 雁渡寒枝", "returncode": 0, "stderr": "", "attempt": 1}]}]}], "resume": {"status": "success", "returncode": 0, "stdout_tail": "tep 3: Suno generation (weirdness=50, style_influence=50)...\n[15:12:04] 🎨 [01_大鱼_雁归无处_20260422] Step 4: SeeDream cover (parallel)...\n  🎵 5f4a1d82... → complete\n  🎵 90856fbd... → complete\n[15:13:00]    🎧 [02_牵丝戏_20260422] Song 1: https://cdn1.suno.ai/5f4a1d82-b7e1-4ccf-86bf-d478d28c5abc.mp3\n[15:13:00]    🎧 [02_牵丝戏_20260422] Song 2: https://cdn1.suno.ai/90856fbd-34d4-4371-a398-4a4902cfc192.mp3\n[15:13:00] 🎛️ [02_牵丝戏_20260422] Step 3.5: 混音...\n[15:13:19]    🎚️ [02_牵丝戏_20260422] Song 1: pop | 低35/中62/高3%\n  ✅ submitted: ['42dcc519', 'd3bde3bc']\n  🎵 1770b770... → complete\n  🎵 42dcc519... → streaming\n  🎵 d3bde3bc... → streaming\n[15:13:38]    🎚️ [02_牵丝戏_20260422] Song 2: pop | 低39/中55/高6%\n[15:13:38] ✅ [02_牵丝戏_20260422] Step 3.5: 38.4s | 2 songs mixed\n  🎵 09fe9d1a... → complete\n[15:13:39]    🎧 [03_红昭愿_20260422] Song 1: https://cdn1.suno.ai/09fe9d1a-9a50-4fd7-9c24-1e6558a01753.mp3\n[15:13:39]    🎧 [03_红昭愿_20260422] Song 2: https://cdn1.suno.ai/1770b770-8f63-43fd-b0f3-d50050bf9abd.mp3\n[15:13:39] 🎛️ [03_红昭愿_20260422] Step 3.5: 混音...\n  ✅ submitted: ['e1d6617d', 'fbe35fb4']\n[15:13:58]    🎚️ [03_红昭愿_20260422] Song 1: rock | 低63/中33/高4%\n  🎵 e1d6617d... → submitted\n  🎵 fbe35fb4... → submitted\n[15:13:58] ✅ [02_牵丝戏_20260422] Step 4: 21.4s | /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/02_牵丝戏_20260422/cover_seedream.jpg\n  🎵 2d3ce4f7... → complete\n[15:14:24]    🎚️ [03_红昭愿_20260422] Song 2: rock | 低72/中25/高3%\n[15:14:24] ✅ [03_红昭愿_20260422] Step 3.5: 45.6s | 2 songs mixed\n  🎵 e1d6617d... → streaming\n  🎵 fbe35fb4... → streaming\n  🎵 51a19b7f... → complete\n[15:14:25]    🎧 [05_画心_20260422] Song 1: https://cdn1.suno.ai/2d3ce4f7-4bcb-4966-b2e8-abe10627ab6e.mp3\n[15:14:25]    🎧 [05_画心_20260422] Song 2: https://cdn1.suno.ai/51a19b7f-1e2b-4848-b97d-5db1f9f2499a.mp3\n[15:14:25] 🎛️ [05_画心_20260422] Step 3.5: 混音...\n[15:14:50]    🎚️ [05_画心_20260422] Song 1: hip_hop | 低42/中57/高1%\n[15:14:50] ✅ [03_红昭愿_20260422] Step 4: 16.7s | /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/03_红昭愿_20260422/cover_seedream.jpg\n[15:15:16]    🎚️ [05_画心_20260422] Song 2: hip_hop | 低43/中55/高2%\n[15:15:16] ✅ [05_画心_20260422] Step 3.5: 50.5s | 2 songs mixed\n[15:15:18] ✅ [05_画心_20260422] Step 4: 15.2s | /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/05_画心_20260422/cover_seedream.jpg\n  🎵 d3bde3bc... → complete\n  🎵 42dcc519... → complete\n[15:15:54]    🎧 [06_不染_雁过霜河_20260422] Song 1: https://cdn1.suno.ai/42dcc519-8be2-4582-9e4d-8102837d28cd.mp3\n[15:15:54]    🎧 [06_不染_雁过霜河_20260422] Song 2: https://cdn1.suno.ai/d3bde3bc-d7e5-481d-817f-90f7138254d0.mp3\n[15:15:54] 🎛️ [06_不染_雁过霜河_20260422] Step 3.5: 混音...\n[15:16:12]    🎚️ [06_不染_雁过霜河_20260422] Song 1: pop | 低23/中72/高5%\n  🎵 e1d6617d... → complete\n  🎵 fbe35fb4... → complete\n[15:16:13]    🎧 [01_大鱼_雁归无处_20260422] Song 1: https://cdn1.suno.ai/e1d6617d-8539-4978-a401-312dff11a008.mp3\n[15:16:13]    🎧 [01_大鱼_雁归无处_20260422] Song 2: https://cdn1.suno.ai/fbe35fb4-6d08-4d1e-9cc3-4b75d48bc7ca.mp3\n[15:16:13] 🎛️ [01_大鱼_雁归无处_20260422] Step 3.5: 混音...\n[15:16:31]    🎚️ [06_不染_雁过霜河_20260422] Song 2: edm | 低39/中56/高4%\n[15:16:31] ✅ [06_不染_雁过霜河_20260422] Step 3.5: 37.3s | 2 songs mixed\n[15:16:50]    🎚️ [01_大鱼_雁归无处_20260422] Song 1: pop | 低51/中44/高4%\n[15:16:51] ✅ [06_不染_雁过霜河_20260422] Step 4: 13.6s | /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80/06_不染_雁过霜河_20260422/cover_seedream.jpg\n[15:17:09]    🎚️ [01_大鱼_雁归无处_20260422] Song 2: pop | 低35/中63/高2%\n[15:17:09] ✅ [01_大鱼_雁归无处_20260422] Step 3.5: 56.2s | 2 songs mixed\n[15:17:39] ⚠️  [01_大鱼_雁归无处_20260422] Cover download failed: \n[15:17:39] ✅ [01_大鱼_雁归无处_20260422] Step 4: 15.2s | https://platform.cdn.acedata.cloud/seedream/d229ff2b-6167-4e11-885a-a90342a76b60.jpg\n\n======================================================================\nSUMMARY | 476s (7.9min)\n======================================================================\n✅ Done: 5 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 2\n[MasterDB] ✅ 批次 batch-20260422-150436-869a80 → +5 新增, ~0 更新 | 总计 568 首\n", "stderr_tail": "ated network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n[ WARNING  ] No network created, or last created network has been deleted...\n/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\n  return linkage(y, method='ward', metric='euclidean')\n/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\n  return linkage(y, method='ward', metric='euclidean')\n", "summary": {"timestamp": "2026-04-22T15:17:39.518755+08:00", "wall_clock": 475.9, "total": 7, "success": 5, "awaiting_step2": 0, "failed": 2}}, "status": "success"}
[exit 0]

=== 2026-04-22 15:17: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-20260422-150436-869a80 ===
[Feishu] ✅ Exported 5 songs to: https://ccnu62373cgc.feishu.cn/sheets/Ue3nssZbShERFgtMzNgc5M0gnkf
[Feishu] 📐 Expanded master sheet from 504 to 609 rows
[Feishu] ✅ Appended 5 new songs to master sheet (rows 505-509)
[MasterDB] ✅ 批次 batch-20260422-150436-869a80 → +5 新增, ~0 更新 | 总计 509 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/Ue3nssZbShER
[15:17:49] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [雁归无处] topic head sent (message_id=om_x100b51b32f12889cb3f05e9eb203717)
[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_x100b51b32c04c480b220760f905d20e)
[Feishu IM] ✅ [雁回霜白处] cover replied
[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_x100b51b32d358514b104a2cb5e537cb)
[Feishu IM] ✅ [烟渡无归处] cover replied
[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_x100b51b32bfe0ca8b39224a5142c78e)
[Feishu IM] ✅ [雁渡寒枝] cover replied
[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_x100b51b32897207cb1081bdf204e946)
[Feishu IM] ✅ [雁过霜河] cover replied
[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-20260422-150436-869a80
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260422-150436-869a80
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260422-150436-869a80

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