- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在使用 Azure 应用服务为网站运行 Hangfire。我们还用了精彩的swapping mechanism 。这意味着我们不是部署到生产环境,而是部署一个槽并在部署完成后交换它。
问题是,交换槽不断地从hangfire中获取作业。
我想确保只有生产槽实际上正在执行hangfire 作业。挑战在于,无论是生产状态还是非生产状态,都无需重新启动应用程序(双向)即可发生。
我可以在 Azure 中设置插槽粘性应用程序设置,以便我可以确定我是否处于生产模式。这只是给我留下了一个关键问题:
如何启用和禁用我的应用在运行时处理作业?
最佳答案
我为此提出了一个解决方案,该解决方案不需要将 Hangfire 服务分开,如已接受的答案中所述。
public class SkipProcessingPreProdFilter: IElectStateFilter
{
private readonly IServiceProvider _serviceProvider;
public SkipProcessingPreProdFilter(IServiceProvider serviceProvider)
{
_serviceProvider = serviceProvider;
}
public void OnStateElection(ElectStateContext context)
{
if(context.CandidateState.Name == EnqueuedState.StateName)
{
//wait for prd server to pickup job, reschedule keep trying
if (!IsPrdServer())
{
context.CandidateState = new ScheduledState(TimeSpan.FromSeconds(5));
}
}
}
private bool IsPrdServer()
{
var config = _serviceProvider.GetService<IConfiguration>();
var isPrd = config.GetSection("APPSERVICE_SLOT")?.Value?
.Equals("prd", StringComparison.OrdinalIgnoreCase);
return isPrd == true;
}
}
在 Startup.Configure 中执行以下操作:
GlobalJobFilters.Filters.Add(new SkipProcessingPreProdFilter(app.ApplicationServices));
此过滤器在每个作业入队时对其进行检查,并检查服务器是否具有 pre-prd 或 prd 插槽的环境变量。如果不是 prd,它会重新安排作业 5 秒后重试,但下次尝试时(可能)使用新服务器(它会根据您配置的轮询间隔重试)。
此实现有时可能需要重试几次才能最终找到 prd 服务器,特别是如果您具有多个 Web 服务器的水平扩展。如果有人有任何想法可以改进它,我可以将工作引导到具有匹配服务器前缀的其他服务器,请发表评论。
下面是配置了交换槽并使用“横向扩展”配置了 2 个 Web 应用程序实例的 Hangfire 示例。这最终是 4 台服务器。同一实例上的服务器(prd 之前/prd 交换服务器)具有相同的名称前缀,即 LN1SDLWK0006LS。
或者...您可以像评论中提到的那样为每个插槽使用单独的连接字符串。
编辑:我只是再次考虑了一下,如果您为每个插槽执行单独的连接字符串,那么它仍然会在 preprd 挂火中运行应用程序的重复作业的基本列表,这可能会导致许多意想不到的结果。最好是使用 ENV 变量来阻止应用程序启动时挂火和所有基本重复作业的初始化。
关于.net - 仅根据环境拾取服务器上的 Hangfire 任务(交换槽),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51924132/
我有一个非常复杂的 sql 脚本来清理我的数据库,并且会不时手动运行。脚本运行后,我必须立即启动一个经常性的 hangfire 作业,该作业通常每天只执行一次。 为了不忘记运行脚本,我想直接从sql脚
我有 2 个 hangfire 实例/服务器在运行。两者都指向同一个 hangfire 数据库。如何限制其中一个 hangfire 实例仅从特定队列中获取作业并忽略其他队列? 谢谢 最佳答案 启动实例
我有 2 个 hangfire 实例/服务器在运行。两者都指向同一个 hangfire 数据库。如何限制其中一个 hangfire 实例仅从特定队列中获取作业并忽略其他队列? 谢谢 最佳答案 启动实例
我在使用相同数据库的两台服务器上运行了几个 Hangfire 实例。每个实例根据基于服务器名称的某些标准提交要运行的作业,以便没有两个实例运行相同的作业。我注意到它们正在运行相同的作业,这意味着当一个
nuget 包之间有什么区别 HangFire.AspNetCore和 HangFire和 HangFire.core ? 看来我可以将 hangfire 与 ASP .NET MVC Core 项目
我是 hangfire 的新手,我正在尝试设置一种方法来使用我现有的 serilog 记录器在 asp.net web api 中记录事件。这是我的记录器类: public static class
出于冗余原因,我需要使用相同的数据库运行同一服务的多个实例。 我发现了一些关于“Hangfire 多个实例”的问题,但出于不同的目的,然后是我的:通常是关于在同一数据库上为不同的任务运行多个实例,或与
此 documentation说你可以使用 Queue 指定一个队列要调用的方法的属性。这假设您总是希望在同一个队列上执行一个方法。调用 Enqueue 的进程有没有办法指定将作业放入的队列名称(有效
我有一个现有的 api,它按线程存储数据,并使用 HttpContext.Current 进行检索。 . 我正在尝试重构这个类以从 hangfire 作业中调用——我想知道是否有一个等效的静态方法来检
迁移到 asp.net core 2.1 破坏了我们的 Hangfire 作业设置。 在 Program.cs 的 Main 方法中,我们有类似的内容 var webHost = BuildWebHo
根据 hangfire documentation Starting from Hangfire 1.3.0, you are not required to do anything, if your
我刚刚开始使用Hangfire,现在我很喜欢它。 我了解到,Hangfire将成功工作的历史记录保留了1天,之后将其清除。 有没有一种方法可以自定义此默认行为并将历史记录保留任何持续时间(例如7天)?
我们的网络应用程序允许最终用户在 UI 上设置重复作业的队列。 (我们为每个服务器创建一个队列(使用服务器名称)并允许用户选择要运行的服务器)作业的注册方式: RecurringJob.AddOrUp
我有一个应用程序,具有 Multi-Tenancy 。我想在用户上下文下创建后台作业,但我找不到实现它的好方法。 我将解释一下我的架构。我正在使用包含 UserID 的接口(interface) IC
我想将 QUARTZ 作业转换为 hangfire 我有一个带有 Execute 方法的类。 如何在Hangfire中调用该方法。我尝试类似的事情 public static string CRON_
当使用 Hangfire 排队和处理后台作业时,我能够导致发生可重现的内存不足异常。 . 这些作业是简单的 Console.WriteLine 调用,因此我不希望堆内存以这种方式增加。 我的配置是否不
我有 ASP.NET Web API 应用程序。该应用程序使用 Unity 作为 IoC 容器。该应用程序也在使用 Hangfire,我正在尝试配置 Hangfire 以使用 Unity。 所以基于d
从 1.7.8 版本开始,可以将结果从父作业传递到 Hangfire 中的延续作业。但是没有提供文档或示例。在浏览代码时,我意识到我需要使用带有 pushResults: true 参数的 Conti
有没有人使用过 Hangfire 的多个实例? (在不同的应用程序中)使用相同的 SQL DB 进行配置。因此,我不想为每个 hangfire 实例创建新的 SQL 数据库,而是想与多个实例共享同一个
从 1.7.8 版本开始,可以将结果从父作业传递到 Hangfire 中的延续作业。但是没有提供文档或示例。在浏览代码时,我意识到我需要使用带有 pushResults: true 参数的 Conti
我是一名优秀的程序员,十分优秀!