繁体   English   中英

如何在 Hangfire (Postgresql) 中设置成功作业的自动删除

[英]How to setup auto delete of successful jobs in Hangfire (Postgresql)

我有几个作业计划在由 PostgreSql 支持的 Hangfire 中每 5 分钟运行一次。 我看到当使用 SQL 服务器时,成功的作业会自动从数据库中删除。 我在 PostGreStorageOptions 中找不到类似的东西。 知道如何在 postgresql 中设置成功作业的自动删除吗?

见链接: https://discuss.hangfire.io/t/how-to-configure-the-retention-time-of-job/34我写了一个自定义的 class 如:

public class AutoDeleteAfterSuccessAttribute : JobFilterAttribute, IApplyStateFilter
{
    private readonly TimeSpan _deleteAfter;

    public AutoDeleteAfterSuccessAttribute(int hours, int minutes, int seconds)
    {
        _deleteAfter = new TimeSpan(hours, minutes, seconds);
    }

    public void OnStateApplied(ApplyStateContext context, IWriteOnlyTransaction transaction)
    {
        context.JobExpirationTimeout = _deleteAfter;
    }

    public void OnStateUnapplied(ApplyStateContext context, IWriteOnlyTransaction transaction)
    {
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM