Хабр Курсы для всех
РЕКЛАМА
Практикум, Хекслет, SkyPro, авторские курсы — собрали всех и попросили скидки. Осталось выбрать!
Если для работы каких-то action-методов требуется, чтобы база заведомо содержала данные текущего пользователя, этот подход не годится. Придётся использовать явный вызов DbRefresher.RefreshAsync в теле метода.
а оттуда выбрасывал бы что-то более значимое для доменной области. Например, DuplicatedUserException.
Если обновление в БД происходит по первичному ключу, а, исходя из исключения, это именно так, я бы вообще не делал асинхронный метод.
Если вам важен именно primary key violation в контроллере, то это протаскивание DAL на уровень, где о нем вряд ли должно быть что-то известно.
Но должен отметить, что если используется вышеописанный алгоритм, загрузка СУБД будет одинаковой вне зависимости от того, выполняется обновление в фоне или в самом запросе.
Для типового клиента частота запросов к API будет зависеть от времени выполнения запроса. Чем быстрее запрос — тем быстрее придёт следующий.
Если же перед API поставить какое-нибудь балансировщик или ограничитель запросов — то он, опять-таки, будет измерять загруженность исходя из времени ответа на запрос, а висящие в фоне "хвосты" запросов учитываться не будут.
if (IsAuthorized(actionContext))
Task.Run(
() => DbRefresher.RefreshAsync(actionContext.RequestContext.Principal))
.ContinueWith(t =>
{
LogFactory.For<AuthorizeAndRefreshUserAttribute>()
.ErrorException("Error occured", t.Exception);
}, TaskContinuationOptions.OnlyOnFaulted);
Параллельное обновление данных в ASP.NET Web API