DOCS/journey/plans/archive/260102_db_scheduler_management.md
Claude-51124 84c122f030 docs: daily_headlines, companyx_news DB 전환 및 .env 정리 내용 반영
- 6개 스케줄러 모두 DB 전환 완료
- .env 파일 정리 완료
- news_posting_skill.py 원칙 준수 반영
2026-01-02 12:45:17 +09:00

2.1 KiB

DB 기반 동적 스케줄러 관리 시스템

날짜: 2026-01-02 작성자: happybell80 관련 서비스: rb8001 상태: 구현 완료 (Phase 1-7)

→ 상세: troubleshooting/260102_db_scheduler_management.md


목적

main.py 732줄 중 130줄이 스케줄 관련 코드. DB로 이동하여 동적 관리.

테이블 구조

CREATE TABLE IF NOT EXISTS scheduled_jobs (
    id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
    name VARCHAR(100) UNIQUE NOT NULL,
    job_type VARCHAR(50) NOT NULL,
    cron_expression VARCHAR(50) NOT NULL,
    enabled BOOLEAN DEFAULT true,
    config JSONB DEFAULT '{}',
    created_at TIMESTAMPTZ DEFAULT NOW(),
    updated_at TIMESTAMPTZ DEFAULT NOW()
);

Job Type 매핑

job_type 함수 경로 비고
lunch_worldcup app.scheduler.jobs.lunch_worldcup._run_worldcup_with_logging sync 래퍼
diary_generator app.scheduler.jobs.diary_generator._run_diary_generator_with_logging sync 래퍼
naverworks_briefing app.scheduler.jobs.naverworks_briefing._run_briefing_with_logging sync 래퍼
coldmail_briefing app.scheduler.jobs.coldmail_briefing._run_coldmail_briefing_with_logging sync 래퍼
daily_headlines app.scheduler.jobs.daily_headlines._run_headlines_with_logging sync 래퍼, channel_id config 필요
companyx_news app.scheduler.jobs.companyx_news._run_companyx_news_with_logging sync 래퍼

구현 완료 (Phase 1-7)

  • Phase 1-2: app/state/scheduler_repository.py - CRUD 함수
  • Phase 3: app/scheduler/db_loader.py - DB 로더
  • Phase 4: main.py:146-149 - DB 기반 로드로 전환
  • Phase 5: app/router/scheduler_endpoint.py - API 엔드포인트
  • Phase 6: scripts/migrate_schedules_to_db.py - 기존 데이터 마이그레이션 (6개 스케줄러: daily_diary, naverworks_daily, coldmail_daily, lunch_worldcup, daily_headlines, companyx_news)
  • Phase 7: Pydantic Settings 전환 - app/core/config.py에 스케줄러 설정 추가, os.getenv() 제거