Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

A library for running tasks(jobs) on schedules.

License

NotificationsYou must be signed in to change notification settings

leosperry/Chroniton

Repository files navigation

Build statusNuGet

Synopsis

A library for running tasks(jobs) on schedules. It supports:

  • Strongly typed jobs with strongly typed parameters
  • Asynchronous execution
  • Running a single job on multiple schedules
  • Running Multiple jobs on a single schedule
  • Cron schedules
  • Run once and expiring schedules
  • Custom schedules
  • Limiting the number of threads on which work is done
  • Managing behaviors of jobs which run beyond their next scheduled time
  • Dependency Injection initialization
  • Full mocking for unit tests
  • .NET Core

SeeWiki andTutorial for more info. Official sitehere.

Code Example

varsingularity=Singularity.Instance;varjob=newSimpleParameterizedJob<string>((parameter,scheduledTime)=>Console.WriteLine($"{parameter}\tscheduled:{scheduledTime.ToString("o")}"));varschedule=newEveryXTimeSchedule(TimeSpan.FromSeconds(1));varscheduledJob=singularity.ScheduleParameterizedJob(schedule,job,"Hello World",true);//starts immediatelyvarstartTime=DateTime.UtcNow.Add(TimeSpan.FromSeconds(5));varscheduledJob2=singularity.ScheduleParameterizedJob(schedule,job,"Hello World 2",startTime);singularity.Start();Thread.Sleep(10*1000);singularity.StopScheduledJob(scheduledJob);Thread.Sleep(5*1000);singularity.Stop();

In the above example, here's what happens:The first job starts immediately and print's "Hello World" once every second.Five seconds later the second job starts and prints "Hello World2" every second.Five seconds later the first job stops and only the second job is running.Five seconds later,Stop() is called and the second job also stops.Notice the same job is used with multiple schedules with different parameters.

Coming Soon !!!

The above code works with the currently released version. A new version with serialization features is on the way and has been started. There will be some breaking changes. If you'd like to see some of the changes coming, check out theSerialization branch. The core logic for how jobs run will not change, but how jobs get added has. I'm personally very excited to be bringing these changes as it opens up a world of possibilites for the project.

Motivation

This project was inspired for the need to have a strongly typed .NET solution for running tasks on schedules.

Installation

in your nuget package manager:

Install-Package Chroniton

for .NET Core use:

Install-Package Chroniton.NetCore

Contributors

Created by : Leonard Sperryleosperry@outlook.com

License

Licensed under the MIT License

Changes

V 1.0.3

  • Cron string support
  • XUnit
  • Simplified constructors for SimpleJob and SimpleParameterizedJob

V 1.0.2

  • Support for run once and expiring jobs

V 1.0.1

  • Simplified Singularity by removing one of the main loops.
  • Added .NET Core support

Future Features

  • Serialization
  • Distributed execution

Notes

Unfortunately, .NET Core projects do not yet support referencing Shared Code projects. Therefore, the .NET Core projects in this solution reference all the files in the shared projects directly.

About

A library for running tasks(jobs) on schedules.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages


[8]ページ先頭

©2009-2025 Movatter.jp