最近の 50 回の実行を追跡したい仕事があります。何らかの理由で、状態が私の単純なプロトタイプに保存されているようには見えません:
[PersistJobDataAfterExecution]
public class ApiJob : IJob
{
private const string JobRunsKey = "jobRuns";
private const int HistoryToKeep = 50;
private const string UrlKey = "Url";
public void Execute(IJobExecutionContext context)
{
var jobDataMap = context.JobDetail.JobDataMap;
var url = context.JobDetail.JobDataMap.GetString(UrlKey);
var client = new RestClient(url);
var request = new RestRequest(Method.POST);
var response = client.Execute(request);
var runs = new List<JobRun>();
if (jobDataMap.ContainsKey(JobRunsKey))
{
runs = (List<JobRun>) jobDataMap[JobRunsKey];
}
Console.WriteLine("I'm running so fast!");
runs.Insert(0, new JobRun(){Message = "Hello", Result = JobResult.Ok, TimeForRun = DateTime.UtcNow});
while (runs.Count > HistoryToKeep)
{
runs.RemoveAt(HistoryToKeep);
}
jobDataMap.Put(JobRunsKey, runs);
}
}
で新しいリストを保存しようとしましjobDataMap.Put(JobRunsKey, runs)
たが、次にジョブをトリガーしたときにキーがJobDataMap
. 助言がありますか?