2024-07-04 11:02:45 +05:00
|
|
|
using AsbCloudDb.Model;
|
2022-12-02 17:18:16 +05:00
|
|
|
using AsbCloudInfrastructure.Services.DetectOperations;
|
|
|
|
using AsbCloudInfrastructure.Services;
|
2022-01-17 15:33:00 +05:00
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
using System;
|
2022-12-02 17:18:16 +05:00
|
|
|
using System.Threading.Tasks;
|
|
|
|
using System.Threading;
|
2022-12-02 17:44:47 +05:00
|
|
|
using AsbCloudInfrastructure.Background;
|
2023-05-19 16:27:24 +05:00
|
|
|
using AsbCloudApp.Data.SAUB;
|
2023-10-22 19:37:23 +05:00
|
|
|
using AsbCloudDb;
|
2023-10-24 09:23:07 +05:00
|
|
|
using AsbCloudApp.Repositories;
|
2023-11-28 17:32:14 +05:00
|
|
|
using AsbCloudInfrastructure.Background.PeriodicWorks;
|
2022-01-17 15:33:00 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
namespace AsbCloudInfrastructure;
|
|
|
|
|
|
|
|
public class Startup
|
2022-01-17 15:33:00 +05:00
|
|
|
{
|
2024-08-19 10:01:07 +05:00
|
|
|
public static void BeforeRunHandler(IHost host)
|
2022-01-17 15:33:00 +05:00
|
|
|
{
|
2024-08-19 10:01:07 +05:00
|
|
|
using var scope = host.Services.CreateScope();
|
|
|
|
var provider = scope.ServiceProvider;
|
2022-01-17 15:33:00 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
var context = provider.GetRequiredService<IAsbCloudDbContext>();
|
|
|
|
context.Database.EnsureCreatedAndMigrated();
|
2022-01-17 15:33:00 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
// TODO: Сделать инициализацию кеша телеметрии более явной.
|
|
|
|
_ = provider.GetRequiredService<ITelemetryDataCache<TelemetryDataSaubDto>>();
|
|
|
|
_ = provider.GetRequiredService<ITelemetryDataCache<TelemetryDataSpinDto>>();
|
2023-05-19 16:27:24 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
var backgroundWorker = provider.GetRequiredService<PeriodicBackgroundWorker>();
|
|
|
|
backgroundWorker.Add<WorkToDeleteOldReports>(TimeSpan.FromDays(1));
|
|
|
|
backgroundWorker.Add<WellInfoService.WorkWellInfoUpdate>(TimeSpan.FromMinutes(30));
|
|
|
|
backgroundWorker.Add<WorkOperationDetection>(TimeSpan.FromMinutes(0));
|
|
|
|
backgroundWorker.Add<WorkDataSaubStat>(TimeSpan.FromMinutes(0));
|
2024-10-08 11:23:25 +05:00
|
|
|
backgroundWorker.Add<WorkDataSaubStatDrillingQuality>(TimeSpan.FromMinutes(0));
|
2024-08-19 10:01:07 +05:00
|
|
|
backgroundWorker.Add<WorkLimitingParameterCalc>(TimeSpan.FromMinutes(0));
|
|
|
|
backgroundWorker.Add(MakeMemoryMonitoringWork(), TimeSpan.FromMinutes(0));
|
2022-12-02 17:18:16 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
var notificationBackgroundWorker = provider.GetRequiredService<NotificationBackgroundWorker>();
|
|
|
|
}
|
2022-12-02 17:44:47 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
static Work MakeMemoryMonitoringWork()
|
|
|
|
{
|
|
|
|
var workAction = (string _, IServiceProvider _, Action<string, double?> _, CancellationToken _) => {
|
|
|
|
var bytes = GC.GetTotalMemory(false);
|
|
|
|
var bytesString = FromatBytes(bytes);
|
|
|
|
System.Diagnostics.Trace.TraceInformation($"Total memory allocated is {bytesString} bytes. DbContext count is:{AsbCloudDbContext.ReferenceCount}");
|
|
|
|
return Task.CompletedTask;
|
|
|
|
};
|
|
|
|
var work = Work.CreateByDelegate("Memory monitoring", workAction);
|
|
|
|
return work;
|
|
|
|
}
|
2022-12-02 17:44:47 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
static string FromatBytes(long bytes)
|
|
|
|
{
|
|
|
|
const double gigaByte = 1024 * 1024 * 1024;
|
|
|
|
const double megaByte = 1024 * 1024;
|
|
|
|
const double kiloByte = 1024;
|
|
|
|
|
|
|
|
if (bytes > 10 * gigaByte)
|
|
|
|
return (bytes / gigaByte).ToString("### ### ###.## Gb");
|
2022-12-02 17:44:47 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
if (bytes > 10 * megaByte)
|
|
|
|
return (bytes / megaByte).ToString("### ### ###.## Mb");
|
2022-12-02 17:44:47 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
if (bytes > 10 * kiloByte)
|
|
|
|
return (bytes / megaByte).ToString("### ### ###.## Kb");
|
2022-12-02 17:44:47 +05:00
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
return bytes.ToString("### ### ###");
|
2022-01-17 15:33:00 +05:00
|
|
|
}
|
|
|
|
}
|