Mar*_*Ene 3 c# quartz-scheduler quartz.net
我创建了一个 ASP.NET MVC 网站。然后我创建了一个名为 Site.Scheduler 的类库,我想在其中放置我所有的触发器和作业。
我为测试目的创建了一个简单的工作
public class CurrencyRatesJob : IJob
{
private readonly IBudgetsRepository budgetsRepository;
public CurrencyRatesJob(IBudgetsRepository budgetsRepository)
{
this.budgetsRepository = budgetsRepository;
}
public void Execute(IJobExecutionContext context)
{
try
{
var budgets = new BudgetsDTO();
var user = new UserDTO();
budgets.Sum = 1;
budgets.Name = "Quartz";
user.Email = "email@g.com";
budgetsRepository.InsertBudget(budgets, user);
}
catch (Exception ex)
{
throw new Quartz.JobExecutionException(ex);
}
}
}
Run Code Online (Sandbox Code Playgroud)
和作业调度程序
public class CurrencyRatesJobScheduler
{
public static void GetCurrencyRates()
{
try
{
IScheduler scheduler = StdSchedulerFactory.GetDefaultScheduler();
IJobDetail job = JobBuilder.Create<CurrencyRatesJob>().Build();
ITrigger trigger = TriggerBuilder.Create()
.StartNow()
.WithSimpleSchedule
(s =>
s.WithIntervalInSeconds(10)
.RepeatForever()
)
.Build();
scheduler.ScheduleJob(job, trigger);
}
catch (Exception ex)
{
ex.ToString();
}
}
}
Run Code Online (Sandbox Code Playgroud)
要在应用程序启动时启动调度程序,我在 Global.asax.cs 中添加了以下内容
CurrencyRatesJobScheduler.GetCurrencyRates();
Run Code Online (Sandbox Code Playgroud)
所以毕竟,我希望这项工作每 10 秒执行一次并将所有信息插入数据库,但它没有做任何事情,我也没有收到任何错误。
有谁知道可能是什么问题?
编辑:
所以我创建了所有必要的表(从 Quartz.NET 执行脚本)并且我在我的类库中添加了一个新的 App.config 文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<appSettings>
<add key="quartz.scheduler.instanceName" value="MyQuartzScheduler" />
<add key="quartz.scheduler.instanceId" value="instance_one" />
<add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz" />
<add key="quartz.threadPool.threadCount" value="10" />
<add key="quartz.threadPool.threadPriority" value="1" />
<add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
<add key="quartz.jobStore.misfireThreshold" value="60000" />
<add key="quartz.jobStore.dataSource" value="default" />
<add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz" />
<add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz" />
<add key="quartz.jobStore.tablePrefix" value="QRTZ_" />
<add key="quartz.dataSource.default.connectionString" value="Server=(local);Database=My.Database;UID=User;PWD=Password" />
<add key="quartz.dataSource.default.provider" value="SqlServer-20" />
<add key="quartz.jobStore.useProperties" value="true" />
</appSettings>
</configuration>
Run Code Online (Sandbox Code Playgroud)
仍然没有运气。除此之外,没有触发器或作业存储在数据库中。
| 归档时间: |
|
| 查看次数: |
7176 次 |
| 最近记录: |