
=== 2026-04-25 23:26:09 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260425-232609-19a08d --step1-only ===
[profile] ✅ Loaded profile '__runtime_batch-20260425-232609-19a08d' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260425-232609-19a08d.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   ] On connection Flux::flux → IIR::signal:
[   INFO   ] BUFFER SIZE MISMATCH: max=0 - asked for read size 4096
[   INFO   ] resizing buffer to 36040/4505
/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
/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
/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
/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')
[   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')
[   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 | 10 songs
======================================================================
Gemini concurrency: 2 | Suno concurrency: 2
Output: /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

[23:26:11] 🏥 Health check...
[23:26:12] ✅ qishui: OK
[23:26:12] ✅ netease: OK
[23:26:12] ✅ qq: OK

[23:26:13] 🔍 [01_Brown Sugar_20260425] Step 0: Fetching...
[23:26:13] 🔍 [02_On & On_20260425] Step 0: Fetching...
[23:26:13] 🔍 [03_Ascension (Don't Ever Wonder)_20260425] Step 0: Fetching...
[23:26:13] 🔍 [04_Doo Wop (That Thing)_20260425] Step 0: Fetching...
[23:26:13] 🔍 [05_A Long Walk_20260425] Step 0: Fetching...
[23:26:13] 🔍 [06_Video_20260425] Step 0: Fetching...
[23:26:13] 🔍 [07_Just Friends (Sunny)_20260425] Step 0: Fetching...
[23:26:13] 🔍 [08_Fallin'_20260425] Step 0: Fetching...
[23:26:13] 🔍 [09_Soul Sista_20260425] Step 0: Fetching...
[23:26:13] 🔍 [10_Still Ray_20260425] Step 0: Fetching...
[23:26:16] 🔄 [01_Brown Sugar_20260425] Step 0: retry 1/2 in 5s...
[23:26:16] ✅ [02_On & On_20260425] Step 0: netease | 1687c
[23:26:16] ⬇️  [02_On & On_20260425] Step 0.5: Download from netease...
[23:26:16] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 0: netease | 1295c
[23:26:16] ⬇️  [03_Ascension (Don't Ever Wonder)_20260425] Step 0.5: Download from netease...
[23:26:19] ✅ [05_A Long Walk_20260425] Step 0: netease | 2216c
[23:26:19] ⬇️  [05_A Long Walk_20260425] Step 0.5: Download from netease...
[23:26:19] ✅ [04_Doo Wop (That Thing)_20260425] Step 0: netease | 2981c
[23:26:19] ⬇️  [04_Doo Wop (That Thing)_20260425] Step 0.5: Download from netease...
[23:26:19] ✅ [06_Video_20260425] Step 0: netease | 811c
[23:26:19] ⬇️  [06_Video_20260425] Step 0.5: Download from netease...
[23:26:21] ✅ [07_Just Friends (Sunny)_20260425] Step 0: netease | 1908c
[23:26:21] ⬇️  [07_Just Friends (Sunny)_20260425] Step 0.5: Download from netease...
[23:26:22] ✅ [09_Soul Sista_20260425] Step 0: netease | 1033c
[23:26:22] ⬇️  [09_Soul Sista_20260425] Step 0.5: Download from netease...
[23:26:22] ✅ [08_Fallin'_20260425] Step 0: netease | 887c
[23:26:22] ⬇️  [08_Fallin'_20260425] Step 0.5: Download from netease...
[23:26:23] ✅ [02_On & On_20260425] Step 0.5: 4338638 bytes | 226.2s
[23:26:23] 🔬 [02_On & On_20260425] Step 0.75: Audio features...
[23:26:23] 🔄 [01_Brown Sugar_20260425] Step 0: retry 2/2 in 10s...
[23:26:24] ✅ [10_Still Ray_20260425] Step 0: netease | 851c
[23:26:24] ⬇️  [10_Still Ray_20260425] Step 0.5: Download from netease...
[23:26:26] ✅ [06_Video_20260425] Step 0.5: 4889933 bytes | 251.4s
[23:26:26] 🔬 [06_Video_20260425] Step 0.75: Audio features...
[23:26:43] ✅ [04_Doo Wop (That Thing)_20260425] Step 0.5: 5669740 bytes | 320.4s
[23:26:43] 🔬 [04_Doo Wop (That Thing)_20260425] Step 0.75: Audio features...
[23:26:44] ✅ [08_Fallin'_20260425] Step 0.5: 4150006 bytes | 210.3s
[23:26:44] 🔬 [08_Fallin'_20260425] Step 0.75: Audio features...
[23:26:44] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 0.5: 7226154 bytes | 346.1s
[23:26:44] 🔬 [03_Ascension (Don't Ever Wonder)_20260425] Step 0.75: Audio features...
[23:26:44] ✅ [07_Just Friends (Sunny)_20260425] Step 0.5: 4981685 bytes | 251.5s
[23:26:44] 🔬 [07_Just Friends (Sunny)_20260425] Step 0.75: Audio features...
[23:26:44] ✅ [05_A Long Walk_20260425] Step 0.5: 5554758 bytes | 281.0s
[23:26:44] 🔬 [05_A Long Walk_20260425] Step 0.75: Audio features...
[23:26:44] ✅ [09_Soul Sista_20260425] Step 0.5: 6026774 bytes | 318.7s
[23:26:44] 🔬 [09_Soul Sista_20260425] Step 0.75: Audio features...
[23:26:45] ❌ [01_Brown Sugar_20260425] Step 0: No audio URL
[23:26:48] ✅ [10_Still Ray_20260425] Step 0.5: 3503030 bytes | 183.3s
[23:26:48] 🔬 [10_Still Ray_20260425] Step 0.75: Audio features...
[23:27:06] ✅ [02_On & On_20260425] Step 0.75: BPM=80.31 Key=E minor (43.0s)
[23:27:06] 🧠 [02_On & On_20260425] Step 1: Gemini (queuing)...
[23:27:19] ✅ [06_Video_20260425] Step 0.75: BPM=84.99 Key=A minor (53.3s)
[23:27:19] 🧠 [06_Video_20260425] Step 1: Gemini (queuing)...
[23:27:48] ✅ [04_Doo Wop (That Thing)_20260425] Step 0.75: BPM=99.96 Key=D minor (42.5s)
[23:27:48] 🧠 [04_Doo Wop (That Thing)_20260425] Step 1: Gemini (queuing)...
[23:28:02] ✅ [08_Fallin'_20260425] Step 0.75: BPM=95.95 Key=E minor (42.8s)
[23:28:02] 🧠 [08_Fallin'_20260425] Step 1: Gemini (queuing)...
[23:28:33] ✅ [07_Just Friends (Sunny)_20260425] Step 0.75: BPM=95.02 Key=G major (31.4s)
[23:28:33] 🧠 [07_Just Friends (Sunny)_20260425] Step 1: Gemini (queuing)...
[23:28:51] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 0.75: BPM=96.08 Key=A minor (63.1s)
[23:28:51] 🧠 [03_Ascension (Don't Ever Wonder)_20260425] Step 1: Gemini (queuing)...
[23:29:27] ✅ [09_Soul Sista_20260425] Step 0.75: BPM=145.89 Key=G# minor (35.2s)
[23:29:27] 🧠 [09_Soul Sista_20260425] Step 1: Gemini (queuing)...
[23:29:37] ✅ [05_A Long Walk_20260425] Step 0.75: BPM=152.11 Key=B minor (63.5s)
[23:29:37] 🧠 [05_A Long Walk_20260425] Step 1: Gemini (queuing)...
[23:29:46] ✅ [10_Still Ray_20260425] Step 0.75: BPM=83.77 Key=F minor (19.4s)
[23:29:46] 🧠 [10_Still Ray_20260425] Step 1: Gemini (queuing)...
  📊 Gemini official: 42s | prompt_tokens=10810 completion=1442
[23:30:19] ⚠️  [02_On & On_20260425] Step 1.5: prompt 1333c > 1000c, compressing...
  📏 [02_On & On_20260425] prompt 1333c → 970c (smart truncate)
[23:30:19] ✅ [02_On & On_20260425] Step 1.5: prompt compressed 1333c → 970c
[23:30:19] ✅ [02_On & On_20260425] Step 1: 42.5s | prompt=970c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 41s | prompt_tokens=11372 completion=1480
[23:30:27] ⚠️  [06_Video_20260425] Step 1.5: prompt 1233c > 1000c, compressing...
  📏 [06_Video_20260425] prompt 1233c → 919c (smart truncate)
[23:30:27] ✅ [06_Video_20260425] Step 1.5: prompt compressed 1233c → 919c
[23:30:27] ✅ [06_Video_20260425] Step 1: 41.0s | prompt=919c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 51s | prompt_tokens=14117 completion=2045
[23:31:11] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 1.5: prompt 1002c > 1000c, compressing...
  📏 [04_Doo Wop (That Thing)_20260425] prompt 1002c → 983c (smart truncate)
[23:31:11] ✅ [04_Doo Wop (That Thing)_20260425] Step 1.5: prompt compressed 1002c → 983c
[23:31:11] ✅ [04_Doo Wop (That Thing)_20260425] Step 1: 51.2s | prompt=983c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 43s | prompt_tokens=10087 completion=1507
[23:31:11] ⚠️  [08_Fallin'_20260425] Step 1.5: prompt 1180c > 1000c, compressing...
  📏 [08_Fallin'_20260425] prompt 1180c → 980c (smart truncate)
[23:31:11] ✅ [08_Fallin'_20260425] Step 1.5: prompt compressed 1180c → 980c
[23:31:11] ✅ [08_Fallin'_20260425] Step 1: 43.4s | prompt=980c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 37s | prompt_tokens=14589 completion=1475
[23:31:48] ⚠️  [03_Ascension (Don't Ever Wonder)_20260425] Step 1.5: prompt 1363c > 1000c, compressing...
  📏 [03_Ascension (Don't Ever Wonder)_20260425] prompt 1363c → 843c (smart truncate)
[23:31:48] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 1.5: prompt compressed 1363c → 843c
[23:31:48] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 1: 36.9s | prompt=843c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 39s | prompt_tokens=11693 completion=1634
[23:31:49] ⚠️  [07_Just Friends (Sunny)_20260425] Step 1.5: prompt 1253c > 1000c, compressing...
  📏 [07_Just Friends (Sunny)_20260425] prompt 1253c → 885c (smart truncate)
[23:31:49] ✅ [07_Just Friends (Sunny)_20260425] Step 1.5: prompt compressed 1253c → 885c
[23:31:49] ✅ [07_Just Friends (Sunny)_20260425] Step 1: 38.6s | prompt=885c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 43s | prompt_tokens=13638 completion=1681
[23:32:31] ⚠️  [09_Soul Sista_20260425] Step 1.5: prompt 1052c > 1000c, compressing...
  📏 [09_Soul Sista_20260425] prompt 1052c → 954c (smart truncate)
[23:32:31] ✅ [09_Soul Sista_20260425] Step 1.5: prompt compressed 1052c → 954c
[23:32:31] ✅ [09_Soul Sista_20260425] Step 1: 43.2s | prompt=954c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 54s | prompt_tokens=12646 completion=1848
[23:32:43] ⚠️  [05_A Long Walk_20260425] Step 1.5: prompt 1361c > 1000c, compressing...
  📏 [05_A Long Walk_20260425] prompt 1361c → 871c (smart truncate)
[23:32:43] ✅ [05_A Long Walk_20260425] Step 1.5: prompt compressed 1361c → 871c
[23:32:43] ✅ [05_A Long Walk_20260425] Step 1: 53.7s | prompt=871c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 36s | prompt_tokens=9231 completion=1354
[23:33:07] ⚠️  [10_Still Ray_20260425] Step 1.5: prompt 1303c > 1000c, compressing...
  📏 [10_Still Ray_20260425] prompt 1303c → 978c (smart truncate)
[23:33:07] ✅ [10_Still Ray_20260425] Step 1.5: prompt compressed 1303c → 978c
[23:33:07] ✅ [10_Still Ray_20260425] Step 1: 35.8s | prompt=978c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 414s (6.9min)
======================================================================
✅ Done: 9 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1
[MasterDB] ✅ 批次 batch-20260425-232609-19a08d → +0 新增, ~0 更新 | 总计 594 首
[exit 0]

=== 2026-04-25 23:33:08 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d --profile grammy --resume-mode each --skip-feishu ===
[phase2] batch=batch-20260425-232609-19a08d pending=9 groups=3
[phase2] group 1/3 -> 02_On & On_20260425, 03_Ascension (Don't Ever Wonder)_20260425, 04_Doo Wop (That Thing)_20260425
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 02_On & On_20260425: target_language=auto
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 03_Ascension (Don't Ever Wonder)_20260425: target_language=auto
[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml
[phase2] 🌐 04_Doo Wop (That Thing)_20260425: 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-20260425-232609-19a08d/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d --profile grammy --skip-feishu
[phase2] group 2/3 -> all songs already handled, skipping
[phase2] group 3/3 -> all songs already handled, skipping
[23:33:08] 🌐 [02_On & On_20260425] Step 2: target_language=auto → lang_mode=EN
[23:33:08] 🤖 [02_On & On_20260425] Step 2 API: 31355 chars ≈ 7838 tokens → claude-sonnet-4-6
[23:33:08] 🌐 [03_Ascension (Don't Ever Wonder)_20260425] Step 2: target_language=auto → lang_mode=EN
[23:33:08] 🤖 [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API: 30952 chars ≈ 7738 tokens → claude-sonnet-4-6
[23:33:08] 🌐 [04_Doo Wop (That Thing)_20260425] Step 2: target_language=auto → lang_mode=EN
[23:33:08] 🤖 [04_Doo Wop (That Thing)_20260425] Step 2 API: 33538 chars ≈ 8384 tokens → claude-sonnet-4-6
[23:33:39] ⚠️  [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API: originality 48% < 85% | 5 copied phrases
          ❗ "over Dm9; repeats with slight variation.)" ~ "over Dm9; repeats with slight variation.)" (100%)
          ❗ "over the Dm9 chord on 'realize', creating sweet tension before resolving down to the G of the G13 chord.)" ~ "over the Dm9 chord on 'realize', creating sweet tension before resolving down to the G of the G13 chord.)" (100%)
          ❗ "over the G13, building anticipation for the final chorus.)" ~ "over the G13, building anticipation for the final chorus.)" (100%)
          ❗ "over Dm9; repeats with slight variation.)" ~ "over Dm9; repeats with slight variation.)" (100%)
          ❗ "over the Dm9 chord on 'realize', creating sweet tension before resolving down to the G of the G13 chord.)" ~ "over the Dm9 chord on 'realize', creating sweet tension before resolving down to the G of the G13 chord.)" (100%)
[23:33:39] 🔄 [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API: originality retry 1/3...
[23:33:39] ⚠️  [02_On & On_20260425] Step 2 API: originality 56% < 85% | 2 copied phrases
          ❗ "are whispered and panned hard right.)" ~ "are whispered and panned hard right.)" (100%)
          ❗ "Hold on..." ~ "And on..." (74%)
[23:33:39] 🔄 [02_On & On_20260425] Step 2 API: originality retry 1/3...
[23:34:06] ⚠️  [02_On & On_20260425] Step 2 API retry 1: originality 60%
[23:34:06] 🔄 [02_On & On_20260425] Step 2 API: originality retry 2/3...
[23:34:12] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 2 API: originality 56% < 85% | 0 copied phrases
[23:34:12] 🔄 [04_Doo Wop (That Thing)_20260425] Step 2 API: originality retry 1/3...
[23:34:19] ⚠️  [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API originality retry 1 failed: Expecting value: line 1 column 1 (char 0)
[23:34:19] ⚠️  [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API: best originality 48% after 3 retries
[23:34:19] ✅ [03_Ascension (Don't Ever Wonder)_20260425] Step 2 API: 《Slow Reveal》 | 30.7s | in=16347 out=2227 | ~$0.082
[23:34:52] ⚠️  [02_On & On_20260425] Step 2 API originality retry 2 failed: Expecting value: line 1 column 1 (char 0)
[23:34:52] ⚠️  [02_On & On_20260425] Step 2 API: best originality 60% after 3 retries
[23:34:52] ✅ [02_On & On_20260425] Step 2 API: 《Warm Enough》 | 58.1s | in=35408 out=4382 | ~$0.172
[23:35:17] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 2 API retry 1: originality 57%
[23:35:17] 🔄 [04_Doo Wop (That Thing)_20260425] Step 2 API: originality retry 2/3...
[23:36:26] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 2 API retry 2: originality 57%
[23:36:26] 🔄 [04_Doo Wop (That Thing)_20260425] Step 2 API: originality retry 3/3...
[23:37:38] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)
[23:37:38] ⚠️  [04_Doo Wop (That Thing)_20260425] Step 2 API: best originality 57% after 3 retries
[23:37:38] ✅ [04_Doo Wop (That Thing)_20260425] Step 2 API: 《Soft Erosion》 | 197.3s | in=61587 out=9253 | ~$0.324
{"timestamp": "2026-04-25T23:33:08.251550+08:00", "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d", "profile": "grammy", "concurrency": 3, "resume_mode": "each", "pending_song_count": 9, "groups": [{"group_index": 1, "songs": ["/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/02_On & On_20260425", "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/03_Ascension (Don't Ever Wonder)_20260425", "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425"], "success_count": 3, "failed_count": 0, "results": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/02_On & On_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/02_On & On_20260425/step2_json_b.json", "agent_summary": "API direct: Warm Enough", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/02_On & On_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/02_On & On_20260425/step2_json_b.json", "agent_summary": "API direct: Warm Enough", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/03_Ascension (Don't Ever Wonder)_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/03_Ascension (Don't Ever Wonder)_20260425/step2_json_b.json", "agent_summary": "API direct: Slow Reveal", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/03_Ascension (Don't Ever Wonder)_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/03_Ascension (Don't Ever Wonder)_20260425/step2_json_b.json", "agent_summary": "API direct: Slow Reveal", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425/step2_json_b.json", "agent_summary": "API direct: Soft Erosion", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425/step2_json_b.json", "agent_summary": "API direct: Soft Erosion", "returncode": 0, "stderr": "", "attempt": 1}]}]}], "resume": {"status": "success", "returncode": 0, "stdout_tail": " [05_A Long Walk_Still_Gray_Sweater_20260425] Song 2: edm | 低76/中22/高2%\n[23:43:44] ✅ [05_A Long Walk_Still_Gray_Sweater_20260425] Step 3.5: 42.1s | 2 songs mixed\n  🎵 2672478d... → complete\n[23:43:45]    🎧 [04_Doo Wop (That Thing)_20260425] Song 1: https://cdn1.suno.ai/2672478d-dde6-45ab-aa4f-8a31c2e7190a.mp3\n[23:43:45]    🎧 [04_Doo Wop (That Thing)_20260425] Song 2: https://cdn1.suno.ai/0a1ce4b6-6954-45b1-a677-101a18fd9527.mp3\n[23:43:45] 🎛️ [04_Doo Wop (That Thing)_20260425] Step 3.5: 混音...\n[23:43:46] ✅ [05_A Long Walk_Still_Gray_Sweater_20260425] Step 4: 12.4s | /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/05_A Long Walk_Still_Gray_Sweater_20260425/cover_seedream.jpg\n[23:44:29]    🎚️ [04_Doo Wop (That Thing)_20260425] Song 1: pop | 低81/中17/高2%\n  ✅ submitted: ['2cd79a7e', '4bc6b63d']\n  🎵 2cd79a7e... → streaming\n  🎵 4bc6b63d... → streaming\n[23:44:54]    🎚️ [04_Doo Wop (That Thing)_20260425] Song 2: pop | 低61/中34/高5%\n[23:44:54] ✅ [04_Doo Wop (That Thing)_20260425] Step 3.5: 69.5s | 2 songs mixed\n  🎵 3e261d41... → complete\n[23:44:55]    🎧 [08_Fallin'_Salt_&_Smoke_20260425] Song 1: https://cdn1.suno.ai/eda961c3-a391-43f5-ba24-922c8eb1c934.mp3\n[23:44:55]    🎧 [08_Fallin'_Salt_&_Smoke_20260425] Song 2: https://cdn1.suno.ai/3e261d41-b476-4b20-855e-9882478294fc.mp3\n[23:44:55] 🎛️ [08_Fallin'_Salt_&_Smoke_20260425] Step 3.5: 混音...\n[23:45:14]    🎚️ [08_Fallin'_Salt_&_Smoke_20260425] Song 1: pop | 低51/中45/高4%\n[23:45:14] ✅ [04_Doo Wop (That Thing)_20260425] Step 4: 15.4s | /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/04_Doo Wop (That Thing)_20260425/cover_seedream.jpg\n[23:46:04]    🎚️ [08_Fallin'_Salt_&_Smoke_20260425] Song 2: hip_hop | 低64/中34/高2%\n[23:46:04] ✅ [08_Fallin'_Salt_&_Smoke_20260425] Step 3.5: 68.7s | 2 songs mixed\n  🎵 3fb8849a... → complete\n[23:46:06] ✅ [08_Fallin'_Salt_&_Smoke_20260425] Step 4: 14.7s | /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/08_Fallin'_Salt_&_Smoke_20260425/cover_seedream.jpg\n  🎵 04aec9bf... → complete\n[23:46:37]    🎧 [09_Soul Sista_Slow_Dissolve_20260425] Song 1: https://cdn1.suno.ai/3fb8849a-0c84-4001-8ac7-828670760f1e.mp3\n[23:46:37]    🎧 [09_Soul Sista_Slow_Dissolve_20260425] Song 2: https://cdn1.suno.ai/04aec9bf-cbf2-4893-9c82-65bca4fb0df3.mp3\n[23:46:37] 🎛️ [09_Soul Sista_Slow_Dissolve_20260425] Step 3.5: 混音...\n[23:47:02]    🎚️ [09_Soul Sista_Slow_Dissolve_20260425] Song 1: pop | 低67/中29/高4%\n[23:47:27]    🎚️ [09_Soul Sista_Slow_Dissolve_20260425] Song 2: edm | 低75/中22/高3%\n[23:47:27] ✅ [09_Soul Sista_Slow_Dissolve_20260425] Step 3.5: 50.1s | 2 songs mixed\n  ⏱  poll timeout, retry...\n[23:47:30] ✅ [09_Soul Sista_Slow_Dissolve_20260425] Step 4: 25.7s | /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/09_Soul Sista_Slow_Dissolve_20260425/cover_seedream.jpg\n  🎵 4bc6b63d... → complete\n  🎵 2cd79a7e... → complete\n[23:48:11]    🎧 [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Song 1: https://cdn1.suno.ai/2cd79a7e-e945-4f76-b562-38fd4b239e0b.mp3\n[23:48:11]    🎧 [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Song 2: https://cdn1.suno.ai/4bc6b63d-3cb7-4d1b-8805-2707898b7818.mp3\n[23:48:11] 🎛️ [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Step 3.5: 混音...\n[23:48:56]    🎚️ [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Song 1: pop | 低75/中22/高3%\n[23:49:20]    🎚️ [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Song 2: jazz | 低72/中26/高2%\n[23:49:20] ✅ [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Step 3.5: 68.2s | 2 songs mixed\n[23:49:23] ✅ [07_Just Friends (Sunny)_Slow_Dissolve_20260425] Step 4: 25.6s | /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d/07_Just Friends (Sunny)_Slow_Dissolve_20260425/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 701s (11.7min)\n======================================================================\n✅ Done: 7 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1\n[MasterDB] ✅ 批次 batch-20260425-232609-19a08d → +7 新增, ~0 更新 | 总计 601 首\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-25T23:49:23.055326+08:00", "wall_clock": 701.1, "total": 10, "success": 7, "awaiting_step2": 0, "failed": 1}}, "status": "success"}
[exit 0]

=== 2026-04-25 23:49:25 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d ===
[Feishu] ✅ Exported 7 songs to: https://ccnu62373cgc.feishu.cn/sheets/CuDysHaaXhxHFktVZOMcPPsAncd
[Feishu] 📐 Expanded master sheet from 537 to 644 rows
[Feishu] ✅ Appended 7 new songs to master sheet (rows 538-544)
[MasterDB] ✅ 批次 batch-20260425-232609-19a08d → +7 新增, ~0 更新 | 总计 544 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/CuDysHaaXhxH
[23:49:34] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [Warm Enough] topic head sent (message_id=om_x100b51fa6620a8a0b258511ab1de4e1)
[Feishu IM] ✅ [Warm Enough] cover replied
[Feishu IM] ✅ [Warm Enough] Warm Enough_V1_raw.mp3 replied
[Feishu IM] ✅ [Warm Enough] Warm Enough_V1_mixed.mp3 replied
[Feishu IM] ✅ [Warm Enough] Warm Enough_V2_raw.mp3 replied
[Feishu IM] ✅ [Warm Enough] Warm Enough_V2_mixed.mp3 replied
[Feishu IM] ✅ [Slow Reveal] topic head sent (message_id=om_x100b51fa670908a0b48cfdf5ae41a6c)
[Feishu IM] ✅ [Slow Reveal] cover replied
[Feishu IM] ✅ [Slow Reveal] Slow Reveal_V1_raw.mp3 replied
[Feishu IM] ✅ [Slow Reveal] Slow Reveal_V1_mixed.mp3 replied
[Feishu IM] ✅ [Slow Reveal] Slow Reveal_V2_raw.mp3 replied
[Feishu IM] ✅ [Slow Reveal] Slow Reveal_V2_mixed.mp3 replied
[Feishu IM] ✅ [Soft Erosion] topic head sent (message_id=om_x100b51fa643de0a0b29e365375c3f92)
[Feishu IM] ✅ [Soft Erosion] cover replied
[Feishu IM] ✅ [Soft Erosion] Soft Erosion_V1_raw.mp3 replied
[Feishu IM] ✅ [Soft Erosion] Soft Erosion_V1_mixed.mp3 replied
[Feishu IM] ✅ [Soft Erosion] Soft Erosion_V2_raw.mp3 replied
[Feishu IM] ✅ [Soft Erosion] Soft Erosion_V2_mixed.mp3 replied
[Feishu IM] ✅ [Still Gray Sweater] topic head sent (message_id=om_x100b51fa62db50a4b343d4b807533da)
[Feishu IM] ✅ [Still Gray Sweater] cover replied
[Feishu IM] ✅ [Still Gray Sweater] Still Gray Sweater_V1_raw.mp3 replied
[Feishu IM] ✅ [Still Gray Sweater] Still Gray Sweater_V1_mixed.mp3 replied
[Feishu IM] ✅ [Still Gray Sweater] Still Gray Sweater_V2_raw.mp3 replied
[Feishu IM] ✅ [Still Gray Sweater] Still Gray Sweater_V2_mixed.mp3 replied
[Feishu IM] ✅ [Slow Burn Season] topic head sent (message_id=om_x100b51fa63e6aca0b1067484ec317c9)
[Feishu IM] ⚠️  [Slow Burn Season] Slow Burn Season_V1_raw.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Burn Season] Slow Burn Season_V1_mixed.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Burn Season] Slow Burn Season_V2_raw.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Burn Season] Slow Burn Season_V2_mixed.mp3 not found, skipping
[Feishu IM] ✅ [Slow Dissolve] topic head sent (message_id=om_x100b51fa63f8b4b4b32c51d4e97c5d7)
[Feishu IM] ✅ [Slow Dissolve] cover replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V1_raw.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V1_mixed.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V2_raw.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V2_mixed.mp3 replied
[Feishu IM] ✅ [Salt & Smoke] topic head sent (message_id=om_x100b51fa60bd84a8b20ec4a2264c318)
[Feishu IM] ✅ [Salt & Smoke] cover replied
[Feishu IM] ✅ [Salt & Smoke] Salt & Smoke_V1_raw.mp3 replied
[Feishu IM] ✅ [Salt & Smoke] Salt & Smoke_V1_mixed.mp3 replied
[Feishu IM] ✅ [Salt & Smoke] Salt & Smoke_V2_raw.mp3 replied
[Feishu IM] ✅ [Salt & Smoke] Salt & Smoke_V2_mixed.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] topic head sent (message_id=om_x100b51fa615d6ca8b37aab0d83ad303)
[Feishu IM] ✅ [Slow Dissolve] cover replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V1_raw.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V1_mixed.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V2_raw.mp3 replied
[Feishu IM] ✅ [Slow Dissolve] Slow Dissolve_V2_mixed.mp3 replied
[Feishu IM] ✅ [Slow Unraveling] topic head sent (message_id=om_x100b51fa7e0930a0b27254d4c12be6e)
[Feishu IM] ⚠️  [Slow Unraveling] Slow Unraveling_V1_raw.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Unraveling] Slow Unraveling_V1_mixed.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Unraveling] Slow Unraveling_V2_raw.mp3 not found, skipping
[Feishu IM] ⚠️  [Slow Unraveling] Slow Unraveling_V2_mixed.mp3 not found, skipping
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260425-232609-19a08d
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260425-232609-19a08d

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