nestjs-scheduling | Skill Performance & Reviews | TopRankSkills

TopRank Skills

Home / Skills / tools / nestjs-scheduling

nestjs-scheduling

maintained by HoangNguyen0403

star 143 account_tree 48 verified_user MIT License
bolt View GitHub

name: NestJS Scheduling description: Distributed cron jobs and locking patterns. metadata: labels: [nestjs, cron, scheduling, redis] triggers: files: ['**/*.service.ts'] keywords: [@Cron, CronExpression, ScheduleModule]

Task Scheduling & Jobs

Priority: P1 (OPERATIONAL)

Background job processing and scheduled task patterns.

  • Problem: @Cron() runs on every instance. In K8s with 3 pods, your "Daily Report" runs 3 times.
  • Solution: Distributed Locking using Redis.
    • Pattern: Using a decorator to wrap the cron method.
    • Logic: SET resource_name my_random_value NX PX 30000 (Redis Atomic Set).

Cron Decorator Pattern

  • Implementation:

    @Cron(CronExpression.EVERY_MINUTE)
    @DistributedLock({ key: 'send_emails', ttl: 5000 })
    async handleCron() {
      // Only runs if lock acquired
    }
    
  • Tools: Use nestjs-redlock or custom Redis wrapper via redlock library.

Job Robustness

  • Isolation: Never perform heavy processing inside the Cron handler.
    • Pattern: Cron -> Push Job ID to Queue (BullMQ) -> Worker processes it.
    • Why: Cron schedulers can get blocked by the Event Loop; Workers are scalable.
  • Error Handling: Wrap ALL cron logic in try/catch. Uncaught exceptions in a Cron job can crash the entire Node process.

chat Comments (0)

chat_bubble_outline

No comments yet. Be the first to share your thoughts!

Skill Details

GitHub Stars 143
GitHub Forks 48
Created Jan 2026
Last Updated il y a 4 mois
tools tools system admin

Related Skills

docker-expert
chevron_right
caffeine
chevron_right
telnyx-network
chevron_right
discord-governance
chevron_right
plex

plex

openclaw
star 2.4k
chevron_right

Build your own?

Join 12,000+ developers contributing to the Claude ecosystem.