![]() |
VOOZH | about |
dotnet add package Reo.Core.AsyncOperations --version 10.0.210
NuGet\Install-Package Reo.Core.AsyncOperations -Version 10.0.210
<PackageReference Include="Reo.Core.AsyncOperations" Version="10.0.210" />
<PackageVersion Include="Reo.Core.AsyncOperations" Version="10.0.210" />Directory.Packages.props
<PackageReference Include="Reo.Core.AsyncOperations" />Project file
paket add Reo.Core.AsyncOperations --version 10.0.210
#r "nuget: Reo.Core.AsyncOperations, 10.0.210"
#:package Reo.Core.AsyncOperations@10.0.210
#addin nuget:?package=Reo.Core.AsyncOperations&version=10.0.210Install as a Cake Addin
#tool nuget:?package=Reo.Core.AsyncOperations&version=10.0.210Install as a Cake Tool
Набор сервисов для интеграции с микросервисом асинхронных операций.
Этот набор сервисов предназначен для облегчения интеграции с микросервисом Reo.MonitoringAsyncOperations.
Набор сервисов предоставляет абстрактный уровень доступа к функциональности Reo.MonitoringAsyncOperations, что
упрощает интеграцию для клиентских приложений. Вместо того, чтобы напрямую взаимодействовать с микросервисом,
разработчики могут использовать готовые методы и функции, предоставляемые этим набором сервисов.
Для того, чтобы установить сервисы для интеграции с микросервисом асинхронных операций, необходимо добавить
соответствующий пакет Install-Package Reo.Core.AsyncOperations.
Затем зарегистрировать сервисы через следующий метод расширения:
AddAsyncOperationServices(configuration.GetSection(nameof(AuthConfigureOptions)).Get<AuthConfigureOptions>()!.ClientId)
Если ваш сервис не использует AuthConfigureOptions, то передайте наименование сервиса вручную, например:
reo-waste-sources-api.
Этот интерфейс представляет сервис для работы с контекстом запроса. Он предоставляет методы для захвата, получения и удаления контекста запроса. Вот краткое описание каждого метода:
CaptureRequestContext: Этот метод захватывает контекст запроса и возвращает его идентификатор. Он принимает параметр
time, представляющий абсолютное время жизни контекста запроса относительно текущего момента.
GetRequestContext: Этот метод получает контекст запроса по его идентификатору. Если контекст существует, он
возвращает объект типа RequestContextDto, содержащий информацию о контексте запроса. Если контекст не найден, метод
возвращает null.
RemoveRequestContext: Этот метод удаляет контекст запроса по его идентификатору. После удаления контекста запроса, он становится недоступным для дальнейшего использования.
Этот интерфейс представляет фабрику для создания событий о асинхронных операциях. Он предоставляет методы для создания
событий о начале операции, о ошибке операции и о завершении операции. Достаточно создать событие одним из методов,
например CreateRunningEvent, а далее использовать методы SetState, SetResult, SetCompleteDate для изменения
состояние операции. Вот краткое описание каждого метода:
CreateRunningEvent: Этот метод создает событие о начале операции. Принимает идентификатор запроса requestId,
наименование операции name, тип операции type и текстовое описание состояния result.
Если передать name равный null, то в качестве наименования операции будет использоваться path запроса. Например:
/api/v1/elastic/reindex
CreateErrorEvent: Этот метод создает событие о ошибке операции. Принимает параметры такие же, как и предыдущий метод.
CreateCompletedEvent: Этот метод создает событие о завершении операции. Принимает параметры такие же, как и предыдущие методы.
Этот интерфейс представляет сервис для работы с событиями о асинхронных операциях. Он предоставляет метод
SendEventAsync, который отправляет событие о асинхронной операции. Для отправки событий используется MassTransit,
так что удостоверьтесь что у вас он настроен.
Этот интерфейс представляет собой идентификатор контекста запроса. Используя этот интерфейс, можно обеспечить стандартизацию идентификации запросов в системе, что упрощает их отслеживание и управление. Все ваши сервисы, которым требуется доступ к контексту запроса, должны наследовать этот интерфейс.
Захватить контекст нужно до начала выполнения операции в отдельном потоке.
// Захватываем контекст запроса на 6 часов
var requestId = _requestContextService.CaptureRequestContext(TimeSpan.FromHours(6));
_ = Task.Run(async () =>
{
// Передаем идентификатор захваченного контекста запроса в наш сервис
_reindaxable.RequestId = requestId;
// Запускаем асинхронную операцию реиндексации
await _reindaxable.ReindexAsync(default);
// Удаляем контекст запроса после выполнения операции реиндексации
_requestContextService.RemoveContext(requestId);
}, default);
Сервис должен наследовать интерфейс IRequestContextId чтобы можно было передать ему идентификатор захваченного
контекста запроса.
public interface IAsyncReindaxable : IRequestContextId
{
// ...
}
Теперь внутри сервиса нужно вызвать фабрику IAsyncOperationProcessedFactory для создания события о асинхронной
операции и передать в нее свойство RequestId, фабрика в свою очередь получит по этому идентификатору контекст
захваченного запроса и создаст событие, которое нужно отправить, используя IAsyncOperationEventService.
var eventModel = _factory.CreateRunningEvent(RequestId, null, OperationType.Reindex, null);
await _eventService.SendEventAsync(eventModel, token);
// ...
eventModel
.SetState(OperationState.Completed)
.SetResult("Обработано 100% записей")
.SetCompleteDate(_timeService.CurrentDateTime);
await _eventService.SendEventAsync(eventModel, token);
result. Например: Обработано 0%, 10%, 20%
и т.д.waste_source_doc, в
остальных случаях можно передавать его как null, в таком случае в качестве наименования будет использоваться path
из контекста запроса.Данный пакет распространяется под лицензией MIT.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 net10.0 is compatible. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
Showing the top 2 NuGet packages that depend on Reo.Core.AsyncOperations:
| Package | Downloads |
|---|---|
|
Reo.Core.Elastic
Package Description |
|
|
Reo.MnoApi.Sensors
Package Description |
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 10.0.210 | 0 | 6/18/2026 |
| 10.0.209 | 56 | 6/17/2026 |
| 10.0.208 | 57 | 6/17/2026 |
| 10.0.207 | 57 | 6/17/2026 |
| 10.0.206 | 61 | 6/17/2026 |
| 10.0.205 | 86 | 6/16/2026 |
| 10.0.204 | 80 | 6/16/2026 |
| 10.0.203 | 78 | 6/16/2026 |
| 10.0.202 | 88 | 6/16/2026 |
| 10.0.201 | 108 | 6/16/2026 |
| 10.0.200 | 104 | 6/16/2026 |
| 10.0.199 | 103 | 6/16/2026 |
| 10.0.198 | 101 | 6/16/2026 |
| 10.0.197 | 128 | 6/16/2026 |
| 10.0.196 | 108 | 6/16/2026 |
| 10.0.195 | 123 | 6/15/2026 |
| 10.0.194 | 124 | 6/15/2026 |
| 10.0.193 | 123 | 6/15/2026 |
| 10.0.192 | 147 | 6/11/2026 |
| 10.0.191 | 154 | 6/11/2026 |