В MVC, где находится код для фоновых задач?
Я использую ASP.NET, но я уверен, что это относится к любым (или большинству) средам MVC.
Когда создается новый веб-проект, вы получаете базовую структуру папок / семантики для вашего кода:
- Контроллеры (запросы на обслуживание от браузеров)
- Модели (хранить и манипулировать данными)
- Просмотры (HTML-страницы)
- Контент (статический контент
- Скрипты (JavaScript)
- App_Data (файлы базы данных)
Это нормально, но что, если я хочу иметь код, который выполняется отдельно от запросов браузера - например, возможно, запрос выполняет некоторый код, но в другом потоке, и продолжает выполняться после завершения запроса. Или если код просто периодически запускается независимо от запроса.
В моем случае код будет работать с данными - генерировать их, очищать и т. Д. - что заставляет меня думать, что они должны использоваться в моделях. Но на самом деле они не "моделируют" данные, они просто работают с ними в фоновом режиме. Есть ли семантическое место для такого рода вещей?
1 ответ
Здесь можно использовать очереди, такие как MSMQ, RabbitMQ и т. Д. Каждый запрос, который должен быть выгружен, может быть поставлен в очередь, и внешняя служба будет извлекать элементы из очереди и начинать обрабатывать их один за другим. Сам сервис может быть обычным сервисом Windows, хотя вы можете использовать WCF здесь. Вы даже можете интегрировать рабочий процесс в него для более сложных сценариев обработки. Я обычно создаю отдельное пространство имен под названием "services.servicename" для этих типов проектов.
РЕДАКТИРОВАТЬ: Вы, вероятно, смотрите на 2 части здесь. Чтобы что-то подобное работало, вам понадобится служба, которая будет принимать запросы от вашего приложения и добавлять их в очередь. И еще один сервис, который фактически обрабатывает очередь. Вы, вероятно, смотрите на 3 различных проекта в своем решении для достижения этой цели. Я уже делал это с WCF раньше, поэтому мои предложения основаны на технологии WCF. Вот как будет выглядеть структура вашего проекта.
- MyCompany.Services.QueueRequest - принимает запросы от вашего приложения.
- MyCompany.Services.QueueRequestContract - предоставляет контракт (интерфейс), который позволяет вашему приложению взаимодействовать со службой QueueRequest.
- MyCompany.Services.QueueProcessor - Фоновый процессор.
Ваша служба QueueRequest будет реализовывать интерфейс в пространстве имен QueueRequestContract вместо своего собственного. Мы делаем это для того, чтобы мы могли повторно использовать этот контракт на уровне приложений для связи со службой. Так это выглядит примерно так.
Ваше приложение -> QueueRequestContract (IMyService) -> Служба QueueRequest (реализует IMyService).