網(wǎng)站首頁 編程語言 正文
簡要說明
后臺作業(yè)在系統(tǒng)開發(fā)的過程當(dāng)中,是比較常用的功能。因為總是有一些長耗時的任務(wù),而這些任務(wù)我們不是立即響應(yīng)的,例如 Excel 文檔導(dǎo)入、批量發(fā)送短信通知等。
ABP vNext 提供了后臺作業(yè)的支持,并且還提供了對 HangFire 和 RabbitMQ 的后臺作業(yè)集成。開發(fā)人員在使用這些第三方庫的時候,基本就是開箱即用,不需要做其他復(fù)雜的配置。
ABP vNext 的實現(xiàn)就是在 CLR 的?Timer?之上封裝了一層,周期性地執(zhí)行用戶邏輯。
ABP vNext 默認(rèn)提供的?后臺任務(wù)管理器,就是在后臺作業(yè)基礎(chǔ)之上進(jìn)行的封裝。
涉及到后臺任務(wù)的模塊一共有 6 個,它們分別是:
- Volo.Abp.Threading :提供了一些常用的線程組件,其中?AbpTimer?就是在里面實現(xiàn)的。
- Volo.Abp.BackgroundWorkers :后臺任務(wù)的定義和實現(xiàn)。
- Volo.Abp.BackgroundJobs.Abstractions :后臺任務(wù)的一些共有定義。
- Volo.Abp.BackgroundJobs :默認(rèn)的后臺任務(wù)管理器實現(xiàn)。
- Volo.Abp.BackgroundJobs.HangFire :基于 Hangfire 庫實現(xiàn)的后臺任務(wù)管理器。
- Volo.Abp.BackgroundJobs.RabbitMQ :基于 RabbitMQ 實現(xiàn)的后臺任務(wù)管理器。
什么是Hangfire
Hangfire?是一個開源的.NET任務(wù)調(diào)度框架,目前1.6+版本已支持.NET?Core。個人認(rèn)為它最大特點在于內(nèi)置提供集成化的控制臺,方便后臺查看及監(jiān)控。
引用
<PackageReference Include="Volo.Abp.AspNetCore.Mvc" Version="1.0.2" /> <PackageReference Include="Volo.Abp.Autofac" Version="1.0.2" /> <PackageReference Include="Hangfire" Version="1.7.7" /> <PackageReference Include="Hangfire.AspNetCore" Version="1.7.7" /> <PackageReference Include="Hangfire.Dashboard.BasicAuthorization" Version="1.0.2" /> <PackageReference Include="Hangfire.Redis.StackExchange.StrongName" Version="1.7.0" />
啟動
public class Startup
{
public void ConfigureServices(IServiceCollection services)
{
services.AddApplication();
var Configuration = services.GetConfiguration();
GlobalStateHandlers.Handlers.Add(new SucceededStateExpireHandler(int.Parse(Configuration["Hangfire:JobExpirationTimeout"])));
services.AddHostedService();
services.AddHangfire(x =>
{
var connectionString = Configuration["Hangfire:Redis:ConnectionString"];
x.UseRedisStorage(connectionString, new RedisStorageOptions()
{
//活動服務(wù)器超時時間
InvisibilityTimeout = TimeSpan.FromMinutes(60),
Db = int.Parse(Configuration["Hangfire:Redis:Db"])
});
x.UseDashboardMetric(DashboardMetrics.ServerCount)
.UseDashboardMetric(DashboardMetrics.RecurringJobCount)
.UseDashboardMetric(DashboardMetrics.RetriesCount)
.UseDashboardMetric(DashboardMetrics.AwaitingCount)
.UseDashboardMetric(DashboardMetrics.EnqueuedAndQueueCount)
.UseDashboardMetric(DashboardMetrics.ScheduledCount)
.UseDashboardMetric(DashboardMetrics.ProcessingCount)
.UseDashboardMetric(DashboardMetrics.SucceededCount)
.UseDashboardMetric(DashboardMetrics.FailedCount)
.UseDashboardMetric(DashboardMetrics.EnqueuedCountOrNull)
.UseDashboardMetric(DashboardMetrics.FailedCountOrNull)
.UseDashboardMetric(DashboardMetrics.DeletedCount);
});
}
public void Configure(IApplicationBuilder app, IConfiguration Configuration)
{
app.InitializeApplication();
app.UseAuthorization();
var filter = new BasicAuthAuthorizationFilter(new BasicAuthAuthorizationFilterOptions
{
SslRedirect = false,
RequireSsl = false,
LoginCaseSensitive = false,
Users = new[]
{
new BasicAuthAuthorizationUser
{
Login = Configuration["Hangfire:Login"] ,
PasswordClear= Configuration["Hangfire:PasswordClear"]
}
}
});
app.UseHangfireDashboard("", new DashboardOptions
{
Authorization = new[]
{
filter
},
});
var jobOptions = new BackgroundJobServerOptions
{
Queues = new[] { "critical", "test", "default" },
WorkerCount = Environment.ProcessorCount * int.Parse(Configuration["Hangfire:ProcessorCount"]),
ServerName = Configuration["Hangfire:ServerName"],
SchedulePollingInterval = TimeSpan.FromSeconds(1), //計劃輪詢間隔 支持任務(wù)到秒
};
app.UseHangfireServer(jobOptions);
}
}
設(shè)置
///
/// 已完成的job設(shè)置過期,防止數(shù)據(jù)無限增長
///
public class SucceededStateExpireHandler : IStateHandler
{
public TimeSpan JobExpirationTimeout;
public SucceededStateExpireHandler(int jobExpirationTimeout)
{
JobExpirationTimeout = TimeSpan.FromMinutes(jobExpirationTimeout);
}
public string StateName => SucceededState.StateName;
public void Apply(ApplyStateContext context, IWriteOnlyTransaction transaction)
{
context.JobExpirationTimeout = JobExpirationTimeout;
}
public void Unapply(ApplyStateContext context, IWriteOnlyTransaction transaction)
{
}
}
原文鏈接:https://www.cnblogs.com/jackyfei/p/16205512.html
相關(guān)推薦
- 2022-08-31 C++?OpenCV裁剪圖片時發(fā)生報錯的解決方式_C 語言
- 2023-01-15 c++矩陣計算性能對比:Eigen和GPU解讀_C 語言
- 2023-07-05 parcel運行終端報錯Uncaught ReferenceError: parcelRequire
- 2022-04-11 c#?理解csredis庫實現(xiàn)分布式鎖的詳細(xì)流程_C#教程
- 2022-12-08 重溫Python基礎(chǔ)之列表操作_python
- 2022-04-08 Android實現(xiàn)一個簡單的單詞本_Android
- 2022-08-26 Pandas?DataFrame.drop()刪除數(shù)據(jù)的方法實例_python
- 2022-08-30 C#中的委托和事件詳解_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支