
=== 2026-05-14 10:52:56 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/pipeline.py /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/_input.json -o /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43 -cg 2 -cs 2 --skip-feishu --profile __runtime_batch-20260514-105256-3b0c43 --step1-only ===
[profile] ✅ Loaded profile '__runtime_batch-20260514-105256-3b0c43' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260514-105256-3b0c43.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
/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-20260514-105256-3b0c43
Skip Suno: False | Step1 only: True | Version: v4
======================================================================

[10:52:58] 🏥 Health check...
[10:52:59] ✅ qishui: OK
[10:52:59] ✅ netease: OK
[10:52:59] ✅ qq: OK

[10:52:59] 🔍 [01_Piel Canela_20260514] Step 0: Fetching...
[10:52:59] 🔍 [02_Time Of My Life_20260514] Step 0: Fetching...
[10:52:59] 🔍 [03_Loving You_20260514] Step 0: Fetching...
[10:52:59] 🔍 [04_Estrada Branca_20260514] Step 0: Fetching...
[10:52:59] 🔍 [05_You're The One_20260514] Step 0: Fetching...
[10:52:59] 🔍 [06_Jasmine Flower_20260514] Step 0: Fetching...
[10:52:59] 🔍 [07_Palomita Blanca_20260514] Step 0: Fetching...
[10:53:02] ✅ [02_Time Of My Life_20260514] Step 0: netease | 1629c lyrics
[10:53:02] ⬇️  [02_Time Of My Life_20260514] Step 0.5: Download from netease...
[10:53:02] ✅ [03_Loving You_20260514] Step 0: netease | 1273c lyrics
[10:53:02] ⬇️  [03_Loving You_20260514] Step 0.5: Download from netease...
[10:53:02] ⚠️  [netease] 'Piel Canela' too short (102s < 120s), likely a cover/clip, skipping
[10:53:02] 🔄 [01_Piel Canela_20260514] Step 0: retry 1/2 in 5s...
[10:53:04] ✅ [04_Estrada Branca_20260514] Step 0: netease | 899c lyrics
[10:53:04] ⬇️  [04_Estrada Branca_20260514] Step 0.5: Download from netease...
[10:53:04] ✅ [05_You're The One_20260514] Step 0: netease | 7c lyrics
[10:53:04] ⬇️  [05_You're The One_20260514] Step 0.5: Download from netease...
[10:53:05] ✅ [06_Jasmine Flower_20260514] Step 0: netease | 7c lyrics
[10:53:05] ⬇️  [06_Jasmine Flower_20260514] Step 0.5: Download from netease...
[10:53:06] ✅ [03_Loving You_20260514] Step 0.5: 4239420 bytes | 211.8s
[10:53:06] 🔬 [03_Loving You_20260514] Step 0.75: Audio features...
[10:53:07] ✅ [07_Palomita Blanca_20260514] Step 0: netease | 7c lyrics
[10:53:07] ⬇️  [07_Palomita Blanca_20260514] Step 0.5: Download from netease...
[10:53:08] ✅ [02_Time Of My Life_20260514] Step 0.5: 5158556 bytes | 261.5s
[10:53:08] 🔬 [02_Time Of My Life_20260514] Step 0.75: Audio features...
[10:53:10] ⚠️  [netease] 'Piel Canela' too short (102s < 120s), likely a cover/clip, skipping
[10:53:10] 🔄 [01_Piel Canela_20260514] Step 0: retry 2/2 in 10s...
[10:53:23] ✅ [04_Estrada Branca_20260514] Step 0.5: 4602282 bytes | 242.7s
[10:53:23] 🔬 [04_Estrada Branca_20260514] Step 0.75: Audio features...
[10:53:24] ✅ [07_Palomita Blanca_20260514] Step 0.5: 2723632 bytes | 143.4s
[10:53:24] 🔬 [07_Palomita Blanca_20260514] Step 0.75: Audio features...
[10:53:24] ✅ [05_You're The One_20260514] Step 0.5: 7250526 bytes | 360.3s
[10:53:24] 🔬 [05_You're The One_20260514] Step 0.75: Audio features...
[10:53:28] ⚠️  [netease] 'Piel Canela' too short (102s < 120s), likely a cover/clip, skipping
[10:53:28] ❌ [01_Piel Canela_20260514] Step 0: No audio URL
[10:53:29] ✅ [06_Jasmine Flower_20260514] Step 0.5: 5529309 bytes | 276.8s
[10:53:29] 🔬 [06_Jasmine Flower_20260514] Step 0.75: Audio features...
[10:53:42] ✅ [03_Loving You_20260514] Step 0.75: BPM=112.04 Key=D minor (35.7s)
[10:53:42] 🧠 [03_Loving You_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:53:42.569Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "03_Loving You_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514/song_pgc.mp3", "has_features": true}}
/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
[10:53:52] ✅ [02_Time Of My Life_20260514] Step 0.75: BPM=161.66 Key=G minor (44.4s)
[10:53:52] 🧠 [02_Time Of My Life_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:53:52.538Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "02_Time Of My Life_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514/song_pgc.mp3", "has_features": true}}
[   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')
[10:54:10] ✅ [07_Palomita Blanca_20260514] Step 0.75: BPM=101.86 Key=G major (18.1s)
[10:54:10] 🧠 [07_Palomita Blanca_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:54:10.638Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "07_Palomita Blanca_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/07_Palomita Blanca_20260514/song_pgc.mp3", "has_features": true}}
[step1] 🎹 Instrumental mode — empty lyrics fallback
/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
[10:54:22] ✅ [04_Estrada Branca_20260514] Step 0.75: BPM=184.57 Key=C major (39.4s)
[10:54:22] 🧠 [04_Estrada Branca_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:54:22.052Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "04_Estrada Branca_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514/song_pgc.mp3", "has_features": true}}
[   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')
[10:54:55] ✅ [05_You're The One_20260514] Step 0.75: BPM=120.99 Key=A minor (44.7s)
[10:54:55] 🧠 [05_You're The One_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:54:55.400Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "05_You're The One_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/05_You're The One_20260514/song_pgc.mp3", "has_features": true}}
[step1] 🎹 Instrumental mode — empty lyrics fallback
/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')
[10:54:59] ✅ [06_Jasmine Flower_20260514] Step 0.75: BPM=101.02 Key=D# major (37.9s)
[10:54:59] 🧠 [06_Jasmine Flower_20260514] Step 1: Gemini (queuing)...
{"__trace__": true, "ts": "2026-05-14T02:54:59.988Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "06_Jasmine Flower_20260514", "step": "step1", "type": "step_start", "inputs": {"audio": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/06_Jasmine Flower_20260514/song_pgc.mp3", "has_features": true}}
[step1] 🎹 Instrumental mode — empty lyrics fallback
[step1] stripped 'live' from lyrics
  📊 Gemini official: 46s | prompt_tokens=10344 completion=1717
{"__trace__": true, "ts": "2026-05-14T02:55:41.032Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "03_Loving You_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 45.5, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:55:41.032Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "03_Loving You_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 118.463}
[10:55:41] ⚠️  [03_Loving You_20260514] Step 1.5: prompt 1213c > 1000c, compressing...
  📏 [03_Loving You_20260514] prompt 1213c → 884c (smart truncate)
[10:55:41] ✅ [03_Loving You_20260514] Step 1.5: prompt compressed 1213c → 884c
[10:55:41] ✅ [03_Loving You_20260514] Step 1: 45.5s | prompt=884c | prompt_ok=True lyrics_ok=True
[step1] stripped 'live' from lyrics
  📊 Gemini official: 43s | prompt_tokens=11938 completion=1773
{"__trace__": true, "ts": "2026-05-14T02:55:42.826Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "02_Time Of My Life_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 42.8, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:55:42.826Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "02_Time Of My Life_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 110.288}
[10:55:42] ⚠️  [02_Time Of My Life_20260514] Step 1.5: prompt 1046c > 1000c, compressing...
  📏 [02_Time Of My Life_20260514] prompt 1046c → 964c (smart truncate)
[10:55:42] ✅ [02_Time Of My Life_20260514] Step 1.5: prompt compressed 1046c → 964c
[10:55:42] ✅ [02_Time Of My Life_20260514] Step 1: 42.8s | prompt=964c | prompt_ok=True lyrics_ok=True
[step1] stripped 'live' from lyrics
  📊 Gemini official: 50s | prompt_tokens=11150 completion=1435
{"__trace__": true, "ts": "2026-05-14T02:56:32.933Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "04_Estrada Branca_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 50.1, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:56:32.933Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "04_Estrada Branca_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 130.881}
[10:56:32] ⚠️  [04_Estrada Branca_20260514] Step 1.5: prompt 1043c > 1000c, compressing...
  📏 [04_Estrada Branca_20260514] prompt 1043c → 949c (smart truncate)
[10:56:32] ✅ [04_Estrada Branca_20260514] Step 1.5: prompt compressed 1043c → 949c
[10:56:32] ✅ [04_Estrada Branca_20260514] Step 1: 50.1s | prompt=949c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 72s | prompt_tokens=6212 completion=1191
{"__trace__": true, "ts": "2026-05-14T02:56:52.607Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "07_Palomita Blanca_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 71.6, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:56:52.607Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "07_Palomita Blanca_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 161.969}
[10:56:52] ⚠️  [07_Palomita Blanca_20260514] Step 1.5: prompt 1490c > 1000c, compressing...
  📏 [07_Palomita Blanca_20260514] prompt 1490c → 944c (smart truncate)
[10:56:52] ✅ [07_Palomita Blanca_20260514] Step 1.5: prompt compressed 1490c → 944c
[10:56:52] ✅ [07_Palomita Blanca_20260514] Step 1: 71.6s | prompt=944c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 42s | prompt_tokens=13151 completion=1205
{"__trace__": true, "ts": "2026-05-14T02:57:14.914Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "05_You're The One_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 42.0, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:57:14.914Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "05_You're The One_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 139.514}
[10:57:14] ⚠️  [05_You're The One_20260514] Step 1.5: prompt 1241c > 1000c, compressing...
  📏 [05_You're The One_20260514] prompt 1241c → 993c (smart truncate)
[10:57:14] ✅ [05_You're The One_20260514] Step 1.5: prompt compressed 1241c → 993c
[10:57:14] ✅ [05_You're The One_20260514] Step 1: 42.0s | prompt=993c | prompt_ok=True lyrics_ok=True
  📊 Gemini official: 40s | prompt_tokens=10484 completion=976
{"__trace__": true, "ts": "2026-05-14T02:57:33.045Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "06_Jasmine Flower_20260514", "step": "step1", "type": "api_call", "provider": "gemini", "model": "gemini-2.5-pro", "duration_sec": 40.4, "cost_usd": null, "status": "success"}
{"__trace__": true, "ts": "2026-05-14T02:57:33.045Z", "trace_id": "batch-20260514-105256-3b0c43", "song_key": "06_Jasmine Flower_20260514", "step": "step1", "type": "step_end", "status": "success", "duration_sec": 153.057}
[10:57:33] ⚠️  [06_Jasmine Flower_20260514] Step 1.5: prompt 1362c > 1000c, compressing...
  📏 [06_Jasmine Flower_20260514] prompt 1362c → 911c (smart truncate)
[10:57:33] ✅ [06_Jasmine Flower_20260514] Step 1.5: prompt compressed 1362c → 911c
[10:57:33] ✅ [06_Jasmine Flower_20260514] Step 1: 40.4s | prompt=911c | prompt_ok=True lyrics_ok=True

======================================================================
SUMMARY | 273s (4.6min)
======================================================================
✅ Done: 6 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1
[MasterDB] ✅ 批次 batch-20260514-105256-3b0c43 → +0 新增, ~0 更新 | 总计 756 首
[exit 0]

=== 2026-05-14 10:57:34 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/orchestrate_phase2.py /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43 --profile __runtime_batch-20260514-105256-3b0c43 --resume-mode each --skip-feishu ===
[phase2] batch=batch-20260514-105256-3b0c43 pending=6 groups=2
[phase2] group 1/2 -> 02_Time Of My Life_20260514, 03_Loving You_20260514, 04_Estrada Branca_20260514
[profile] ✅ Loaded profile '__runtime_batch-20260514-105256-3b0c43' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260514-105256-3b0c43.yaml
[phase2] 🌐 02_Time Of My Life_20260514: target_language=auto
[profile] ✅ Loaded profile '__runtime_batch-20260514-105256-3b0c43' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260514-105256-3b0c43.yaml
[phase2] 🌐 03_Loving You_20260514: target_language=auto
[profile] ✅ Loaded profile '__runtime_batch-20260514-105256-3b0c43' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260514-105256-3b0c43.yaml
[phase2] 🌐 04_Estrada Branca_20260514: 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-20260514-105256-3b0c43/_manifest.json --resume /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43 --profile __runtime_batch-20260514-105256-3b0c43 --skip-feishu
[phase2] group 2/2 -> all songs already handled, skipping
[10:57:34] 🌐 [02_Time Of My Life_20260514] Step 2: target_language=auto → lang_mode=EN | single-turn
[10:57:34] 🤖 [02_Time Of My Life_20260514] Step 2 Turn 2: 37304 chars ≈ 9326 tokens → claude-sonnet-4-6
[10:57:34] 🌐 [03_Loving You_20260514] Step 2: target_language=auto → lang_mode=EN | single-turn
[10:57:34] 🤖 [03_Loving You_20260514] Step 2 Turn 2: 36661 chars ≈ 9165 tokens → claude-sonnet-4-6
[10:57:34] 🌐 [04_Estrada Branca_20260514] Step 2: target_language=auto → lang_mode=EN | single-turn
[10:57:34] 🤖 [04_Estrada Branca_20260514] Step 2 Turn 2: 36490 chars ≈ 9122 tokens → claude-sonnet-4-6
[10:58:16] ⚠️  [03_Loving You_20260514] Step 2 API: originality 53% < 85% | 1 copied phrases
          ❗ ". Repetition structure: Motif repeats twice, third statement rises a step before resolving down.)" ~ ". Repetition structure: Motif repeats twice, third statement rises a step before resolving down.)" (100%)
[10:58:16] 🔄 [03_Loving You_20260514] Step 2 API: originality retry 1/3...
[10:58:29] ⚠️  [04_Estrada Branca_20260514] Step 2 API: originality 60% < 85% | 1 copied phrases
          ❗ ", with the vocal landing on the root note over a complex minor chord , providing a dark, final resolution.)" ~ ", with the vocal landing on the root note over a complex minor chord , providing a dark, final resolution.)" (100%)
[10:58:29] 🔄 [04_Estrada Branca_20260514] Step 2 API: originality retry 1/3...
[10:58:34] ⚠️  [02_Time Of My Life_20260514] Step 2 API: originality 46% < 85% | 9 copied phrases
          ❗ "Baby" ~ "Baby" (100%)
          ❗ "for a full beat, creating sweet tension before resolving.)" ~ "for a full beat, creating sweet tension before resolving.)" (100%)
          ❗ "Baby" ~ "Baby" (100%)
          ❗ "Baby" ~ "Baby" (100%)
          ❗ "for a full beat, creating sweet tension before resolving.)" ~ "for a full beat, creating sweet tension before resolving.)" (100%)
[10:58:34] 🔄 [02_Time Of My Life_20260514] Step 2 API: originality retry 1/3...
[10:59:08] ⚠️  [03_Loving You_20260514] Step 2 API originality retry 1 failed: Expecting value: line 1 column 1 (char 0)
[10:59:08] ⚠️  [03_Loving You_20260514] Step 2 API: best originality 53% after 3 retries
[10:59:08] ✅ [03_Loving You_20260514] Step 2 API: 《Somewhere Unhurried》 engine=? | 41.9s | in=20261 out=2543 | ~$0.099
[10:59:23] ⚠️  [04_Estrada Branca_20260514] Step 2 API retry 1: originality 66%
[10:59:23] 🔄 [04_Estrada Branca_20260514] Step 2 API: originality retry 2/3...
[10:59:25] ⚠️  [02_Time Of My Life_20260514] Step 2 API originality retry 1 failed: Expecting value: line 1 column 1 (char 0)
[10:59:25] ⚠️  [02_Time Of My Life_20260514] Step 2 API: best originality 46% after 3 retries
[10:59:25] ✅ [02_Time Of My Life_20260514] Step 2 API: 《Gravity Keeps Pulling》 engine=? | 60.0s | in=20357 out=2775 | ~$0.103
[11:00:27] ⚠️  [04_Estrada Branca_20260514] Step 2 API originality retry 2 failed: Expecting value: line 1 column 1 (char 0)
[11:00:27] ⚠️  [04_Estrada Branca_20260514] Step 2 API: best originality 66% after 3 retries
[11:00:27] ✅ [04_Estrada Branca_20260514] Step 2 API: 《Held Pitch》 engine=? | 109.2s | in=42950 out=4683 | ~$0.199
{"timestamp": "2026-05-14T10:57:34.220694+08:00", "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43", "profile": "__runtime_batch-20260514-105256-3b0c43", "concurrency": 3, "resume_mode": "each", "pending_song_count": 6, "groups": [{"group_index": 1, "songs": ["/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514", "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514", "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514"], "success_count": 3, "failed_count": 0, "results": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514/step2_json_b.json", "agent_summary": "API direct: Gravity Keeps Pulling", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/02_Time Of My Life_20260514/step2_json_b.json", "agent_summary": "API direct: Gravity Keeps Pulling", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514/step2_json_b.json", "agent_summary": "API direct: Somewhere Unhurried", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/03_Loving You_20260514/step2_json_b.json", "agent_summary": "API direct: Somewhere Unhurried", "returncode": 0, "stderr": "", "attempt": 1}]}, {"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514/step2_json_b.json", "agent_summary": "API direct: Held Pitch", "returncode": 0, "stderr": "", "attempt": 1, "attempts": [{"status": "success", "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514", "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43/04_Estrada Branca_20260514/step2_json_b.json", "agent_summary": "API direct: Held Pitch", "returncode": 0, "stderr": "", "attempt": 1}]}]}], "resume": {"status": "success", "returncode": 0, "stdout_tail": "p 4: http_403 (non-fatal)\n  🎵 4c9e268d... → complete\n[11:04:52]    🎧 [02_Time Of My Life_20260514] Song 1: https://cdn1.suno.ai/4c9e268d-e849-4913-b352-390cc0ea1ea2.mp3\n[11:04:52]    🎧 [02_Time Of My Life_20260514] Song 2: https://cdn1.suno.ai/e88872f0-8969-4724-8bc8-c909ffd2d84a.mp3\n[11:04:52] 🎛️ [02_Time Of My Life_20260514] Step 3.5: 混音...\n  ✅ submitted: ['e93514f7', '24794079']\n  🎵 e93514f7... → submitted\n  🎵 24794079... → submitted\n[11:05:11]    🎚️ [02_Time Of My Life_20260514] Song 1: edm | 低70/中28/高2%\n  🎵 e93514f7... → queued\n  🎵 24794079... → streaming\n[11:05:27]    🎚️ [02_Time Of My Life_20260514] Song 2: edm | 低69/中28/高4%\n[11:05:27] ✅ [02_Time Of My Life_20260514] Step 3.5: 34.6s | 2 songs mixed\n[11:05:27] ⚠️  [02_Time Of My Life_20260514] Step 4: http_403 (non-fatal)\n  🎵 e93514f7... → streaming\n  🎵 eee765f0... → complete\n  🎵 24794079... → complete\n  🎵 afaa45cd... → complete\n[11:07:01]    🎧 [05_You're The One_20260514] Song 1: https://cdn1.suno.ai/afaa45cd-8a7e-48f9-8748-4eb5dfb85f42.mp3\n[11:07:01]    🎧 [05_You're The One_20260514] Song 2: https://cdn1.suno.ai/eee765f0-d6aa-48c5-b6c7-07d7a492c704.mp3\n[11:07:01] 🎛️ [05_You're The One_20260514] Step 3.5: 混音...\n  ✅ submitted: ['3d4a4cc8', '6757f3a7']\n  🎵 3d4a4cc8... → submitted\n  🎵 6757f3a7... → submitted\n[11:07:18]    🎚️ [05_You're The One_20260514] Song 1: pop | 低61/中37/高2%\n  🎵 3d4a4cc8... → streaming\n  🎵 6757f3a7... → streaming\n[11:07:35]    🎚️ [05_You're The One_20260514] Song 2: edm | 低63/中35/高2%\n[11:07:35] ✅ [05_You're The One_20260514] Step 3.5: 33.3s | 2 songs mixed\n[11:07:35] ⚠️  [05_You're The One_20260514] Step 4: http_403 (non-fatal)\n  🎵 e93514f7... → complete\n[11:07:40]    🎧 [06_Jasmine Flower_20260514] Song 1: https://cdn1.suno.ai/e93514f7-4db2-4760-9e04-2348e5af11e9.mp3\n[11:07:40]    🎧 [06_Jasmine Flower_20260514] Song 2: https://cdn1.suno.ai/24794079-687b-4f9a-968a-43de38e59ce2.mp3\n[11:07:40] 🎛️ [06_Jasmine Flower_20260514] Step 3.5: 混音...\n[11:07:55]    🎚️ [06_Jasmine Flower_20260514] Song 1: rnb | 低50/中50/高0%\n[11:08:09]    🎚️ [06_Jasmine Flower_20260514] Song 2: rnb | 低40/中60/高0%\n[11:08:09] ✅ [06_Jasmine Flower_20260514] Step 3.5: 28.2s | 2 songs mixed\n[11:08:09] ⚠️  [06_Jasmine Flower_20260514] Step 4: http_403 (non-fatal)\n  🎵 6757f3a7... → complete\n  🎵 3d4a4cc8... → complete\n[11:08:57]    🎧 [07_Palomita Blanca_20260514] Song 1: https://cdn1.suno.ai/3d4a4cc8-80ff-470d-a692-2faa6c7237d2.mp3\n[11:08:57]    🎧 [07_Palomita Blanca_20260514] Song 2: https://cdn1.suno.ai/6757f3a7-a364-4619-afe7-cc219d9bb86f.mp3\n[11:08:57] 🎛️ [07_Palomita Blanca_20260514] Step 3.5: 混音...\n[11:09:09]    🎚️ [07_Palomita Blanca_20260514] Song 1: pop | 低51/中48/高1%\n[11:09:20]    🎚️ [07_Palomita Blanca_20260514] Song 2: edm | 低48/中50/高2%\n[11:09:20] ✅ [07_Palomita Blanca_20260514] Step 3.5: 23.5s | 2 songs mixed\n[11:09:20] ⚠️  [07_Palomita Blanca_20260514] Step 4: http_403 (non-fatal)\n  ✅ submitted: ['af11f5ca', 'b31f64c1']\n  🎵 af11f5ca... → submitted\n  🎵 b31f64c1... → submitted\n  🎵 af11f5ca... → queued\n  🎵 b31f64c1... → queued\n  🎵 af11f5ca... → streaming\n  🎵 b31f64c1... → streaming\n  🎵 af11f5ca... → complete\n  🎵 b31f64c1... → complete\n[11:14:26]    🎧 [04_Estrada Branca_20260514] Song 1: https://cdn1.suno.ai/af11f5ca-ad5c-408c-9546-bb78d5453d28.mp3\n[11:14:26]    🎧 [04_Estrada Branca_20260514] Song 2: https://cdn1.suno.ai/b31f64c1-2b55-46b2-a265-ab7c34543c42.mp3\n[11:14:26] 🎛️ [04_Estrada Branca_20260514] Step 3.5: 混音...\n[11:14:43]    🎚️ [04_Estrada Branca_20260514] Song 1: pop | 低35/中64/高0%\n[11:15:00]    🎚️ [04_Estrada Branca_20260514] Song 2: pop | 低54/中46/高0%\n[11:15:00] ✅ [04_Estrada Branca_20260514] Step 3.5: 33.9s | 2 songs mixed\n[11:15:00] ⚠️  [04_Estrada Branca_20260514] Step 4: http_403 (non-fatal)\n\n======================================================================\nSUMMARY | 869s (14.5min)\n======================================================================\n✅ Done: 6 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1\n[MasterDB] ✅ 批次 batch-20260514-105256-3b0c43 → +6 新增, ~0 更新 | 总计 762 首\n", "stderr_tail": "[profile] ✅ Loaded profile '__runtime_batch-20260514-105256-3b0c43' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/__runtime_batch-20260514-105256-3b0c43.yaml\n", "summary": {"timestamp": "2026-05-14T11:15:00.195114+08:00", "wall_clock": 868.7, "total": 7, "success": 6, "awaiting_step2": 0, "failed": 1}}, "status": "success"}
[exit 0]

=== 2026-05-14 11:15:01 exec: /usr/bin/python3 /srv/current/3000music-platform-next/services/music-pipeline/scripts/steps/step5_feishu.py /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43 ===
[Feishu] ✅ Exported 6 songs to: https://ccnu62373cgc.feishu.cn/sheets/JX8bsoSR0hSi0qtEtmRcfxDon9d
[Feishu] 📐 Expanded master sheet from 693 to 799 rows
[Feishu] ✅ Appended 6 new songs to master sheet (rows 694-699)
[MasterDB] ✅ 批次 batch-20260514-105256-3b0c43 → +6 新增, ~0 更新 | 总计 699 首
[Feishu IM] ✅ Text sent: 📊 本批次结果表格：https://ccnu62373cgc.feishu.cn/sheets/JX8bsoSR0hSi
[11:15:11] 📨 Step 5: Sending files to Feishu IM...
[Feishu IM] ✅ [Gravity Keeps Pulling] topic head sent (message_id=om_x100b6f67ad364308b117034b76cec00)
[Feishu IM] ✅ [Gravity Keeps Pulling] Gravity Keeps Pulling_V1_raw.mp3 replied
[Feishu IM] ✅ [Gravity Keeps Pulling] Gravity Keeps Pulling_V1_mixed.mp3 replied
[Feishu IM] ✅ [Gravity Keeps Pulling] Gravity Keeps Pulling_V2_raw.mp3 replied
[Feishu IM] ✅ [Gravity Keeps Pulling] Gravity Keeps Pulling_V2_mixed.mp3 replied
[Feishu IM] ✅ [Somewhere Unhurried] topic head sent (message_id=om_x100b6f67abb2cc84b13d67c43197044)
[Feishu IM] ✅ [Somewhere Unhurried] Somewhere Unhurried_V1_raw.mp3 replied
[Feishu IM] ✅ [Somewhere Unhurried] Somewhere Unhurried_V1_mixed.mp3 replied
[Feishu IM] ✅ [Somewhere Unhurried] Somewhere Unhurried_V2_raw.mp3 replied
[Feishu IM] ✅ [Somewhere Unhurried] Somewhere Unhurried_V2_mixed.mp3 replied
[Feishu IM] ✅ [Held Pitch] topic head sent (message_id=om_x100b6f67a84c8898b15faaab1b71d0f)
[Feishu IM] ✅ [Held Pitch] Held Pitch_V1_raw.mp3 replied
[Feishu IM] ✅ [Held Pitch] Held Pitch_V1_mixed.mp3 replied
[Feishu IM] ✅ [Held Pitch] Held Pitch_V2_raw.mp3 replied
[Feishu IM] ✅ [Held Pitch] Held Pitch_V2_mixed.mp3 replied
[Feishu IM] ✅ [05_You're The One_20260514] topic head sent (message_id=om_x100b6f67a9a280acb150b45084ba22c)
[Feishu IM] ✅ [05_You're The One_20260514] 05_You're The One_20260514_V1_raw.mp3 replied
[Feishu IM] ✅ [05_You're The One_20260514] 05_You're The One_20260514_V1_mixed.mp3 replied
[Feishu IM] ✅ [05_You're The One_20260514] 05_You're The One_20260514_V2_raw.mp3 replied
[Feishu IM] ✅ [05_You're The One_20260514] 05_You're The One_20260514_V2_mixed.mp3 replied
[Feishu IM] ✅ [06_Jasmine Flower_20260514] topic head sent (message_id=om_x100b6f67a6b11080b22066dc890d27e)
[Feishu IM] ✅ [06_Jasmine Flower_20260514] 06_Jasmine Flower_20260514_V1_raw.mp3 replied
[Feishu IM] ✅ [06_Jasmine Flower_20260514] 06_Jasmine Flower_20260514_V1_mixed.mp3 replied
[Feishu IM] ✅ [06_Jasmine Flower_20260514] 06_Jasmine Flower_20260514_V2_raw.mp3 replied
[Feishu IM] ✅ [06_Jasmine Flower_20260514] 06_Jasmine Flower_20260514_V2_mixed.mp3 replied
[Feishu IM] ✅ [07_Palomita Blanca_20260514] topic head sent (message_id=om_x100b6f67a7a76cb8b48664c4d425b76)
[Feishu IM] ✅ [07_Palomita Blanca_20260514] 07_Palomita Blanca_20260514_V1_raw.mp3 replied
[Feishu IM] ✅ [07_Palomita Blanca_20260514] 07_Palomita Blanca_20260514_V1_mixed.mp3 replied
[Feishu IM] ✅ [07_Palomita Blanca_20260514] 07_Palomita Blanca_20260514_V2_raw.mp3 replied
[Feishu IM] ✅ [07_Palomita Blanca_20260514] 07_Palomita Blanca_20260514_V2_mixed.mp3 replied
[Feishu] ✅ Already on file server: /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43
[Feishu] ✅ Archived to GDrive: /mnt/gdrive/music-pipeline/batch-20260514-105256-3b0c43
[Feishu] 📦 Local files kept at: /srv/music-files-platform-next/pipeline/batch-20260514-105256-3b0c43

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